/* ============================================================
   КОНЦЕПТ A · АРХИВ
   Тёмная навигация, плотный список-каталог, типографика NYT
   ============================================================ */

/* ---------- общий каркас ---------- */
.a-app {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: calc(100vh - 53px);
  background: var(--ink-1);
  color: var(--ink-fg);
  font-family: var(--sans);
}

/* ---------- левый сайдбар: только фильтры ---------- */
.a-side {
  border-right: 1px solid var(--ink-line-soft);
  padding: 28px 0;
  background: var(--ink-1);
  font-size: var(--t-13);
  position: sticky;
  top: 53px;
  align-self: start;
  max-height: calc(100vh - 53px);
  overflow-y: auto;
}
.a-side h4 {
  margin: 0 0 10px;
  padding: 0 24px;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-fg-4);
}
.a-side section + section { margin-top: 28px; }
.a-side ul li {
  padding: 5px 24px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  color: var(--ink-fg-2);
  cursor: pointer;
  font-size: var(--t-13);
  border-left: 2px solid transparent;
  transition: color .12s, background .12s, border-color .12s;
}
.a-side ul li:hover { color: var(--ink-fg); background: var(--ink-2); }
.a-side ul li.is-active {
  color: var(--sage);
  border-left-color: var(--sage);
  background: rgba(143,174,124,.05);
}
.a-side ul li .cnt {
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--ink-fg-4);
  letter-spacing: .04em;
}
.a-side ul li.is-active .cnt { color: var(--sage); }
.a-side .sub {
  padding-left: 36px;
  font-size: 12.5px;
  color: var(--ink-fg-3);
}
.a-side .sub.is-active { color: var(--sage); }
.a-side .tag-cloud {
  padding: 0 22px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 6px;
}
.a-side .tag-cloud span {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .04em;
  color: var(--ink-fg-3);
  padding: 2px 6px;
  border: 1px solid var(--ink-line-soft);
  border-radius: 2px;
  cursor: pointer;
}
.a-side .tag-cloud span:hover { color: var(--sage); border-color: var(--sage); }
.a-side .tag-cloud span.big { color: var(--ink-fg-2); font-size: 12px; }

/* ---------- главная колонка ---------- */
.a-main {
  min-width: 0;
  padding: 0 0 96px;
}

/* верхняя панель: поиск + компактная статистика */
.a-top {
  padding: 26px 40px 0;
}
.a-search {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--ink-2);
  border: 1px solid var(--ink-line);
  border-radius: var(--r-4);
  padding: 11px 14px;
}
.a-search:focus-within {
  border-color: var(--sage);
  box-shadow: 0 0 0 3px rgba(143,174,124,.08);
}
.a-search svg { color: var(--ink-fg-3); }
.a-search input {
  flex: 1;
  border: 0;
  background: transparent;
  outline: none;
  font-family: var(--sans);
  font-size: 14px;
}
.a-search input::placeholder { color: var(--ink-fg-3); }
.a-search .hint {
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--ink-fg-3);
  letter-spacing: .04em;
}
.a-search .hint b { color: var(--sage-3); font-weight: 500; }
.a-search kbd {
  font-family: var(--mono);
  font-size: 10.5px;
  padding: 2px 6px;
  border: 1px solid var(--ink-line);
  border-radius: 2px;
  color: var(--ink-fg-3);
}

