/* components.css — styles for Hero/ABDemo/MapMdReveal/MCPTools/Sections */

/* ==================== HERO TERM ==================== */
.hero-right { position: relative; }
.hero-right .term { max-width: 560px; margin-left: auto; }

/* ==================== A/B DEMO ==================== */
.demo-task {
  background: var(--term-bg-2);
  border: 1px solid rgba(232,225,208,0.08);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  margin-bottom: 28px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px 32px;
  align-items: center;
}
.demo-task-label {
  grid-column: 1; grid-row: 1;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--term-muted);
}
.demo-task-body { grid-column: 1; grid-row: 2; display: flex; flex-direction: column; gap: 4px; }
.demo-task-quote { font-family: var(--font-serif); font-size: 22px; color: var(--term-fg); font-style: italic; }
.demo-task-meta  { font-family: var(--font-mono); font-size: 12px; color: var(--term-dim); }
.demo-task-controls { grid-column: 2; grid-row: 1 / 3; display: flex; align-items: center; gap: 12px; }
.demo-btn {
  display: inline-flex; align-items: center; gap: 6px;
  font: 500 13px var(--font-sans);
  padding: 10px 18px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(232,225,208,0.2);
  background: transparent; color: var(--term-fg);
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--dur-fast);
}
.demo-btn:hover { background: rgba(232,225,208,0.06); border-color: rgba(232,225,208,0.4); }
.demo-btn-primary { background: var(--clay-600); border-color: var(--clay-600); color: #fff; }
.demo-btn-primary:hover { background: var(--clay-700); border-color: var(--clay-700); }
.demo-task-time {
  display: flex; flex-direction: column; align-items: flex-end; gap: 0;
  padding-left: 12px; border-left: 1px solid rgba(232,225,208,0.1);
  margin-left: 4px;
}
.demo-task-time-k { font-family: var(--font-mono); font-size: 10px; color: var(--term-dim); letter-spacing: 0.06em; text-transform: uppercase; }
.demo-task-time-v { font-family: var(--font-mono); font-size: 18px; color: var(--term-fg); font-variant-numeric: tabular-nums; }

.demo-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
@media (max-width: 1100px) { .demo-grid { grid-template-columns: 1fr; } }

.runner {
  background: transparent;
  border-radius: var(--radius-lg);
}
.runner-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 0 14px 0;
  gap: 16px;
  flex-wrap: wrap;
}
.runner-meters { flex: 0 0 auto; }
.runner-title { display: flex; flex-direction: column; gap: 4px; }
.runner-chip {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-sans); font-size: 14px; font-weight: 600;
  color: var(--term-fg);
}
.runner-sub { font: 400 12px var(--font-sans); color: var(--term-muted); }
.runner-meters { display: flex; gap: 24px; align-items: center; flex: 0 0 auto; }
.meter { display: flex; flex-direction: column; align-items: flex-end; min-width: 56px; }
.meter-status { min-width: 72px; }
.meter-k { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--term-dim); }
.meter-v { font-family: var(--font-mono); font-size: 18px; color: var(--term-fg); font-variant-numeric: tabular-nums; }
.meter-v.ok { color: var(--term-green); }
.meter-v.running { color: var(--term-yellow); }

.runner-term { border: 1px solid rgba(232,225,208,0.08); }
.runner-vanilla .runner-term { border-top: 2px solid var(--ink-300); }
.runner-smart .runner-term { border-top: 2px solid var(--clay-500); box-shadow: var(--shadow-lg), 0 0 0 1px rgba(204, 120, 92, 0.2); }

