/* Self-hosted fonts */
@font-face {
  font-family: "Inter";
  src: url("/fonts/inter/Inter-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Inter";
  src: url("/fonts/inter/Inter-SemiBold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Inter";
  src: url("/fonts/inter/Inter-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "JetBrains Mono";
  src: url("/fonts/jetbrains-mono/JetBrainsMono-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "JetBrains Mono";
  src: url("/fonts/jetbrains-mono/JetBrainsMono-SemiBold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "JetBrains Mono";
  src: url("/fonts/jetbrains-mono/JetBrainsMono-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --text: #1a1a1a;
  --muted: #5a5a5a;
  --rule: #e5e5e5;
  --link: #0a58ca;
  --link-hover: #064299;
  --bg: #fafafa;
  --card-bg: #fff;
  --accent: #b5450f;
  --max-w: 720px;
  --max-w-wide: 920px;
  --code-bg: #f0f0f0;
  --selection-bg: #ffe9b8;

  /* Spacing scale */
  --space-xs: 0.5rem;
  --space-sm: 0.75rem;
  --space-md: 1.25rem;
  --space-lg: 2rem;
  --space-xl: 3rem;

  /* Typography */
  --font-body: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-ui: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Monaco, Consolas, monospace;
}

html[data-theme="dark"] {
  --text: #e0e0e0;
  --muted: #aaa;
  --rule: #333;
  --link: #6cb4f5;
  --link-hover: #8ec8ff;
  --bg: #121212;
  --card-bg: #1a1a1a;
  --accent: #e67e45;
  --code-bg: #2a2a2a;
  --selection-bg: #5a4a2a;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  font: 1.0625rem/1.65 var(--font-body);
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main {
  flex: 1;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--space-lg) var(--space-md) var(--space-xl);
  width: 100%;
  outline: none;
}

main.wide { max-width: var(--max-w-wide); }

header.site, footer.site {
  max-width: var(--max-w-wide);
  margin: 0 auto;
  padding: var(--space-md) var(--space-md);
  width: 100%;
}

header.site {
  border-bottom: 1px solid var(--rule);
  display: flex;
  gap: 1.5rem;
  align-items: baseline;
  flex-wrap: wrap;
}

header.site a.brand {
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--text);
  text-decoration: none;
}

header.site nav a {
  font-family: var(--font-ui);
  font-size: 0.92rem;
  color: var(--muted);
  text-decoration: none;
  margin-right: 1rem;
}

header.site nav a:hover { color: var(--link); }

.theme-toggle {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  color: var(--muted);
  background: transparent;
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 0.25rem 0.6rem;
  cursor: pointer;
  margin-left: 0.5rem;
}
.theme-toggle:hover {
  color: var(--link);
  border-color: var(--link);
}

footer.site {
  border-top: 1px solid var(--rule);
  font-family: var(--font-ui);
  font-size: 0.88rem;
  color: var(--muted);
  margin-top: var(--space-xl);
}

footer.site a { color: var(--muted); }
footer.site .row { display: flex; gap: 1.5rem; flex-wrap: wrap; margin-bottom: 0.5rem; }
footer.site .social-links a {
  font-family: var(--font-ui);
  font-size: 0.88rem;
  color: var(--muted);
  text-decoration: none;
  border-bottom: 1px dotted var(--rule);
}
footer.site .social-links a:hover {
  color: var(--link);
  border-bottom-color: var(--link);
}

h1, h2, h3, h4 {
  font-family: var(--font-ui);
  line-height: 1.25;
  color: var(--text);
  margin-top: var(--space-lg);
}

h1 { font-size: 2.25rem; margin-top: var(--space-sm); }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.15rem; }

p, ul, ol { margin: 1rem 0; }

a { color: var(--link); text-decoration: underline; text-underline-offset: 2px; }
a:hover { color: var(--link-hover); }

.lede {
  font-size: 1.15rem;
  line-height: 1.55;
  color: var(--muted);
  margin: 1rem 0 2rem;
}

.meta {
  font-family: var(--font-ui);
  font-size: 0.9rem;
  color: var(--muted);
  margin: var(--space-xs) 0 var(--space-lg);
}

.stats {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  display: flex;
  gap: var(--space-lg);
  flex-wrap: wrap;
  padding: var(--space-md);
  background: var(--card-bg);
  border: 1px solid var(--rule);
  border-radius: 4px;
  margin: var(--space-lg) 0;
}

.stats > div { min-width: 120px; }

.stats b { display: block; font-size: 1.35rem; color: var(--text); }
.stats span { color: var(--muted); font-size: 0.85rem; }

/* Curated intro block on topic hub pages */
.topic-intro {
  background: var(--card-bg);
  border: 1px solid var(--rule);
  border-left: 3px solid var(--accent);
  border-radius: 4px;
  padding: var(--space-md) var(--space-lg);
  margin: var(--space-lg) 0 var(--space-xl);
}
.topic-intro h2 {
  font-size: 1.05rem;
  margin: 0 0 0.5rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
}
.topic-intro h2:not(:first-child) { margin-top: 1.25rem; }
.topic-intro p { margin: 0; }
.topic-intro ul.key-themes {
  list-style: disc;
  padding-left: 1.25rem;
  margin: 0;
}
.topic-intro ul.key-themes li {
  margin: 0.35rem 0;
  font-size: 0.97rem;
  line-height: 1.55;
}
h2.articles-heading {
  font-size: 1.25rem;
  margin-top: var(--space-lg);
  padding-bottom: var(--space-xs);
  border-bottom: 1px solid var(--rule);
}

/* Quick reads section on topic hub pages */
.quick-reads {
  margin: var(--space-lg) 0;
}
.quick-reads h2 {
  font-size: 1.15rem;
  margin-bottom: var(--space-md);
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--rule);
}
.quick-read {
  margin: 1rem 0 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--rule);
}
.quick-read:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.quick-read h3 {
  font-size: 1rem;
  margin: 0 0 0.25rem;
}
.quick-read h3 a {
  color: var(--text);
  text-decoration: none;
}
.quick-read h3 a:hover {
  color: var(--link);
  text-decoration: underline;
}
.quick-read-meta {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--muted);
  margin: 0 0 0.35rem;
}
.quick-read-tldr {
  font-size: 0.97rem;
  line-height: 1.55;
  color: var(--text);
  margin: 0;
}

/* Article card */
.card {
  border-bottom: 1px solid var(--rule);
  padding: var(--space-md) 0;
  transition: background 0.15s ease;
}
.card:last-child { border-bottom: none; }
.card:hover { background: var(--card-bg); }
.card h3 {
  margin: 0 0 0.35rem;
  font-size: 1.1rem;
}
.card h3 a {
  color: var(--text);
  text-decoration: none;
}
.card h3 a:hover { color: var(--link); text-decoration: underline; }
.card .card-meta {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--muted);
  margin-bottom: 0.35rem;
}
.card .summary {
  color: var(--text);
  font-size: 0.97rem;
  line-height: 1.55;
  margin: 0.4rem 0 0.6rem;
}
.card .topics {
  font-family: var(--font-ui);
  font-size: 0.82rem;
}
.card .topics a {
  color: var(--muted);
  text-decoration: none;
  margin-right: 0.75rem;
  border-bottom: 1px dotted var(--rule);
}
.card .topics a:hover { color: var(--link); border-bottom-color: var(--link); }
.card .cta {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.85rem;
  color: var(--accent);
  text-decoration: none;
  margin-left: 0.5rem;
}
.card .cta:hover { text-decoration: underline; }
.card .cta:hover { text-decoration: underline; }

