/* ════════════════════════════════════════════════════════════
   ConCal Blog — trade-publication layer
   Loads AFTER style.css. All colors via theme vars (light/dark safe).
   ════════════════════════════════════════════════════════════ */

:root {
  --blog-serif: 'Source Serif 4', Georgia, 'Times New Roman', serif;
}

/* ── Kickers (category labels) ─────────────────────────── */
.kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--accent);
}
.kicker.k-business, .kicker.k-green  { color: var(--green); }
.kicker.k-materials, .kicker.k-yellow { color: var(--yellow); }
.kicker.k-news, .kicker.k-orange { color: var(--orange); }

/* ── Data covers ───────────────────────────────────────── */
.data-cover {
  background: var(--surface2);
  border: 1px solid var(--border);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-shrink: 0;
}
.data-cover::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--accent);
}
.data-cover .dc-figure {
  font-family: var(--blog-serif);
  font-weight: 600;
  color: var(--text);
  letter-spacing: -1px;
  line-height: 1;
  font-size: 56px;
}
.data-cover .dc-caption {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--text2);
}
.data-cover.dc-sm { width: 168px; height: 104px; gap: 2px; }
.data-cover.dc-sm .dc-figure { font-size: 26px; letter-spacing: -0.5px; }
.data-cover.dc-sm .dc-caption { display: none; }
.data-cover.dc-hero { width: 100%; height: 300px; margin: 0 0 8px; }
.data-cover.dc-hero .dc-figure { font-size: 72px; }

/* ── Byline ────────────────────────────────────────────── */
.author-dot {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--surface3);
  border: 1px solid var(--border2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 800;
  color: var(--accent);
  flex-shrink: 0;
}
.byline-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
  color: var(--text3);
  flex-wrap: wrap;
}
.byline-row strong { color: var(--text2); font-weight: 600; }
.byline-row .dot { color: var(--border2); margin: 0 2px; }

/* ════════════════════════════════════════════════════════
   INDEX PAGE
   ════════════════════════════════════════════════════════ */
.bx-wrap { max-width: 920px; margin: 0 auto 72px; padding: 0 32px; }

.bx-masthead {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 2px solid var(--text);
  padding-bottom: 12px;
  margin: 48px 0 0;
}
.bx-masthead h1 {
  font-family: var(--blog-serif);
  font-size: 38px;
  font-weight: 700;
  letter-spacing: -0.5px;
  margin: 0;
  color: var(--text);
}
.bx-masthead .bx-cats { font-size: 12px; color: var(--text3); white-space: nowrap; }

.bx-tools {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding: 16px 0;
  border-bottom: 1px solid var(--border);
}

/* Featured story */
.blog-card.bfeat {
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 28px;
  align-items: center;
  padding: 28px 0;
  border-bottom: 1px solid var(--border);
  text-decoration: none;
  transition: opacity 0.15s;
}
.blog-card.bfeat .data-cover { width: 100%; height: 236px; }
.blog-card.bfeat .data-cover .dc-figure { font-size: 60px; }
.blog-card.bfeat .bf-content { display: flex; flex-direction: column; gap: 11px; }
.blog-card.bfeat h2 {
  font-family: var(--blog-serif);
  font-size: 26px;
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: -0.3px;
  margin: 0;
  color: var(--text);
}
.blog-card.bfeat p { font-size: 14.5px; line-height: 1.6; color: var(--text2); margin: 0; }

/* Article rows */
.blog-card.brow {
  display: grid;
  grid-template-columns: 1fr 168px;
  gap: 24px;
  align-items: center;
  padding: 22px 0;
  border-bottom: 1px solid var(--border);
  text-decoration: none;
}
.blog-card.brow .br-content { display: flex; flex-direction: column; gap: 7px; }
.blog-card.brow h2 {
  font-family: var(--blog-serif);
  font-size: 19.5px;
  font-weight: 700;
  line-height: 1.25;
  margin: 0;
  color: var(--text);
}
.blog-card.brow p { font-size: 13.5px; line-height: 1.55; color: var(--text2); margin: 0; }
.blog-card.bfeat:hover h2, .blog-card.brow:hover h2 { color: var(--accent); }
.blog-card.bfeat:hover .data-cover, .blog-card.brow:hover .data-cover { border-color: var(--accent); }
.blog-card.hidden { display: none; }

