/* ================================================================
   ARC Reports — Editorial Style
   Replaces: style.css + hub.css dependencies
   Requires: Google Fonts (Fraunces + JetBrains Mono) in HTML
   ================================================================ */

:root {
  --paper:    #f5f1ea;
  --paper-2:  #ede7d8;
  --ink:      #1a1814;
  --ink-soft: #4a463e;
  --rule:     #c8bfae;
  --grid:     #e6dfd0;
  --accent:   #c14a26;
  --accent-2: #4a6b3a;
  --accent-3: #2c4a6b;
  --warn:     #b8741f;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: 'Fraunces', Georgia, serif;
  font-feature-settings: 'ss01';
  background: var(--paper);
  color: var(--ink);
  line-height: 1.55;
  font-size: 16.5px;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background-image:
    radial-gradient(circle at 92% 8%, rgba(44,74,107,0.05) 0%, transparent 40%),
    radial-gradient(circle at 8% 92%, rgba(74,107,58,0.05) 0%, transparent 40%);
  background-attachment: fixed;
}

img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }

/* ─────────── UTILITY NAV ─────────── */
.util-nav {
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
  padding: 14px 0;
  position: sticky;
  top: 0;
  z-index: 50;
}
.util-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
}
.util-left { display: flex; align-items: center; gap: 16px; min-width: 0; }
.util-brand { display: flex; align-items: center; gap: 12px; transition: opacity 0.2s ease; flex-shrink: 0; }
.util-brand:hover { opacity: 0.7; }
.util-brand img { height: 28px; width: auto; }
.util-brand .wordmark {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -0.01em;
  color: var(--ink);
  font-variation-settings: 'opsz' 36;
}
.util-crumb {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  display: flex;
  align-items: center;
  gap: 12px;
  text-transform: uppercase;
  min-width: 0;
}
.util-crumb .slash { color: var(--rule); }
.util-crumb .here { color: var(--accent-3); font-weight: 700; white-space: nowrap; }
.util-crumb a.crumb-mid {
  color: var(--ink-soft);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color 0.2s ease;
}
.util-crumb a.crumb-mid:hover { color: var(--accent-3); }
.util-links { display: flex; gap: 18px; align-items: center; flex-shrink: 0; }
.util-links a {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  transition: color 0.2s ease;
  text-transform: uppercase;
}
.util-links a:hover { color: var(--accent); }
.util-links .u-arrow { display: inline-block; margin-left: 2px; font-size: 10px; transition: transform 0.2s ease; }
.util-links a:hover .u-arrow { transform: translate(2px, -2px); }
.util-links .onboard {
  padding: 6px 14px;
  border: 1px solid var(--ink);
  color: var(--ink);
  transition: all 0.2s ease;
}
.util-links .onboard:hover { background: var(--ink); color: var(--paper); }

/* ─────────── PAGE HEADER ─────────── */
.page-header {
  border-top: 6px solid var(--ink);
  max-width: 1200px;
  margin: 0 auto;
  padding: 56px 40px 36px;
  width: 100%;
}
.page-eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 18px;
  display: flex;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
}
.page-eyebrow .sep { width: 4px; height: 4px; border-radius: 50%; background: var(--accent-3); display: inline-block; }
.page-header h1 {
  font-family: 'Fraunces', serif;
  font-weight: 800;
  font-size: 64px;
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-variation-settings: 'opsz' 144;
  margin-bottom: 18px;
}
.page-tagline {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-style: italic;
  font-size: 22px;
  color: var(--ink);
  line-height: 1.3;
  max-width: 38ch;
  margin-bottom: 12px;
  font-variation-settings: 'opsz' 60;
}
.page-supporting {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: 15.5px;
  color: var(--ink-soft);
  line-height: 1.55;
  max-width: 56ch;
}
.header-rule { max-width: 1200px; margin: 0 auto; padding: 0 40px; }
.header-rule hr { border: none; border-top: 1px solid var(--ink); margin: 0; }

/* ─────────── STATS STRIP ─────────── */
.stats-strip { max-width: 1200px; margin: 0 auto; padding: 32px 40px 0; width: 100%; }
.stats-row { display: flex; border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); }
.stat-item { flex: 1; padding: 20px 22px; border-right: 1px solid var(--rule); }
.stat-item:last-child { border-right: none; }
.stat-n {
  font-family: 'Fraunces', serif;
  font-weight: 800;
  font-size: 48px;
  line-height: 1;
  color: var(--accent-3);
  letter-spacing: -0.03em;
  font-variation-settings: 'opsz' 144;
  display: block;
}
.stat-l {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  margin-top: 8px;
  line-height: 1.4;
  display: block;
}