/* Topic list (index of all topics) */
.topic-list {
  list-style: none;
  padding: 0;
  margin: var(--space-lg) 0;
  column-count: 2;
  column-gap: 2.5rem;
}
.topic-list li {
  break-inside: avoid;
  padding: 0.3rem 0;
  font-family: var(--font-ui);
  font-size: 0.95rem;
}
.topic-list a { text-decoration: none; color: var(--text); }
.topic-list a:hover { color: var(--link); text-decoration: underline; }
.topic-list .count {
  color: var(--muted);
  font-size: 0.85rem;
  margin-left: 0.5rem;
}
.topic-list .inert {
  color: var(--muted);
}

/* Breadcrumb */
.breadcrumb {
  font-family: var(--font-ui);
  font-size: 0.87rem;
  color: var(--muted);
  margin: 0 0 var(--space-md);
}
.breadcrumb a { color: var(--muted); }

/* Prose (about page, home intro) */
.prose { font-size: 1.02rem; }
.prose h2 { font-size: 1.3rem; margin-top: 2.5rem; }
.prose ul li { margin: 0.35rem 0; }

/* Raw-data links at the bottom of home */
.data-links {
  font-family: var(--font-ui);
  font-size: 0.92rem;
  background: var(--card-bg);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: var(--space-md);
  margin: var(--space-lg) 0;
}
.data-links h3 { margin-top: var(--space-xs); font-size: 1rem; }
.data-links ul { list-style: none; padding: 0; margin: var(--space-sm) 0 0; }
.data-links li { padding: 0.2rem 0; }
.data-links code {
  font-family: var(--font-mono);
  background: var(--code-bg);
  padding: 0 4px;
  border-radius: 3px;
  font-size: 0.88rem;
}