/* компактная панель дашборда */
.a-stats {
  margin-top: 18px;
  display: grid;
  grid-template-columns: 1.2fr 1.2fr 1.2fr 2fr;
  gap: 1px;
  background: var(--ink-line-soft);
  border: 1px solid var(--ink-line-soft);
  border-radius: var(--r-4);
  overflow: hidden;
}
.a-stat {
  background: var(--ink-1);
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  cursor: pointer;
  transition: background .12s;
}
.a-stat:hover { background: var(--ink-2); }
.a-stat .k {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-fg-4);
}
.a-stat .v {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 400;
  line-height: 1;
  letter-spacing: -.015em;
  color: var(--ink-fg);
}
.a-stat .v small {
  font-family: var(--serif);
  font-size: 14px;
  color: var(--ink-fg-3);
  font-weight: 400;
  margin-left: 2px;
}
.a-stat .delta {
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--sage);
}
.a-stat.heatmap {
  flex-direction: row;
  align-items: stretch;
  gap: 14px;
}
.a-stat.heatmap .col { display: flex; flex-direction: column; gap: 2px; justify-content: center; }
.a-stat.heatmap .col .k { margin-bottom: 4px; }
.a-stat.heatmap .grid {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(26, 1fr);
  grid-auto-rows: 9px;
  gap: 2px;
}
.a-stat.heatmap .cell { background: var(--ink-2); border-radius: 1px; }
.a-stat.heatmap .cell.l1 { background: rgba(143,174,124,.20); }
.a-stat.heatmap .cell.l2 { background: rgba(143,174,124,.40); }
.a-stat.heatmap .cell.l3 { background: rgba(143,174,124,.70); }
.a-stat.heatmap .cell.l4 { background: var(--sage); }

/* «цитата дня» */
.a-qotd {
  margin: 24px 0 28px;
  padding: 20px 28px 22px;
  background: linear-gradient(180deg, var(--ink-2), var(--ink-1));
  border: 1px solid var(--ink-line-soft);
  border-left: 2px solid var(--sage);
  border-radius: var(--r-4);
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 28px;
  align-items: center;
}
.a-qotd .q {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.35;
  color: var(--ink-fg);
  letter-spacing: -.005em;
  text-wrap: balance;
}
.a-qotd .q::before {
  content: '“';
  font-size: 44px;
  line-height: 0;
  color: var(--sage);
  margin-right: 4px;
  vertical-align: -10px;
}
.a-qotd .src {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .04em;
  color: var(--ink-fg-3);
}
.a-qotd .src b { color: var(--ink-fg-2); font-weight: 500; }
.a-qotd .meta {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-fg-4);
  text-align: right;
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: flex-end;
}
.a-qotd .meta .kanji { font-family: var(--jp); font-size: 14px; color: var(--sage); letter-spacing: 0; text-transform: none; }

/* ---------- список материалов ---------- */
.a-list-head {
  margin: 0 40px;
  padding: 12px 0 12px;
  border-top: 1px solid var(--ink-line);
  border-bottom: 1px solid var(--ink-line);
  display: grid;
  grid-template-columns: 56px 1.4fr 2.2fr .9fr .8fr 1.1fr .8fr;
  gap: 24px;
  align-items: center;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-fg-4);
  position: sticky;
  top: 53px;
  background: var(--ink-1);
  z-index: 5;
}
.a-list-head .h { cursor: pointer; }
.a-list-head .h:hover { color: var(--sage); }
.a-list-head .h.is-sort { color: var(--sage); }
.a-list-head .h.is-sort::after { content: '↓'; margin-left: 4px; }

/* строка материала */
.a-row {
  margin: 0 40px;
  display: grid;
  grid-template-columns: 56px 1.4fr 2.2fr .9fr .8fr 1.1fr .8fr;
  gap: 24px;
  align-items: stretch;
  padding: 14px 0;
  border-bottom: 1px solid var(--ink-line-soft);
  cursor: pointer;
  transition: background .1s;
  position: relative;
}
.a-row:hover { background: var(--ink-2); }
.a-row::before {
  content: '';
  position: absolute;
  left: -40px; top: 0; bottom: 0;
  width: 2px;
  background: transparent;
  transition: background .12s;
}
.a-row:hover::before { background: var(--sage); }

