/* Real Job Check - content engine styles (Learn / Answers / Glossary / Research / Compare).
   Loaded after styles.css on generated content pages only. Reuses the civic-trust
   tokens from styles.css. House rule: no em or en dashes anywhere. */

/* hero / page head */
.content-head { padding:40px 0 8px; }
.crumbs { font-family:var(--font-mono); font-size:13px; color:var(--ink-3); margin-bottom:18px; display:flex; flex-wrap:wrap; gap:6px; align-items:center; }
.crumbs a { color:var(--ink-2); }
.crumbs a:hover { color:var(--brand-2); }
.crumbs .crumb-sep { color:var(--line-2); }
.crumbs [aria-current="page"] { color:var(--ink-3); }
.content-head h1 { font-size:clamp(30px,5vw,46px); margin:4px 0 0; max-width:18ch; }
.content-head .lead { font-size:clamp(18px,2.3vw,22px); line-height:1.5; color:var(--ink); max-width:62ch; margin:18px 0 0;
  border-left:3px solid var(--brand); padding-left:18px; }
.content-meta { font-family:var(--font-mono); font-size:13px; color:var(--ink-3); margin:18px 0 0; }

/* body prose */
.content-body { padding:30px 0 64px; border-top:none; }
.prose { max-width:720px; font-size:17.5px; }
.prose h2 { font-size:clamp(22px,3vw,28px); margin:40px 0 12px; letter-spacing:-.02em; scroll-margin-top:80px; }
.prose h3 { font-size:20px; margin:28px 0 8px; }
.prose p, .prose li { color:var(--ink-2); }
.prose p { margin:0 0 1.05em; }
.prose strong { color:var(--ink); }
.prose a { color:var(--brand-2); text-decoration:underline; text-underline-offset:2px; text-decoration-thickness:1px; }
.prose ul, .prose ol { padding-left:22px; margin:0 0 1.1em; }
.prose li { margin-bottom:8px; }
.prose blockquote { margin:20px 0; padding:14px 20px; background:var(--paper-2); border-left:4px solid var(--brand);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0; color:var(--ink); font-size:18px; }
.prose blockquote p:last-child { margin-bottom:0; }
.prose hr { border:none; border-top:1px solid var(--line); margin:34px 0; }
.prose code { font-family:var(--font-mono); font-size:.92em; background:var(--paper-2); border:1px solid var(--line);
  border-radius:6px; padding:1px 6px; color:var(--ink); }

/* answer-first TL;DR / key-facts callouts (markdown: use a blockquote that starts with **TL;DR**,
   or an explicit div via attr_list). The .callout class can be applied in markdown with {: .callout } */
.prose .callout { background:var(--brand-tint); border:1px solid var(--safe-line); border-left:4px solid var(--brand);
  border-radius:var(--radius-sm); padding:16px 18px; margin:22px 0; color:var(--ink); }
.prose .callout strong:first-child { color:var(--brand-2); }
.prose .warn { background:var(--risk-bg); border:1px solid var(--risk-line); border-left:4px solid var(--risk);
  border-radius:var(--radius-sm); padding:16px 18px; margin:22px 0; color:var(--ink); }
.prose .warn strong:first-child { color:var(--risk); }
.prose .keyfacts { background:var(--panel); border:1px solid var(--line-2); border-radius:var(--radius); padding:18px 20px;
  margin:24px 0; box-shadow:var(--shadow-sm); }
.prose .keyfacts ul { margin:8px 0 0; }

/* tables already styled in styles.css (.prose table) */
.prose th { white-space:nowrap; }

/* report / source citation footnote rows */
.prose .src { font-family:var(--font-mono); font-size:13px; color:var(--ink-3); }

/* share row */
.share-row { display:flex; align-items:center; flex-wrap:wrap; gap:10px; margin:34px 0 0; padding-top:20px; border-top:1px solid var(--line); }
.share-label { font-family:var(--font-mono); font-size:12px; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-3); margin-right:4px; }
.share-link { font-family:var(--font-body); font-size:14px; font-weight:500; color:var(--ink-2); background:var(--paper-2);
  border:1px solid var(--line-2); border-radius:999px; padding:6px 14px; cursor:pointer; text-decoration:none; transition:background .15s, border-color .15s, color .15s; }