/* Responsive */
@media (max-width: 600px) {
  h1 { font-size: 1.7rem; }
  h2 { font-size: 1.25rem; }
  body { font-size: 1rem; }
  .topic-list { column-count: 1; }
  .stats { gap: var(--space-md); }
  .stats > div { min-width: auto; }
  header.site { gap: 0.8rem; }
  header.site nav a { margin-right: 0.6rem; }
}

@media (min-width: 600px) and (max-width: 900px) {
  .topic-list { column-count: 2; }
}

/* Article page */
.article-page { max-width: var(--max-w); margin: 0 auto; }
.article-header { margin-bottom: var(--space-lg); }
.archive-notice {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  color: var(--muted);
  background: var(--card-bg);
  border: 1px solid var(--rule);
  border-left: 3px solid var(--accent);
  border-radius: 4px;
  padding: 0.75rem 1rem;
  margin: 0 0 1.25rem;
}
.archive-notice a { color: var(--accent); text-decoration: none; }
.archive-notice a:hover { text-decoration: underline; }
.article-body { font-size: 1.02rem; line-height: 1.7; }
.article-body h2 { font-size: 1.35rem; margin-top: var(--space-xl); }
.article-body h3 { font-size: 1.15rem; margin-top: var(--space-lg); }
.article-body h4 { font-size: 1.05rem; margin-top: var(--space-lg); }
.article-body p { margin: 1.1rem 0; }
.article-body ul, .article-body ol { margin: 1rem 0; padding-left: 1.5rem; }
.article-body li { margin: 0.4rem 0; }
.article-body blockquote {
  border-left: 3px solid var(--rule);
  margin: var(--space-lg) 0;
  padding: var(--space-xs) 0 var(--space-xs) var(--space-md);
  color: var(--muted);
  font-style: italic;
}
.article-body blockquote p { margin: 0.4rem 0; }
.article-body pre {
  background: var(--code-bg);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 1rem;
  overflow-x: auto;
  font-size: 0.92rem;
  line-height: 1.5;
}
.article-body code {
  font-family: var(--font-mono);
  background: var(--code-bg);
  padding: 0.15rem 0.35rem;
  border-radius: 3px;
  font-size: 0.9em;
}
.article-body pre code { background: none; padding: 0; }
.article-body img {
  max-width: 100%;
  height: auto;
  border-radius: 4px;
  margin: 1rem 0;
}
.article-body table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-lg) 0;
  font-size: 0.95rem;
}
.article-body th, .article-body td {
  border: 1px solid var(--rule);
  padding: 0.5rem 0.75rem;
  text-align: left;
}
.article-body th {
  background: var(--card-bg);
  font-weight: 600;
}
.article-body hr {
  border: none;
  border-top: 1px solid var(--rule);
  margin: var(--space-lg) 0;
}
.article-body a { color: var(--link); }
.article-body a:hover { color: var(--link-hover); }
.article-footer {
  margin-top: var(--space-xl);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--rule);
  font-family: var(--font-ui);
  font-size: 0.88rem;
  color: var(--muted);
}
.article-footer p { margin: 0.4rem 0; }
.article-footer a { color: var(--muted); }

/* Errata */
.errata {
  margin: var(--space-xl) 0 var(--space-lg);
  padding: var(--space-md);
  background: var(--card-bg);
  border: 1px solid var(--rule);
  border-radius: 4px;
}
.errata h2 {
  font-size: 1.15rem;
  margin: 0 0 var(--space-sm);
  color: var(--accent);
}
.erratum {
  margin: var(--space-md) 0 0;
  padding-top: var(--space-md);
  border-top: 1px solid var(--rule);
}
.erratum:first-child {
  border-top: none;
  padding-top: 0;
}
.erratum h3 {
  font-size: 1rem;
  margin: 0 0 0.35rem;
}
.erratum-meta {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--muted);
  margin: 0 0 0.6rem;
}
.erratum-type {
  text-transform: capitalize;
  font-weight: 600;
}
.erratum-body {
  font-size: 0.95rem;
  line-height: 1.65;
}
.erratum-body p { margin: 0.5rem 0; }