/* обложка-«корешок» */
.a-cover {
  width: 56px;
  height: 78px;
  border-radius: 1px;
  overflow: hidden;
  position: relative;
  box-shadow: var(--sh-2);
  background: var(--ink-3);
}
.a-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* типографическая обложка */
.a-cover.gen {
  display: flex;
  flex-direction: column;
  padding: 5px 5px 5px 5px;
  justify-content: space-between;
  font-family: var(--serif);
  color: rgba(255,255,255,.92);
  text-align: left;
  background: var(--t-article);
}
.a-cover.gen.t-book     { background: var(--t-book); }
.a-cover.gen.t-article  { background: var(--t-article); }
.a-cover.gen.t-lecture  { background: var(--t-lecture); }
.a-cover.gen.t-interview{ background: var(--t-interview); }
.a-cover.gen.t-video    { background: var(--t-video); }
.a-cover.gen.t-note     { background: var(--t-note); color: rgba(40,30,20,.85); }
.a-cover.gen .au {
  font-family: var(--mono);
  font-size: 6.5px;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .8;
  line-height: 1.1;
}
.a-cover.gen .ti {
  font-family: var(--serif);
  font-size: 9px;
  line-height: 1.06;
  font-weight: 500;
  letter-spacing: -.005em;
  /* clamp */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* колонки */
.a-row .au {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-fg-2);
  align-self: start;
  padding-top: 4px;
  line-height: 1.4;
}
.a-row .au .role {
  display: block;
  font-size: 9px;
  letter-spacing: .14em;
  color: var(--ink-fg-4);
  margin-top: 2px;
  text-transform: uppercase;
}
.a-row .ti {
  font-family: var(--serif);
  font-size: 19px;
  line-height: 1.2;
  font-weight: 500;
  letter-spacing: -.015em;
  color: var(--ink-fg);
  align-self: start;
  padding-top: 1px;
}
.a-row .ti .sub {
  display: block;
  font-style: italic;
  font-weight: 400;
  color: var(--ink-fg-3);
  font-size: 14px;
  letter-spacing: 0;
  margin-top: 2px;
  line-height: 1.3;
}
.a-row .ti .orig {
  display: inline-block;
  margin-right: 6px;
  font-family: var(--jp);
  font-weight: 500;
  color: var(--ink-fg-2);
}
.a-row .meta1, .a-row .meta2, .a-row .meta3, .a-row .meta4 {
  font-family: var(--mono);
  font-size: 11.5px;
  color: var(--ink-fg-3);
  letter-spacing: .02em;
  align-self: start;
  padding-top: 4px;
  line-height: 1.5;
}
.a-row .meta1 b { color: var(--ink-fg); font-weight: 500; }
.a-row .meta3 .pub { display: block; color: var(--ink-fg-2); }
.a-row .meta3 .city { display: block; color: var(--ink-fg-4); }
.a-row .meta4 { display: flex; flex-direction: column; gap: 4px; align-items: flex-start; }