.tool-line {
  display: grid; grid-template-columns: 170px 1fr auto; gap: 12px;
  padding: 3px 0; font-family: var(--font-mono); font-size: 12.5px;
  border-bottom: 1px dashed rgba(232,225,208,0.04);
  align-items: baseline;
}
.tl-tool { color: var(--term-blue); font-weight: 500; }
.tl-tool.tl-carto { color: var(--clay-500); }
.tl-label { color: var(--term-fg); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tl-info { color: var(--term-dim); font-size: 11.5px; text-align: right; }

.demo-scoreboard {
  margin-top: 28px;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
}
@media (max-width: 960px) { .demo-scoreboard { grid-template-columns: 1fr 1fr; } }
.score-card {
  background: var(--term-bg-2);
  border: 1px solid rgba(232,225,208,0.08);
  border-radius: var(--radius-md);
  padding: 16px 18px;
}
.score-label { font: 500 11px var(--font-mono); letter-spacing: 0.06em; text-transform: uppercase; color: var(--term-dim); margin-bottom: 10px; }
.score-row { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.score-v { display: flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 14px; color: var(--term-fg); font-variant-numeric: tabular-nums; }
.score-vanilla { color: var(--ink-300); }
.score-smart { color: var(--term-fg); font-weight: 500; }
.score-dot { width: 8px; height: 8px; border-radius: 999px; background: var(--ink-400); flex: 0 0 auto; }
.score-dot-smart { background: var(--clay-500); }
.score-delta { font: 500 12px var(--font-sans); color: var(--clay-300); font-style: italic; }

/* ==================== MAP.MD ==================== */
.mapmd {
  display: grid; grid-template-columns: 260px 1fr;
  gap: 24px;
  background: var(--paper-2);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-xl);
  overflow: hidden;
  min-height: 640px;
}
@media (max-width: 900px) { .mapmd { grid-template-columns: 1fr; } }

.mapmd-toc {
  background: var(--paper-3);
  border-right: 1px solid var(--border-soft);
  padding: 24px 12px 24px 20px;
  display: flex; flex-direction: column;
}
.mapmd-toc-head { padding-bottom: 16px; border-bottom: 1px solid var(--border-soft); margin-bottom: 12px; }
.mapmd-toc-title { font-family: var(--font-mono); font-size: 13px; color: var(--fg-strong); font-weight: 600; }
.mapmd-toc-meta { font-family: var(--font-mono); font-size: 11px; color: var(--fg-muted); margin-top: 4px; }
.mapmd-toc-item {
  display: flex; align-items: center; gap: 10px;
  width: 100%; text-align: left;
  padding: 8px 12px; border: 0; background: transparent; cursor: pointer;
  font: 500 13px var(--font-sans); color: var(--fg-secondary);
  border-radius: var(--radius-sm);
  transition: all var(--dur-fast);
}
.mapmd-toc-item:hover { background: var(--paper); color: var(--fg-strong); }
.mapmd-toc-item.active { background: var(--paper); color: var(--fg-strong); box-shadow: inset 2px 0 0 var(--clay-600); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; margin-left: -20px; padding-left: 32px; }
.mapmd-toc-icon { font-family: var(--font-mono); font-size: 12px; color: var(--clay-600); width: 14px; text-align: center; }
.mapmd-toc-foot { margin-top: auto; padding-top: 16px; border-top: 1px solid var(--border-soft); }

.mapmd-doc {
  background: var(--paper);
  overflow-y: auto;
  padding: 40px 56px 40px 48px;
  max-height: 700px;
  font-family: var(--font-serif);
}
.mapmd-header { padding-bottom: 24px; border-bottom: 1px solid var(--border-hair); margin-bottom: 32px; }
.mapmd-meta { font-family: var(--font-mono); font-size: 11px; color: var(--fg-muted); letter-spacing: 0.04em; margin-bottom: 12px; }
.mapmd-h1 { font-family: var(--font-serif); font-size: 44px; line-height: 1.05; letter-spacing: -0.02em; font-weight: 400; color: var(--fg-strong); margin: 0 0 16px; }
.mapmd-tldr { font-family: var(--font-serif); font-size: 18px; line-height: 1.6; color: var(--fg-secondary); margin: 0; }
.mapmd-tldr code { background: var(--paper-3); padding: 1px 6px; border-radius: 3px; font-size: 14px; color: var(--clay-700); margin: 0 3px; }

.mapmd-section { padding: 32px 0; border-bottom: 1px solid var(--border-hair); }
.mapmd-section:last-of-type { border-bottom: 0; }
.mapmd-section-head { display: flex; align-items: baseline; gap: 12px; margin-bottom: 16px; }
.mapmd-section-n { font-family: var(--font-mono); font-size: 12px; color: var(--fg-subtle); letter-spacing: 0.08em; }
.mapmd-h2 { font-family: var(--font-serif); font-size: 28px; line-height: 1.2; letter-spacing: -0.01em; font-weight: 500; color: var(--fg-strong); margin: 0; }
.mapmd-section p { font-family: var(--font-serif); font-size: 17px; line-height: 1.65; color: var(--fg-primary); margin: 0 0 14px; }
.mapmd-section code { background: var(--paper-2); padding: 1px 6px; border-radius: 3px; font-size: 14px; color: var(--ink-800); font-family: var(--font-mono); }

.mapmd-ul, .mapmd-ol { margin: 0 0 12px; padding-left: 24px; }
.mapmd-ul li, .mapmd-ol li { font-family: var(--font-serif); font-size: 17px; line-height: 1.6; color: var(--fg-primary); margin-bottom: 10px; }
.mapmd-ul-dim li { color: var(--fg-muted); }
.mapmd-ol li strong { color: var(--fg-strong); font-weight: 600; }

.mapmd-note {
  padding: 16px 20px;
  border-left: 3px solid var(--clay-500);
  background: var(--clay-50);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  margin: 16px 0;
  font-family: var(--font-serif); font-size: 16px; line-height: 1.6;
  color: var(--ink-800);
}
.mapmd-note-k { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--clay-700); margin-bottom: 6px; font-weight: 600; }
.mapmd-note-red { border-left-color: var(--danger-500); background: rgba(192, 80, 59, 0.08); }
.mapmd-note-red .mapmd-note-k { color: var(--danger-700); }
.mapmd-note-clay { background: var(--paper-3); border-left-color: var(--clay-500); }