/* Citation sections (references / referenced by) */
.citation-section {
  margin: var(--space-xl) 0 var(--space-lg);
  padding: var(--space-md);
  background: var(--card-bg);
  border: 1px solid var(--rule);
  border-radius: 4px;
}
.citation-section h2 {
  font-size: 1.15rem;
  margin: 0 0 var(--space-sm);
  color: var(--accent);
}
.citation-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.citation-list li {
  margin: 0.5rem 0;
  font-size: 0.95rem;
  line-height: 1.5;
}
.citation-list a {
  font-weight: 500;
}
.citation-meta {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--muted);
  margin-left: 0.4rem;
}
.citation-truncated {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--muted);
  margin: var(--space-sm) 0 0;
  font-style: italic;
}

/* Table of contents */
.toc {
  background: var(--card-bg);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: var(--space-md);
  margin: var(--space-lg) 0;
}
.toc h2 {
  font-size: 1rem;
  margin: 0 0 var(--space-sm);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
}
.toc ul {
  list-style: none;
  padding: 0;
  margin: 0;
  font-family: var(--font-ui);
  font-size: 0.95rem;
}
.toc li { margin: 0.35rem 0; }
.toc li.toc-level-3 { padding-left: 1.25rem; }
.toc a { color: var(--text); text-decoration: none; }
.toc a:hover { color: var(--link); text-decoration: underline; }

/* Cite this article block */
.cite-block {
  margin: var(--space-xl) 0 var(--space-lg);
  padding: var(--space-md);
  background: var(--card-bg);
  border: 1px solid var(--rule);
  border-radius: 4px;
}
.cite-block h2 {
  font-size: 1.15rem;
  margin: 0 0 var(--space-sm);
  color: var(--accent);
}
.doi-line {
  margin: 0 0 var(--space-sm);
  font-family: var(--font-mono);
  font-size: 0.9rem;
}
.cite-format {
  margin: var(--space-sm) 0 0;
  padding: var(--space-sm);
  background: var(--bg);
  border: 1px solid var(--rule);
  border-radius: 4px;
}
.cite-format summary {
  cursor: pointer;
  font-weight: 600;
  font-size: 0.9rem;
}
.cite-format pre {
  margin: var(--space-sm) 0 0;
  padding: var(--space-sm);
  background: var(--code-bg);
  border-radius: 4px;
  font-size: 0.8rem;
  overflow-x: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

/* Related articles */
.related-articles {
  margin: 2.5rem 0 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule);
}
.related-articles h2 {
  font-size: 1.15rem;
  margin: 0 0 1rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--rule);
}
.related-article {
  margin: 0.75rem 0;
}
.related-article h3 {
  font-size: 1rem;
  margin: 0;
}
.related-article h3 a {
  color: var(--text);
  text-decoration: none;
}
.related-article h3 a:hover {
  color: var(--link);
  text-decoration: underline;
}
.related-meta {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--muted);
  margin: 0.15rem 0 0;
}

/* Selection + focus */
::selection { background: var(--selection-bg); }
a:focus-visible {
  outline: 2px solid var(--link);
  outline-offset: 2px;
  border-radius: 2px;
}


/* Skip link */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--bg);
  color: var(--link);
  padding: 0.5rem 1rem;
  z-index: 100;
  font-family: var(--font-ui);
  font-size: 0.9rem;
  text-decoration: none;
  border: 1px solid var(--rule);
  border-radius: 0 0 4px 0;
}
.skip-link:focus {
  top: 0;
}

/* Button focus */
button:focus-visible,
.theme-toggle:focus-visible {
  outline: 2px solid var(--link);
  outline-offset: 2px;
  border-radius: 2px;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}