/* статус-чип */
.a-status {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
  background: transparent;
  border: 1px solid var(--ink-line);
  color: var(--ink-fg-2);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.a-status::before {
  content: '';
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ink-fg-4);
}
.a-status.s-want    { color: #B8B6D6; border-color: rgba(124,122,160,.4); }
.a-status.s-want::before    { background: var(--s-want); }
.a-status.s-reading { color: #D6BD93; border-color: rgba(181,138,74,.4); }
.a-status.s-reading::before { background: var(--s-reading); }
.a-status.s-done    { color: #B5CFA2; border-color: rgba(143,174,124,.4); }
.a-status.s-done::before    { background: var(--s-done); }
.a-status.s-working { color: #D6A9A9; border-color: rgba(168,107,107,.4); }
.a-status.s-working::before { background: var(--s-working); }

/* прогресс */
.a-progress {
  height: 2px;
  width: 100%;
  background: var(--ink-line);
  border-radius: 1px;
  overflow: hidden;
  margin-top: 6px;
  max-width: 100px;
}
.a-progress span { display: block; height: 100%; background: var(--sage); }

.a-row .quotes {
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--ink-fg-3);
  letter-spacing: .05em;
}
.a-row .quotes b { color: var(--sage-3); font-weight: 500; }

/* —— заметка как «другая» строка —— */
.a-row.is-note {
  background: transparent;
  border-bottom: 1px solid var(--ink-line-soft);
}
.a-row.is-note .a-cover {
  background: transparent;
  box-shadow: none;
  border: 1px dashed var(--ink-line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--jp);
  color: var(--ink-fg-4);
  font-size: 22px;
}
.a-row.is-note .ti {
  font-style: italic;
  font-family: var(--serif);
  color: var(--ink-fg);
  font-weight: 400;
  font-size: 18px;
}
.a-row.is-note .ti::before {
  content: '— ';
  color: var(--sage);
  font-style: normal;
}
.a-row.is-note .au { color: var(--ink-fg-3); }

/* «раздел года» */
.a-year-sep {
  margin: 28px 40px 8px;
  padding: 14px 0 6px;
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: 24px;
  align-items: baseline;
  border-bottom: 1px solid var(--ink-line);
}
.a-year-sep .y {
  font-family: var(--serif);
  font-size: 48px;
  font-weight: 400;
  letter-spacing: -.025em;
  color: var(--sage);
  line-height: 1;
}
.a-year-sep .title {
  font-family: var(--serif);
  font-style: italic;
  font-size: 18px;
  color: var(--ink-fg-2);
  font-weight: 400;
}
.a-year-sep .count {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-fg-4);
}

/* ============================================================
   A · Reader (academic, cream paper)
   ============================================================ */

.a-reader {
  background: var(--paper-1);
  color: var(--paper-fg);
  min-height: calc(100vh - 53px);
  font-family: var(--serif);
  /* slight paper texture */
  background-image:
    radial-gradient(at 80% 0%, rgba(180,140,80,.04), transparent 50%),
    radial-gradient(at 0% 100%, rgba(120,90,40,.04), transparent 50%);
}

.a-reader .a-rd-bar {
  position: sticky;
  top: 53px;
  z-index: 6;
  background: rgba(236,228,208,.84);
  backdrop-filter: blur(10px) saturate(1.15);
  -webkit-backdrop-filter: blur(10px) saturate(1.15);
  border-bottom: 1px solid var(--paper-line-soft);
  padding: 12px 40px;
  display: flex;
  align-items: center;
  gap: 18px;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--paper-fg-2);
}
.a-rd-bar .back {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--paper-fg-3);
}
.a-rd-bar .crumbs {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .04em;
  color: var(--paper-fg-3);
}
.a-rd-bar .crumbs b { color: var(--paper-fg-2); font-weight: 500; }
.a-rd-bar .crumbs em { font-style: italic; }
.a-rd-bar .spacer { flex: 1; }
.a-rd-bar .progress {
  height: 2px; width: 220px;
  background: var(--paper-line-soft);
  border-radius: 1px; position: relative;
}
.a-rd-bar .progress span { position: absolute; left: 0; top: 0; bottom: 0; background: var(--sage-dark); border-radius: 1px; }
.a-rd-bar .progress::after {
  content: attr(data-pages);
  position: absolute; right: -8px; top: 8px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .1em;
  color: var(--paper-fg-3);
  white-space: nowrap;
  transform: translateX(100%);
}
.a-rd-bar .tools {
  display: flex; gap: 4px; align-items: center;
}
.a-rd-bar .tools button {
  width: 32px; height: 32px;
  border-radius: var(--r-4);
  color: var(--paper-fg-3);
}
.a-rd-bar .tools button:hover { background: var(--paper-3); color: var(--paper-fg); }

/* three-column reader layout */
.a-rd-body {
  display: grid;
  grid-template-columns: 240px minmax(0,640px) 320px;
  gap: 60px;
  max-width: 1300px;
  margin: 0 auto;
  padding: 56px 40px 120px;
  align-items: start;
}

/* левая колонка — метаданные и цитаты-bookmarks */
.a-rd-meta {
  position: sticky; top: 110px;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--paper-fg-2);
  align-self: start;
}
.a-rd-meta .type {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--sage-paper-fg);
  margin-bottom: 12px;
}
.a-rd-meta .cover {
  width: 100%;
  aspect-ratio: 2 / 3;
  background: var(--paper-3);
  border-radius: 2px;
  margin-bottom: 18px;
  overflow: hidden;
  box-shadow:
    0 1px 0 rgba(80,60,30,.06),
    0 16px 30px -14px rgba(80,60,30,.35);
}
.a-rd-meta .cover img { width: 100%; height: 100%; object-fit: cover; }