.mapmd-table { border-collapse: collapse; width: 100%; margin: 12px 0; }
.mapmd-table td { padding: 8px 16px 8px 0; font-size: 14px; border-bottom: 1px solid var(--border-hair); font-family: var(--font-sans); color: var(--fg-primary); vertical-align: top; }
.mapmd-table td:first-child { font-family: var(--font-mono); font-size: 13px; color: var(--ink-800); font-weight: 500; width: 220px; }
.mapmd-table td:last-child { color: var(--fg-muted); font-size: 13px; }

.mapmd-path { display: grid; grid-template-columns: 120px 1fr; gap: 16px; padding: 10px 0; border-bottom: 1px dashed var(--border-hair); align-items: baseline; }
.mapmd-path-k { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-muted); }
.mapmd-path-v { font-family: var(--font-mono); font-size: 13px; color: var(--ink-800); background: var(--paper-2); padding: 6px 10px; border-radius: 4px; word-break: break-all; }
.mapmd-path-plain { background: transparent; padding: 0; font-family: var(--font-serif); font-size: 16px; color: var(--fg-primary); }

.mapmd-foot { margin-top: 32px; padding-top: 20px; border-top: 1px solid var(--border-hair); }
.mapmd-foot-k { font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); letter-spacing: 0.04em; }

/* ==================== MCP TOOLS ==================== */
.mcp {
  display: grid; grid-template-columns: 280px 1fr;
  gap: 24px;
  background: var(--paper);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-xl);
  overflow: hidden;
  min-height: 560px;
}
@media (max-width: 900px) { .mcp { grid-template-columns: 1fr; } }

.mcp-list {
  background: var(--paper-3);
  border-right: 1px solid var(--border-soft);
  padding: 20px 12px;
  display: flex; flex-direction: column; gap: 4px;
}
.mcp-item {
  display: flex; align-items: center; gap: 12px;
  width: 100%; padding: 12px 14px;
  background: transparent; border: 0; border-radius: var(--radius-sm);
  cursor: pointer; text-align: left;
  transition: all var(--dur-fast);
}
.mcp-item:hover { background: var(--paper-2); }
.mcp-item.active { background: var(--paper); box-shadow: var(--shadow-sm), inset 2px 0 0 var(--clay-600); }
.mcp-icon { font-family: var(--font-mono); font-size: 18px; color: var(--clay-600); width: 24px; text-align: center; }
.mcp-item-body { display: flex; flex-direction: column; }
.mcp-item-name { font-family: var(--font-mono); font-size: 13px; color: var(--fg-strong); font-weight: 500; }
.mcp-item-tag { font: 400 11px var(--font-sans); color: var(--fg-muted); margin-top: 2px; }

.mcp-detail { padding: 36px 40px; display: flex; flex-direction: column; gap: 20px; }
.mcp-detail-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.mcp-detail-title { font-family: var(--font-mono); font-size: 28px; color: var(--fg-strong); margin: 0; font-weight: 500; letter-spacing: -0.01em; }
.mcp-detail-purpose { font-family: var(--font-serif); font-size: 18px; line-height: 1.5; color: var(--fg-secondary); margin: 8px 0 0; max-width: 560px; }
.mcp-icon-lg { font-family: var(--font-mono); font-size: 48px; color: var(--clay-300); opacity: 0.6; line-height: 1; }

.mcp-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-muted); font-weight: 600; }
.mcp-signature { background: var(--paper-2); border: 1px solid var(--border-hair); border-radius: var(--radius-md); padding: 14px 18px; }
.mcp-signature .mcp-label { margin-bottom: 6px; }
.mcp-signature code { font-family: var(--font-mono); font-size: 13px; color: var(--ink-800); background: transparent; padding: 0; }