.share-link:hover { background:#fff; border-color:var(--brand); color:var(--brand-2); text-decoration:none; }
.share-copy.copied { background:var(--safe-bg); border-color:var(--safe-line); color:var(--safe); }

/* related links */
.related { margin:40px 0 0; padding:22px 24px; background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius); }
.related-head { font-size:15px; font-family:var(--font-body); font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-3); margin:0 0 12px; }
.related-list { list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.related-list a { color:var(--brand-2); font-weight:500; }

/* feedback slot spacing */
.feedback-slot { margin-top:8px; }

/* library hub index grids */
.lib-grid { list-style:none; margin:18px 0 0; padding:0; display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.lib-card { background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:22px 22px; box-shadow:var(--shadow-sm);
  transition:border-color .15s, box-shadow .15s, transform .08s; }
.lib-card:hover { border-color:var(--brand); box-shadow:var(--shadow-md); }
.lib-card h3 { font-size:19px; margin:0 0 7px; letter-spacing:-.01em; }
.lib-card h3 a { color:var(--ink); text-decoration:none; }
.lib-card h3 a:hover { color:var(--brand-2); }
.lib-card p { color:var(--ink-2); font-size:15px; margin:0; }
.lib-card .lib-tag { font-family:var(--font-mono); font-size:11.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--brand); display:block; margin-bottom:8px; }

/* glossary index */
.glossary-index { list-style:none; margin:18px 0 0; padding:0; display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.glossary-index dt { font-weight:600; }
.glossary-index a { color:var(--ink); }
.glossary-index a:hover { color:var(--brand-2); }

/* ---- infographic (semantic HTML/CSS/SVG; data table + animated bars) ---- */
.fig { margin:30px 0; padding:24px; background:var(--panel); border:1px solid var(--line-2); border-radius:var(--radius); box-shadow:var(--shadow-sm); }
.fig figcaption { font-family:var(--font-body); font-weight:600; font-size:15px; color:var(--ink); margin-bottom:4px; }
.fig .fig-sub { font-size:13.5px; color:var(--ink-3); margin:0 0 18px; }
.bars { display:grid; gap:14px; margin:0; }
.bar-row { display:grid; grid-template-columns:minmax(120px,200px) 1fr auto; gap:14px; align-items:center; }
.bar-row .bar-label { font-size:14.5px; color:var(--ink-2); }
.bar-track { display:block; background:var(--paper-2); border-radius:999px; height:16px; overflow:hidden; border:1px solid var(--line); }
.bar-fill { display:block; height:100%; border-radius:999px; background:linear-gradient(90deg, var(--brand), var(--brand-2));
  width:var(--w,50%); transform-origin:left center; animation:bargrow 1.1s cubic-bezier(.2,.7,.2,1) both; }
.bar-fill.bar-risk { background:linear-gradient(90deg, #E06A56, var(--risk)); }
.bar-fill.bar-caution { background:linear-gradient(90deg, #D69A3E, var(--caution)); }
.bar-row .bar-val { font-family:var(--font-mono); font-size:14px; color:var(--ink); font-weight:500; min-width:54px; text-align:right; }
@keyframes bargrow { from { transform:scaleX(0); } to { transform:scaleX(1); } }
.fig-source { font-family:var(--font-mono); font-size:12px; color:var(--ink-3); margin:16px 0 0; }
.fig-source a { color:var(--brand-2); }
/* trend (count-up style numbers in a row) */
.trend { display:grid; grid-template-columns:repeat(auto-fit,minmax(120px,1fr)); gap:18px; margin:6px 0 0; }
.trend-cell { text-align:center; padding:14px 10px; background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius-sm); }
.trend-cell .trend-num { font-family:var(--font-display); font-weight:800; font-size:30px; color:var(--brand-2); display:block; letter-spacing:-.02em; }
.trend-cell .trend-lab { font-size:12.5px; color:var(--ink-3); display:block; margin-top:4px; }
/* visually-hidden data table that screen readers + scrapers still read */
.fig-data { margin:16px 0 0; }
.fig-data summary { font-family:var(--font-mono); font-size:12.5px; color:var(--ink-3); cursor:pointer; }
.fig-data table { width:100%; border-collapse:collapse; margin:10px 0 0; font-size:14px; }
.fig-data th, .fig-data td { text-align:left; padding:7px 10px; border-bottom:1px solid var(--line); }

@media (max-width:820px) {
  .lib-grid, .glossary-index { grid-template-columns:1fr; }
  .bar-row { grid-template-columns:1fr; gap:5px; }
  .bar-row .bar-val { text-align:left; }
}
@media (prefers-reduced-motion:reduce) {
  .bar-fill { animation:none; transform:none; width:var(--w,50%); }
}