.a-rd-meta dl {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 8px 12px;
  margin: 0 0 18px;
  font-size: 12.5px;
}
.a-rd-meta dt {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--paper-fg-3);
  padding-top: 2px;
}
.a-rd-meta dd { margin: 0; color: var(--paper-fg-2); font-family: var(--sans); }
.a-rd-meta dd em { font-family: var(--serif); font-style: italic; color: var(--paper-fg); }
.a-rd-meta dd .jp { font-family: var(--jp); }

.a-rd-meta .biblio {
  font-family: var(--serif);
  font-style: italic;
  font-size: 13.5px;
  line-height: 1.45;
  color: var(--paper-fg-2);
  border-top: 1px solid var(--paper-line-soft);
  padding-top: 14px;
  margin-top: 4px;
}
.a-rd-meta .biblio .authors { font-style: normal; font-family: var(--sans); font-variant-caps: small-caps; letter-spacing: .04em; color: var(--paper-fg); }

.a-rd-meta .related {
  margin-top: 22px;
  border-top: 1px solid var(--paper-line-soft);
  padding-top: 14px;
}
.a-rd-meta .related h5 {
  margin: 0 0 10px;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--paper-fg-3);
}
.a-rd-meta .related ul li {
  padding: 6px 0;
  font-family: var(--serif);
  font-size: 14px;
  line-height: 1.3;
  color: var(--paper-fg);
  border-top: 1px solid var(--paper-line-soft);
  cursor: pointer;
}
.a-rd-meta .related ul li:first-child { border-top: 0; }
.a-rd-meta .related ul li:hover { color: var(--sage-paper-fg); }
.a-rd-meta .related ul li .au {
  display: block;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--paper-fg-3);
  margin-top: 2px;
}

/* мини-граф связей */
.a-rd-graph {
  margin-top: 22px;
  border-top: 1px solid var(--paper-line-soft);
  padding-top: 14px;
}
.a-rd-graph h5 {
  margin: 0 0 10px;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--paper-fg-3);
}
.a-rd-graph svg { width: 100%; height: 130px; display: block; }

/* центральная колонка — текст */
.a-rd-doc {
  min-width: 0;
  font-family: var(--serif);
  color: var(--paper-fg);
}
.a-rd-doc .eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--sage-paper-fg);
  margin-bottom: 18px;
}
.a-rd-doc h1 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 56px;
  line-height: 1.02;
  letter-spacing: -.025em;
  margin: 0 0 14px;
  text-wrap: balance;
  color: #1F1A14;
}
.a-rd-doc h1 .jp {
  display: block;
  font-family: var(--jp);
  font-weight: 500;
  font-size: 28px;
  letter-spacing: .02em;
  color: var(--paper-fg-3);
  margin-bottom: 14px;
  line-height: 1;
}
.a-rd-doc .deck {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.35;
  color: var(--paper-fg-2);
  margin: 0 0 30px;
  max-width: 30em;
  text-wrap: pretty;
}
.a-rd-doc .by {
  display: flex; gap: 18px; align-items: baseline;
  border-top: 1px solid var(--paper-line);
  border-bottom: 1px solid var(--paper-line);
  padding: 12px 0;
  margin: 0 0 40px;
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--paper-fg-3);
}
.a-rd-doc .by .who {
  font-family: var(--sans);
  font-variant-caps: small-caps;
  letter-spacing: .08em;
  color: var(--paper-fg);
  font-weight: 500;
  font-size: 13px;
}
.a-rd-doc .by .pipe { color: var(--paper-line); }