.mcp-io { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 760px) { .mcp-io { grid-template-columns: 1fr; } }
.mcp-io-col { display: flex; flex-direction: column; gap: 8px; }
.mcp-io-head { display: flex; justify-content: space-between; align-items: center; }
.mcp-copy {
  font: 500 11px var(--font-mono);
  background: transparent; border: 1px solid var(--border-soft); color: var(--fg-secondary);
  padding: 4px 10px; border-radius: var(--radius-pill); cursor: pointer;
  transition: all var(--dur-fast);
}
.mcp-copy:hover { background: var(--paper-2); color: var(--fg-strong); }
.mcp-io-badge { font: 500 10px var(--font-mono); color: var(--clay-600); letter-spacing: 0.06em; text-transform: uppercase; }
.mcp-code {
  background: var(--term-bg); color: var(--term-fg);
  font: 400 12.5px/1.6 var(--font-mono);
  padding: 16px 18px; border-radius: var(--radius-md);
  margin: 0; overflow: auto; max-height: 260px;
  white-space: pre-wrap; word-break: break-word;
}
.mcp-code-req { border: 1px solid rgba(232,225,208,0.08); }
.mcp-code-res { border: 1px solid rgba(204,120,92,0.3); }
.mcp-footnote { font-family: var(--font-serif); font-size: 15px; color: var(--fg-muted); font-style: italic; border-top: 1px solid var(--border-hair); padding-top: 16px; }

/* ==================== HOW IT WORKS ==================== */
.hiw { display: grid; grid-template-columns: 280px 1fr; gap: 32px; align-items: start; }
@media (max-width: 900px) { .hiw { grid-template-columns: 1fr; } }

.hiw-rail { display: flex; flex-direction: column; gap: 4px; }
.hiw-rail-item {
  display: grid; grid-template-columns: auto 1fr; grid-template-rows: auto auto;
  gap: 2px 16px;
  text-align: left;
  background: transparent; border: 0; padding: 16px 20px;
  border-left: 2px solid var(--border-soft);
  cursor: pointer;
  transition: all var(--dur-base);
}
.hiw-rail-item:hover { background: var(--paper-2); }
.hiw-rail-item.active { border-left-color: var(--clay-600); background: var(--paper-2); }
.hiw-rail-n { grid-row: 1 / 3; font-family: var(--font-mono); font-size: 22px; font-weight: 500; color: var(--fg-subtle); align-self: center; }
.hiw-rail-item.active .hiw-rail-n { color: var(--clay-600); }
.hiw-rail-k { font-family: var(--font-serif); font-size: 20px; font-weight: 500; color: var(--fg-strong); line-height: 1.1; }
.hiw-rail-t { font: 400 13px var(--font-sans); color: var(--fg-muted); }

.hiw-panel {
  background: var(--paper-2); border: 1px solid var(--border-hair);
  border-radius: var(--radius-xl); padding: 40px 44px; min-height: 420px;
}
.hiw-panel-k { font-family: var(--font-mono); font-size: 12px; color: var(--clay-600); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 10px; font-weight: 600; }
.hiw-panel-t { font-family: var(--font-serif); font-size: 36px; line-height: 1.08; letter-spacing: -0.02em; color: var(--fg-strong); margin-bottom: 16px; font-weight: 400; }
.hiw-panel-body { font-family: var(--font-serif); font-size: 18px; line-height: 1.6; color: var(--fg-secondary); max-width: 560px; }

.hiw-panel-art { margin-top: 24px; background: var(--paper); border: 1px solid var(--border-hair); border-radius: var(--radius-lg); padding: 28px; min-height: 180px; display: flex; align-items: center; justify-content: center; }

.hiw-art { width: 100%; }
.hiw-art-explore { display: grid; grid-template-columns: repeat(7, 1fr); gap: 10px; }
.hiw-file { height: 36px; background: var(--paper-2); border: 1px solid var(--border-hair); border-radius: 4px; animation: fileRead 1.6s var(--ease-soft) infinite; }
@keyframes fileRead {
  0% { background: var(--paper-2); border-color: var(--border-hair); }
  50% { background: var(--clay-50); border-color: var(--clay-300); }
  100% { background: var(--ink-100); border-color: var(--border-soft); }
}