@media (max-width: 760px) {
  .bx-wrap { padding: 0 20px; }
  .bx-masthead h1 { font-size: 28px; }
  .bx-masthead .bx-cats { display: none; }
  .blog-card.bfeat { grid-template-columns: 1fr; gap: 16px; }
  .blog-card.bfeat .data-cover { height: 170px; }
  .blog-card.brow { grid-template-columns: 1fr 110px; gap: 14px; }
  .data-cover.dc-sm { width: 110px; height: 76px; }
  .data-cover.dc-sm .dc-figure { font-size: 19px; }
}

/* ════════════════════════════════════════════════════════
   ARTICLE PAGES
   ════════════════════════════════════════════════════════ */

/* Breadcrumbs */
.crumbs { font-size: 12px; color: var(--text3); margin-bottom: 22px; display: flex; gap: 7px; align-items: center; flex-wrap: wrap; }
.crumbs a { color: var(--text3); text-decoration: none; }
.crumbs a:hover { color: var(--text); }
.crumbs .sep { color: var(--border2); }
.crumbs .here { color: var(--text2); }

/* Hero typography — overrides the per-page inline styles */
.post-wrap h1.post-title {
  font-family: var(--blog-serif);
  font-size: 38px;
  font-weight: 700;
  letter-spacing: -0.5px;
  line-height: 1.14;
  margin: 12px 0 14px;
  color: var(--text);
}
.post-dek {
  font-size: 16.5px;
  line-height: 1.6;
  color: var(--text2);
  margin: 0 0 20px;
  text-wrap: pretty;
}
.post-byline {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 26px;
}

/* Serif section headings inside articles */
.post-body h2 {
  font-family: var(--blog-serif);
  letter-spacing: -0.3px;
  scroll-margin-top: 84px;
}
.post-body h3 { scroll-margin-top: 84px; }

/* Table of contents */
.toc-box {
  border-left: 2px solid var(--border2);
  padding: 4px 0 4px 18px;
  margin: 26px 0 34px;
}
.toc-box .toc-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text3);
  margin-bottom: 10px;
}
.toc-box ol { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.toc-box li { margin: 0; }
.toc-box a { font-size: 13.5px; color: var(--text2); text-decoration: none; }
.toc-box a:hover { color: var(--accent); }

/* Related reading */
.related-box { margin-top: 56px; }
.related-box .rel-title {
  font-family: var(--blog-serif);
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  border-bottom: 2px solid var(--text);
  padding-bottom: 8px;
  margin: 0 0 4px;
}
.related-box a.rel-item {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 16px 0;
  border-bottom: 1px solid var(--border);
  text-decoration: none;
}
.related-box a.rel-item .rel-headline {
  font-family: var(--blog-serif);
  font-size: 16.5px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--text);
}
.related-box a.rel-item:hover .rel-headline { color: var(--accent); }
.related-box a.rel-item .rel-meta { font-size: 12px; color: var(--text3); }

/* Author box */
.author-box {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 18px 20px;
  margin-top: 40px;
}
.author-box .author-dot { width: 34px; height: 34px; font-size: 14px; }
.author-box .ab-name { font-size: 13.5px; font-weight: 700; color: var(--text); margin: 0 0 3px; }
.author-box .ab-bio { font-size: 13px; line-height: 1.6; color: var(--text2); margin: 0; }
.author-box .ab-bio a { color: var(--accent); text-decoration: none; }

@media (max-width: 600px) {
  .post-wrap h1.post-title { font-size: 27px; }
  .data-cover.dc-hero { height: 190px; }
  .data-cover.dc-hero .dc-figure { font-size: 44px; }
}