/* буквица */
.a-rd-doc .lede::first-letter {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 88px;
  float: left;
  line-height: .88;
  margin: 8px 10px 0 -2px;
  color: var(--sage-paper-fg);
  font-feature-settings: 'ss01';
}
.a-rd-doc p {
  font-family: var(--serif);
  font-size: 18.5px;
  line-height: 1.58;
  color: var(--paper-fg);
  margin: 0 0 20px;
  max-width: 30em;
  text-wrap: pretty;
  font-feature-settings: 'kern', 'liga', 'onum';
}

.a-rd-doc h2 {
  font-family: var(--sans);
  font-variant-caps: small-caps;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: .14em;
  color: var(--sage-paper-fg);
  margin: 36px 0 14px;
  padding-top: 22px;
  border-top: 1px solid var(--paper-line-soft);
}

/* цитата как pull-quote с привязкой к странице */
.a-rd-doc blockquote {
  margin: 32px 0 28px;
  padding: 6px 0 6px 22px;
  border-left: 2px solid var(--sage-dark);
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.4;
  color: var(--paper-fg);
  position: relative;
}
.a-rd-doc blockquote::before {
  content: '“';
  position: absolute;
  left: -2px; top: -22px;
  font-size: 64px;
  line-height: 1;
  color: var(--sage);
  font-style: normal;
}
.a-rd-doc blockquote cite {
  display: block;
  margin-top: 10px;
  font-family: var(--mono);
  font-style: normal;
  font-size: 10.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--paper-fg-3);
}
.a-rd-doc blockquote cite b { color: var(--sage-paper-fg); font-weight: 500; }

/* japanese inline */
.a-rd-doc .jp-inline { font-family: var(--jp); color: var(--paper-fg-2); }

/* footnote-ref */
.a-rd-doc sup {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--sage-paper-fg);
  vertical-align: super;
  margin-left: 2px;
  cursor: pointer;
}

/* правая колонка — заметки */
.a-rd-notes {
  position: sticky;
  top: 110px;
  align-self: start;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--paper-fg-2);
  max-height: calc(100vh - 130px);
  overflow-y: auto;
  padding-right: 4px;
}
.a-rd-notes h5 {
  margin: 0 0 14px;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--paper-fg-3);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.a-rd-notes h5 .count { color: var(--sage-paper-fg); }

.a-rd-notes .tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--paper-line-soft);
  margin-bottom: 18px;
}
.a-rd-notes .tabs button {
  flex: 1;
  padding: 8px 0 10px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--paper-fg-3);
  border-bottom: 1px solid transparent;
  margin-bottom: -1px;
}
.a-rd-notes .tabs button.is-active {
  color: var(--sage-paper-fg);
  border-color: var(--sage-paper-fg);
}
.a-rd-notes .tabs button:hover { color: var(--paper-fg); }

.a-rd-note {
  padding: 14px 0 14px;
  border-top: 1px solid var(--paper-line-soft);
  position: relative;
}
.a-rd-note:first-of-type { border-top: 0; padding-top: 0; }
.a-rd-note .pg {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .08em;
  color: var(--sage-paper-fg);
  margin-bottom: 6px;
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.a-rd-note .pg .date { color: var(--paper-fg-4); letter-spacing: .12em; text-transform: uppercase; font-size: 9.5px; }
.a-rd-note .body {
  font-family: var(--serif);
  font-style: italic;
  font-size: 15px;
  line-height: 1.5;
  color: var(--paper-fg);
}
.a-rd-note .body b { font-style: normal; font-weight: 500; color: var(--sage-paper-fg); }
.a-rd-note.q .body { font-style: normal; }
.a-rd-note.q .body::before { content: '“'; color: var(--sage-paper-fg); margin-right: 2px; font-size: 18px; line-height: 0; vertical-align: -4px; }
.a-rd-note.q .body::after  { content: '”'; color: var(--sage-paper-fg); margin-left: 2px; font-size: 18px; line-height: 0; vertical-align: -4px; }
.a-rd-note .tags {
  margin-top: 8px;
  display: flex; gap: 6px; flex-wrap: wrap;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .04em;
  color: var(--paper-fg-3);
}
.a-rd-note .tags span:hover { color: var(--sage-paper-fg); cursor: pointer; }