.hiw-doc { width: 100%; max-width: 380px; background: var(--paper); border: 1px solid var(--border-hair); border-radius: 6px; padding: 16px; box-shadow: var(--shadow-sm); }
.hiw-doc-h { height: 12px; background: var(--ink-800); border-radius: 2px; width: 60%; margin-bottom: 12px; }
.hiw-doc-l { height: 6px; background: var(--ink-200); border-radius: 999px; margin-bottom: 8px; animation: fadeLine 1.4s var(--ease-soft) infinite alternate; }
@keyframes fadeLine { from { opacity: 0.3; } to { opacity: 1; } }
.hiw-doc-code { background: var(--paper-3); border-radius: 3px; padding: 8px; margin: 10px 0; }
.hiw-doc-code-l { height: 5px; background: var(--clay-300); border-radius: 999px; margin-bottom: 5px; }

.hiw-art-serve { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.hiw-tool-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  background: var(--paper-2); border: 1px solid var(--border-soft);
  border-radius: var(--radius-pill);
  font: 500 13px var(--font-mono); color: var(--ink-800);
  opacity: 0; animation: pillIn 0.6s var(--ease-emphasized) forwards;
}
@keyframes pillIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.hiw-tool-dot { width: 6px; height: 6px; border-radius: 999px; background: var(--clay-500); }

/* ==================== INSTALL ==================== */
.install { max-width: 820px; margin: 0 auto; text-align: center; }
.install-head { margin-bottom: 36px; }
.install-cmd {
  display: flex; align-items: center;
  background: var(--term-bg-2);
  border: 1px solid rgba(232, 225, 208, 0.12);
  border-radius: var(--radius-pill);
  padding: 8px 8px 8px 28px;
  max-width: 540px; margin: 0 auto 48px;
  font-family: var(--font-mono);
}
.install-cmd-line { display: flex; gap: 10px; font-size: 17px; flex: 1; text-align: left; }
.install-cmd-line .term-dim { color: var(--term-dim); }
.install-cmd-line .term-fg { color: var(--term-fg); }
.install-copy {
  display: inline-flex; align-items: center; gap: 6px;
  font: 500 13px var(--font-mono);
  background: var(--clay-600); color: #fff;
  padding: 10px 18px; border-radius: var(--radius-pill);
  border: 0; cursor: pointer;
  transition: background var(--dur-fast);
}
.install-copy:hover { background: var(--clay-700); }

.install-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: 40px; text-align: left; }
@media (max-width: 760px) { .install-steps { grid-template-columns: 1fr; } }
.install-step { display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: start; }
.install-step-n { font-family: var(--font-mono); font-size: 24px; color: var(--clay-500); font-weight: 400; line-height: 1; }
.install-step-t { font-family: var(--font-serif); font-size: 17px; color: var(--term-fg); margin-bottom: 4px; font-weight: 500; }
.install-step-d { font: 400 14px var(--font-sans); color: var(--term-muted); line-height: 1.5; }

.install-meta { display: flex; flex-direction: column; gap: 6px; padding-top: 32px; border-top: 1px solid rgba(232, 225, 208, 0.08); }
.install-meta-item { font: 400 13px var(--font-mono); color: var(--term-dim); }
.install-meta-item a { color: var(--term-muted); text-decoration: none; border-bottom: 1px dotted var(--term-dim); }
.install-meta-item a:hover { color: var(--term-fg); }
.install-meta-pill {
  display: inline-block; margin-left: 6px;
  padding: 2px 8px;
  font: 500 10px var(--font-mono); letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--term-yellow);
  background: rgba(216, 168, 77, 0.12);
  border: 1px solid rgba(216, 168, 77, 0.25);
  border-radius: 999px;
}

/* ---------- AUTHORS PANEL ---------- */
.authors {
  margin: 8px 0 32px;
  padding: 24px 28px;
  background: var(--term-bg-2);
  border: 1px solid rgba(232, 225, 208, 0.1);
  border-radius: var(--radius-lg);
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 20px 36px;
  align-items: center;
}
@media (max-width: 720px) { .authors { grid-template-columns: 1fr; gap: 16px; } }
.authors-label {
  font: 500 11px var(--font-mono);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--term-muted);
}
.authors-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
@media (max-width: 560px) { .authors-grid { grid-template-columns: 1fr; } }
.author {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 14px;
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background var(--dur-fast);
}
.author:hover { background: rgba(232, 225, 208, 0.04); }
.author-avatar {
  flex: 0 0 auto;
  width: 48px; height: 48px;
  border-radius: 50%;
  overflow: hidden;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 0 0 2px rgba(232, 225, 208, 0.15);
}
.author-avatar svg { display: block; }
.author-body { display: flex; flex-direction: column; gap: 2px; }
.author-name {
  font: 500 16px var(--font-sans);
  color: var(--term-fg);
  letter-spacing: -0.01em;
}
.author-role {
  font: 400 12px var(--font-mono);
  color: var(--clay-300);
}