/* ─────────── SECTIONS ─────────── */
.rpt-section { padding: 56px 0 48px; }
.rpt-section.bg-alt { background: var(--paper-2); }
.rpt-wrap { max-width: 1200px; margin: 0 auto; padding: 0 40px; }

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 28px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--rule);
}
.section-eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent-3);
  font-weight: 700;
  margin-bottom: 8px;
}
.section-title {
  font-family: 'Fraunces', serif;
  font-weight: 700;
  font-size: 32px;
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1.1;
  font-variation-settings: 'opsz' 72;
}
.section-see-all {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-3);
  font-weight: 700;
  transition: color 0.2s ease;
  margin-bottom: 4px;
  flex-shrink: 0;
}
.section-see-all:hover { color: var(--accent); }
.section-lead {
  font-family: 'Fraunces', serif;
  font-size: 15.5px;
  color: var(--ink-soft);
  line-height: 1.6;
  max-width: 56ch;
  margin-bottom: 28px;
  font-style: italic;
  font-variation-settings: 'opsz' 36;
}
.section-full-link {
  margin-top: 22px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.section-full-link a { color: var(--accent-3); font-weight: 700; transition: color 0.2s ease; }
.section-full-link a:hover { color: var(--accent); }

/* ─────────── OUTPUT CARDS ─────────── */
.outputs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 20px;
}
.output-card {
  background: rgba(255,255,255,0.45);
  border: 1px solid var(--rule);
  padding: 28px 28px 24px;
  display: flex;
  flex-direction: column;
  transition: border-color 0.2s ease, transform 0.25s ease, background 0.2s ease;
  position: relative;
  overflow: hidden;
}
.output-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--accent-3);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease;
}
.output-card.live::before  { background: var(--accent-2); }
.output-card:hover {
  border-color: var(--ink);
  background: rgba(255,255,255,0.65);
  transform: translateY(-2px);
}
.output-card:hover::before { transform: scaleX(1); }
.output-card.offline { background: rgba(237,231,216,0.45); }

.output-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 12px;
}
.output-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  font-weight: 700;
}
.output-badge {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-soft);
  background: var(--grid);
  border: 1px solid var(--rule);
  padding: 2px 7px;
  font-weight: 500;
  flex-shrink: 0;
}
.output-arrow {
  font-size: 16px;
  color: var(--rule);
  transition: color 0.2s ease, transform 0.2s ease;
  line-height: 1;
}
.output-card:hover .output-arrow { color: var(--accent-3); transform: translate(2px, -2px); }
.output-card.live:hover .output-arrow { color: var(--accent-2); }

.output-name {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-bottom: 8px;
  font-variation-settings: 'opsz' 36;
}
.output-desc {
  font-family: 'Fraunces', serif;
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.55;
  flex-grow: 1;
  margin-bottom: 16px;
}
.output-desc em { font-style: italic; color: var(--ink); }
.output-cta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  font-weight: 600;
  padding-top: 12px;
  border-top: 1px solid var(--rule);
  margin-top: auto;
}
.output-card.live .output-cta { color: var(--accent-2); }

.output-card-more {
  border-style: dashed;
  background: transparent;
  justify-content: center;
  text-align: center;
}
.output-card-more .output-name { color: var(--ink-soft); font-size: 16px; }
.output-card-more .output-cta {
  border-top: none;
  padding-top: 8px;
  color: var(--accent-3);
  font-weight: 700;
}
.output-card-more:hover { background: rgba(255,255,255,0.3); }
.output-card-more::before { background: var(--accent); }

/* ─────────── PUB LIST ─────────── */
.pub-list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--rule);
}
.pub-item {
  padding: 20px 0;
  border-bottom: 1px solid var(--rule);
}
.pub-item-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.pub-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-3);
  font-weight: 700;
}
.pub-type {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-soft);
  border: 1px solid var(--rule);
  padding: 2px 7px;
  font-weight: 500;
}
.pub-item-title {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  font-size: 17px;
  color: var(--ink);
  margin-bottom: 6px;
  line-height: 1.25;
  font-variation-settings: 'opsz' 36;
}
.pub-item-desc {
  font-family: 'Fraunces', serif;
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.55;
}
.pub-item-desc em { font-style: italic; color: var(--ink); }
.pub-item-more .pub-item-title { color: var(--ink-soft); }
.pub-item-cta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-3);
  font-weight: 700;
  margin-top: 10px;
  display: inline-block;
  transition: color 0.2s ease;
}
a.pub-item {
  display: block;
  transition: background 0.15s ease;
  margin: 0 -12px;
  padding-left: 12px;
  padding-right: 12px;
  border-radius: 2px;
}
a.pub-item:hover { background: rgba(255,255,255,0.4); }
a.pub-item:hover .pub-item-title { color: var(--accent-3); }
a.pub-item:hover .pub-item-cta { color: var(--accent); }

/* ─────────── GRADE BADGES ─────────── */
.grade {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  padding: 4px 10px;
  display: inline-block;
  flex-shrink: 0;
}
.grade-a { background: rgba(74,107,58,0.12); color: var(--accent-2); border: 1px solid rgba(74,107,58,0.3); }
.grade-b { background: rgba(44,74,107,0.10); color: var(--accent-3); border: 1px solid rgba(44,74,107,0.25); }
.grade-c { background: rgba(184,116,31,0.10); color: var(--warn);    border: 1px solid rgba(184,116,31,0.25); }