/* Search */
.search-box {
  margin: var(--space-lg) 0 var(--space-xl);
}
.search-box input[type="search"] {
  font-family: var(--font-ui);
  font-size: 1rem;
  padding: 0.6rem 0.9rem 0.6rem 2.4rem;
  width: 100%;
  max-width: 100%;
  border: 1px solid var(--rule);
  border-radius: 4px;
  background: var(--card-bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E") no-repeat 0.75rem center;
  color: var(--text);
}
html[data-theme="dark"] .search-box input[type="search"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23aaa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");
}
.search-box input[type="search"]::placeholder {
  color: var(--muted);
}
.search-box input[type="search"]:focus-visible {
  outline: 2px solid var(--link);
  outline-offset: 2px;
}
.search-results {
  margin-top: 1rem;
}
.search-result {
  padding: 0.9rem 0;
  border-bottom: 1px solid var(--rule);
}
.search-result:last-child {
  border-bottom: none;
}
.search-result h3 {
  margin: 0 0 0.25rem;
  font-size: 1rem;
}
.search-result h3 a {
  color: var(--text);
  text-decoration: none;
}
.search-result h3 a:hover {
  color: var(--link);
  text-decoration: underline;
}
.search-meta {
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--muted);
  margin: 0;
}
.search-empty {
  font-family: var(--font-ui);
  font-size: 0.95rem;
  color: var(--muted);
  margin: 0.5rem 0;
}

/* Ask the Archive */
.ask-box {
  margin: var(--space-lg) 0 var(--space-xl);
}
.ask-form {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.ask-form textarea {
  font-family: var(--font-body);
  font-size: 1rem;
  padding: 0.75rem 1rem;
  width: 100%;
  max-width: 100%;
  border: 1px solid var(--rule);
  border-radius: 4px;
  background: var(--card-bg);
  color: var(--text);
  resize: vertical;
}
.ask-form textarea:focus-visible {
  outline: 2px solid var(--link);
  outline-offset: 2px;
}
.ask-form textarea::placeholder {
  color: var(--muted);
}
.ask-form .btn-primary {
  align-self: flex-start;
  font-family: var(--font-ui);
  font-size: 1rem;
  padding: 0.6rem 1.2rem;
  border: none;
  border-radius: 4px;
  background: var(--link);
  color: #fff;
  cursor: pointer;
}
.ask-form .btn-primary:hover {
  background: var(--link-hover);
}
.ask-form .btn-primary:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.ask-loading {
  margin-top: 1rem;
  font-family: var(--font-ui);
  color: var(--muted);
}
.ask-error {
  margin-top: 1rem;
  padding: 0.75rem 1rem;
  border-radius: 4px;
  background: rgba(220, 38, 38, 0.08);
  color: #dc2626;
  font-family: var(--font-ui);
}
.ask-disabled {
  margin-top: 1rem;
  padding: 0.75rem 1rem;
  border-radius: 4px;
  background: var(--surface);
  border: 1px solid var(--rule);
  font-family: var(--font-ui);
}
.ask-answer {
  margin-top: var(--space-lg);
}
.ask-answer h2 {
  font-size: 1.25rem;
  margin-bottom: 0.75rem;
}
.ask-answer p {
  margin-bottom: 0.75rem;
  line-height: 1.7;
}
.ask-citations {
  margin-top: var(--space-lg);
}
.ask-citations h2 {
  font-size: 1.25rem;
  margin-bottom: 0.75rem;
}
.ask-citations ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ask-citations li {
  padding: 0.6rem 0;
  border-bottom: 1px solid var(--rule);
  font-family: var(--font-ui);
  font-size: 0.95rem;
}
.ask-citations li:last-child {
  border-bottom: none;
}
.ask-citation-score {
  color: var(--muted);
  font-size: 0.82rem;
}

/* Visually hidden (accessible label) */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Table overflow guard */
.article-body table {
  display: block;
  overflow-x: auto;
  max-width: 100%;
}

/* Inline style replacements */
.related-topic-list {
  font-family: var(--font-ui);
  font-size: 0.95rem;
}
.related-topic-list a {
  text-decoration: none;
  color: var(--link);
}
.related-topic-list a:hover {
  text-decoration: underline;
}
.sep { color: var(--rule); margin: 0 0.25rem; }
.browse-all { margin-top: var(--space-lg); }
.topic-tag-muted {
  color: var(--muted);
  margin-right: 0.75rem;
}
.citation-block {
  border-left: 3px solid var(--rule);
  padding-left: 1rem;
  margin-left: 0;
  font-style: italic;
  color: var(--muted);
}
