/* === Home / library index — collapsible folder tree === */

.home {
  max-width: 960px;
  margin: 0 auto;
  padding: 56px 32px 160px;
}
@media (max-width: 720px) {
  .home { padding: 32px 20px 120px; }
}

/* ─── Hero ─────────────────────────────────────────────── */
.home-hero {
  margin-bottom: 40px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--rule);
}
.home-hero .kicker { margin-bottom: 12px; }
.home-hero h1 {
  font-family: var(--font-serif-tc);
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 1.2;
  margin: 0 0 14px;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.home-hero p {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--ink-2);
  max-width: 36em;
  margin: 0;
}
.progress-stats {
  display: flex;
  gap: 24px;
  margin-top: 16px;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--ink-3);
  letter-spacing: 0.04em;
}
.progress-stats b {
  color: var(--ink);
  font-size: 1.4em;
  font-weight: 600;
}

/* ─── Library (subspecialty → category → notes) ────────── */
.library {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.subspec {
  margin: 0;
  padding: 32px 0 0;
}
.subspec:first-child { padding-top: 0; }
.subspec-title {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin: 0 0 14px;
  font-family: var(--font-sans-tc);
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--ink);
  border-bottom: 1px solid var(--rule);
  padding-bottom: 10px;
}
.subspec-label { color: var(--ink); }
.subspec-slug {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  color: var(--ink-3);
  text-transform: uppercase;
  font-weight: 500;
}
.subspec-count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--ink-faint);
  font-weight: 400;
  letter-spacing: 0.04em;
}

/* ─── Category (collapsible <details>) ─────────────────── */
.cat {
  margin: 0 0 4px;
  padding: 0;
}
.cat-summary {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 10px 4px 10px 0;
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  list-style: none;
  font-family: var(--font-sans-tc);
  border-bottom: 1px solid var(--rule-soft);
}
.cat-summary::-webkit-details-marker { display: none; }
.cat-summary:hover { background: var(--bg-card); }

.cat-chev {
  display: inline-block;
  width: 14px;
  font-family: var(--font-mono);
  color: var(--ink-faint);
  transition: transform 180ms ease;
  font-size: 1rem;
  line-height: 1;
}
.cat[open] > .cat-summary .cat-chev {
  transform: rotate(90deg);
  color: var(--ink-2);
}
.cat-name {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--ink);
}
.cat-slug {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  color: var(--ink-3);
  text-transform: lowercase;
}
.cat-count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--ink-faint);
  letter-spacing: 0.04em;
}
.cat[open] > .cat-summary .cat-count { color: var(--ink-3); }

/* ─── Notes list (inside each category) ────────────────── */
.notes-list {
  display: flex;
  flex-direction: column;
  padding: 4px 0 12px;
}
.note-row {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 12px 12px 12px 18px;
  border-radius: var(--r-md);
  text-decoration: none;
  color: var(--ink);
  transition: background 120ms;
  margin: 0 -12px;
}
.note-row:hover { background: var(--bg-card); }
.note-row .num {
  font-family: var(--font-mono);
  font-size: 0.76rem;
  color: var(--ink-faint);
  text-align: right;
}
.note-row[data-read="true"] .num::before {
  content: "✓ ";
  color: var(--accent);
}
.note-row .label {
  font-family: var(--font-sans-tc);
  font-weight: 500;
  font-size: 0.98rem;
  line-height: 1.5;
}
.note-row .label .en {
  font-family: var(--font-sans-latin);
  font-weight: 600;
}
.note-row .meta-bits {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  color: var(--ink-3);
  letter-spacing: 0.04em;
  margin-top: 3px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.note-row .meta-bits .tag-cm { color: var(--crit); }
.note-row .meta-bits .tag-hi { color: var(--warn); }
.note-row .arr {
  font-family: var(--font-mono);
  color: var(--ink-faint);
  transition: color 120ms, transform 120ms;
  font-size: 1.05rem;
}
.note-row:hover .arr {
  color: var(--accent);
  transform: translateX(3px);
}
.note-row[data-read="true"] {
  opacity: 0.5;
  transition: opacity 120ms;
}
.note-row[data-read="true"]:hover { opacity: 0.85; }
.note-row[data-read="true"] .label { color: var(--ink-3); }
.note-row[data-read="true"]:hover .label { color: var(--ink-2); }

/* ─── Filter pills ───────────────────────────────────── */
.filter-row {
  display: flex;
  gap: 4px;
  margin: 20px 0 0;
  padding: 4px;
  background: var(--bg-card);
  border: 1px solid var(--rule);
  border-radius: 10px;
  width: fit-content;
}
.filter-pill {
  background: transparent;
  border: 0;
  padding: 7px 14px;
  border-radius: 7px;
  font: inherit;
  font-family: var(--font-sans-latin), var(--font-sans-tc);
  font-size: 0.82rem;
  color: var(--ink-2);
  cursor: pointer;
  letter-spacing: 0.02em;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  line-height: 1;
  min-height: 32px;
}
.filter-pill:hover { color: var(--ink); background: var(--bg-elev); }
.filter-pill[aria-pressed="true"] {
  background: var(--ink);
  color: var(--bg);
}
.filter-pill .count {
  font-family: var(--font-mono);
  font-size: 0.74rem;
  opacity: 0.7;
}

/* Filter visibility */
body[data-filter="unread"] .note-row[data-read="true"] { display: none; }
body[data-filter="read"] .note-row:not([data-read="true"]) { display: none; }
/* Hide empty categories & subspecialties */
body[data-filter] details.cat[data-empty="true"] { display: none; }
body[data-filter] section.subspec[data-empty="true"] { display: none; }

/* Expand/collapse buttons in topbar */
.topbar .ctrl[data-expand-all],
.topbar .ctrl[data-collapse-all] {
  background: var(--bg-card);
  border: 1px solid var(--rule);
  border-radius: 8px;
  margin: 0 1px;
  padding: 6px 10px;
  font-family: var(--font-mono);
  font-size: 0.9rem;
  min-width: 32px;
}
@media (max-width: 480px) {
  .topbar .ctrl[data-expand-all],
  .topbar .ctrl[data-collapse-all] { display: none; }
}