.grade-legend {
  margin-top: 28px;
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.grade-legend .leg-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px;
  letter-spacing: 0.06em;
  color: var(--ink-soft);
}

.grade-section-head {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 32px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--rule);
}
.grade-section-title {
  font-family: 'Fraunces', serif;
  font-weight: 700;
  font-size: 28px;
  color: var(--ink);
  letter-spacing: -0.02em;
  font-variation-settings: 'opsz' 60;
}

/* ─────────── GROUPS (dissemination) ─────────── */
.rpt-group {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid var(--grid);
}
.rpt-group:last-child { border-bottom: none; padding-bottom: 0; }
.rpt-group-title {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  font-size: 20px;
  color: var(--ink);
  margin-bottom: 6px;
  line-height: 1.2;
  font-variation-settings: 'opsz' 36;
}
.rpt-group-count {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--ink-soft);
  margin-left: 8px;
  text-transform: uppercase;
  font-weight: 500;
}
.rpt-group-desc {
  font-family: 'Fraunces', serif;
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.6;
  margin-bottom: 16px;
  font-style: italic;
  font-variation-settings: 'opsz' 24;
}
.rpt-group-desc a { color: var(--accent-3); font-style: normal; }
.rpt-group-desc a:hover { color: var(--accent); }

/* ─────────── FULL INVENTORY CTA ─────────── */
.full-cta { max-width: 1200px; margin: 0 auto; padding: 8px 40px 56px; width: 100%; }
.full-cta-inner {
  background: rgba(255,255,255,0.3);
  border: 1px solid var(--ink);
  padding: 36px 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
  flex-wrap: wrap;
}
.full-cta-text h2 {
  font-family: 'Fraunces', serif;
  font-weight: 700;
  font-size: 28px;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-bottom: 8px;
  font-variation-settings: 'opsz' 60;
}
.full-cta-text p {
  font-family: 'Fraunces', serif;
  font-size: 15px;
  color: var(--ink-soft);
  line-height: 1.5;
  max-width: 44ch;
}
.full-cta-btn {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--paper);
  background: var(--ink);
  border: 1px solid var(--ink);
  padding: 14px 28px;
  transition: background 0.2s ease, border-color 0.2s ease;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}
.full-cta-btn:hover { background: var(--accent-3); border-color: var(--accent-3); }
.full-cta-btn .arrow { transition: transform 0.2s ease; }
.full-cta-btn:hover .arrow { transform: translateX(4px); }

/* ─────────── FOOTER ─────────── */
footer {
  margin-top: auto;
  padding: 24px 40px;
  border-top: 1px solid var(--rule);
}
.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--ink-soft);
  letter-spacing: 0.05em;
  flex-wrap: wrap;
}
.footer-inner a { color: var(--ink-soft); transition: color 0.2s ease; }
.footer-inner a:hover { color: var(--accent); }
.footer-sep {
  width: 3px; height: 3px;
  border-radius: 50%;
  background: var(--rule);
  display: inline-block;
  margin: 0 8px;
  vertical-align: middle;
}

/* ─────────── RESPONSIVE ─────────── */
@media (max-width: 900px) {
  .page-header h1 { font-size: 48px; }
  .page-tagline { font-size: 19px; }
  .outputs-grid { grid-template-columns: 1fr; }
  .stat-n { font-size: 38px; }
  .section-title { font-size: 26px; }
  .grade-section-title { font-size: 22px; }
}
@media (max-width: 720px) {
  .util-inner { padding: 0 24px; gap: 12px; flex-wrap: wrap; }
  .util-left { gap: 10px; }
  .util-brand .wordmark { display: none; }
  .util-crumb { font-size: 10px; gap: 8px; }
  .util-links { gap: 10px; }
  .util-links .onboard { padding: 5px 10px; }
  .page-header { padding: 40px 24px 28px; }
  .header-rule { padding-left: 24px; padding-right: 24px; }
  .stats-strip { padding-left: 24px; padding-right: 24px; }
  .rpt-wrap { padding-left: 24px; padding-right: 24px; }
  .full-cta { padding-left: 24px; padding-right: 24px; }
  footer { padding-left: 24px; padding-right: 24px; }
  .page-header h1 { font-size: 38px; }
  .page-tagline { font-size: 17px; }
  .stats-row { flex-direction: column; }
  .stat-item { border-right: none; border-bottom: 1px solid var(--rule); }
  .stat-item:last-child { border-bottom: none; }
  .section-head { flex-direction: column; align-items: flex-start; gap: 8px; }
  .grade-section-head { flex-direction: column; align-items: flex-start; gap: 8px; }
  .full-cta-inner { flex-direction: column; align-items: flex-start; gap: 24px; }
  .grade-legend { flex-direction: column; align-items: flex-start; gap: 12px; }
  .footer-inner { flex-direction: column; align-items: flex-start; gap: 8px; }
}
@media (max-width: 480px) {
  .util-crumb .root-label { display: none; }
  .util-crumb .slash:first-child { display: none; }
}
