/* /blog/css/blog.css — blog + neighbourhood page styles
   Loaded after styles.css; uses brand vars from styles.css where possible. */

/* ====== Layout containers ====== */
.article-container {
  max-width: 760px;
  margin: 0 auto;
  padding: var(--s-6) var(--s-4) var(--s-9);
}
.article-container.wide {
  max-width: 1100px;
}

/* ====== Article hero / breadcrumb ====== */
.article-head {
  margin-bottom: var(--s-6);
}
.article-breadcrumb {
  font-size: 13px;
  color: var(--ink-500, #6F7B89);
  margin-bottom: var(--s-3);
}
.article-breadcrumb a { color: inherit; text-decoration: none; }
.article-breadcrumb a:hover { color: var(--brass-700, #8C6628); }
.article-breadcrumb-sep { margin: 0 6px; }

.article-eyebrow {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--brass-700, #8C6628);
  margin-bottom: var(--s-3);
}
.article-title {
  font-size: clamp(28px, 4vw, 44px);
  line-height: 1.15;
  margin: 0 0 var(--s-3);
}
.article-deck {
  font-size: var(--t-lg);
  line-height: 1.5;
  color: var(--ink-700, #4A5667);
  margin-bottom: var(--s-5);
}

.article-byline {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) 0;
  border-top: 1px solid var(--line, #E2E6EC);
  border-bottom: 1px solid var(--line, #E2E6EC);
  margin: var(--s-4) 0 var(--s-6);
  font-size: 14px;
}
.article-byline-avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--brass-100, #F4EBD9);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
  color: var(--brass-700, #8C6628);
  flex-shrink: 0;
}
.article-byline a {
  color: var(--ink-900, #0F1D2E);
  font-weight: 600;
  text-decoration: none;
}
.article-byline a:hover { color: var(--brass-700, #8C6628); }
.article-byline-meta { color: var(--ink-500, #6F7B89); }

/* ====== Article body ====== */
.article-body {
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink-800, #2A3242);
}
.article-body h2 {
  font-size: clamp(22px, 2.6vw, 30px);
  line-height: 1.25;
  margin: var(--s-7) 0 var(--s-3);
}
.article-body h3 {
  font-size: 20px;
  margin: var(--s-6) 0 var(--s-3);
}
.article-body p { margin: 0 0 var(--s-4); }
.article-body ul, .article-body ol {
  padding-left: 1.4em;
  margin: 0 0 var(--s-4);
}
.article-body li { margin-bottom: 8px; }
.article-body a {
  color: var(--brass-700, #8C6628);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.article-body a:hover { color: var(--ink-900, #0F1D2E); }
.article-body strong { color: var(--ink-900, #0F1D2E); }
.article-body code {
  background: var(--ink-100, #F1F4F7);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.92em;
}

/* Generic blockquote = neither cost nor danger */
.article-body blockquote {
  margin: var(--s-5) 0;
  padding: var(--s-4) var(--s-5);
  background: var(--ink-100, #F1F4F7);
  border-left: 4px solid var(--ink-400, #B5BFCB);
  border-radius: 6px;
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink-800, #2A3242);
}
.article-body blockquote p:last-child { margin-bottom: 0; }

/* Cost reality check (auto-styled by post-process for blockquotes starting with **Cost) */
.article-body blockquote.cost-callout {
  background: #FBF4E5;
  border-left: 4px solid var(--brass-500, #C18E3C);
  color: var(--ink-900, #0F1D2E);
}

/* DANGER block (auto-styled by post-process for blockquotes starting with **DANGER) */
.article-body blockquote.danger-callout {
  background: #FCE8E6;
  border-left: 5px solid #B30E0E;
  color: #5A0E0E;
}
.article-body blockquote.danger-callout strong { color: #7A0E0E; }

/* ====== Related reading block ====== */
.article-related {
  margin: var(--s-8) 0 var(--s-6);
  padding: var(--s-5);
  background: var(--ink-100, #F1F4F7);
  border-radius: var(--radius-lg, 12px);
}
.article-related h2 {
  font-size: 20px;
  margin: 0 0 var(--s-3);
  color: var(--ink-900, #0F1D2E);
}
.article-related ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.article-related li {
  margin: 8px 0;
  font-size: 16px;
  line-height: 1.5;
}
.article-related a {
  color: var(--brass-700, #8C6628);
  font-weight: 600;
  text-decoration: none;
}
.article-related a:hover { text-decoration: underline; }

/* ====== Bottom CTA block ====== */
.article-cta {
  margin: var(--s-6) 0 var(--s-4);
  padding: var(--s-5);
  background: var(--ink-900, #0F1D2E);
  color: #fff;
  border-radius: var(--radius-lg, 12px);
  text-align: center;
}
.article-cta h3 {
  color: #fff;
  margin: 0 0 var(--s-3);
  font-size: 22px;
}
.article-cta p {
  margin: 0 0 var(--s-3);
  color: rgba(255,255,255,0.85);
}

/* ====== Blog index ====== */
.blog-hero {
  background: linear-gradient(160deg, var(--ink-900, #0F1D2E), var(--ink-800, #2A3242));
  color: #fff;
  padding: var(--s-7) 0 var(--s-6);
  text-align: center;
}
.blog-hero h1 {
  color: #fff;
  font-size: clamp(32px, 5vw, 48px);
  margin: 0 0 var(--s-3);
}
.blog-hero p {
  color: rgba(255,255,255,0.78);
  max-width: 600px;
  margin: 0 auto;
  font-size: var(--t-lg);
}

.blog-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
  margin-top: var(--s-6);
}
@media (min-width: 720px) {
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1080px) {
  .blog-grid { grid-template-columns: repeat(3, 1fr); }
}

.post-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--line, #E2E6EC);
  border-radius: var(--radius-lg, 12px);
  padding: var(--s-5);
  text-decoration: none;
  color: inherit;
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}
.post-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(15,29,46,0.08);
  border-color: var(--brass-500, #C18E3C);
}
.post-card-meta {
  display: flex;
  gap: var(--s-2);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--s-3);
  color: var(--brass-700, #8C6628);
}
.post-card-meta .dot {
  color: var(--ink-400, #B5BFCB);
}
.post-card h3 {
  font-size: 19px;
  line-height: 1.3;
  margin: 0 0 var(--s-3);
  color: var(--ink-900, #0F1D2E);
}
.post-card p {
  color: var(--ink-700, #4A5667);
  font-size: 15px;
  line-height: 1.5;
  margin: 0 0 var(--s-3);
  flex: 1;
}
.post-card-foot {
  font-size: 13px;
  color: var(--ink-500, #6F7B89);
}

/* ====== Madison author block / page ====== */
.author-hero {
  padding: var(--s-7) 0 var(--s-6);
  text-align: center;
}
.author-hero .author-avatar {
  width: 120px; height: 120px;
  border-radius: 50%;
  background: var(--brass-100, #F4EBD9);
  display: flex; align-items: center; justify-content: center;
  font-size: 48px;
  font-weight: 700;
  color: var(--brass-700, #8C6628);
  margin: 0 auto var(--s-4);
}
.author-hero h1 {
  font-size: clamp(28px, 4vw, 40px);
  margin: 0 0 var(--s-3);
}
.author-hero .author-role {
  color: var(--brass-700, #8C6628);
  font-weight: 600;
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: 0.08em;
  margin-bottom: var(--s-3);
}
.author-bio {
  max-width: 680px;
  margin: 0 auto;
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink-700, #4A5667);
}

/* ====== Service area hub ====== */
.areas-list-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
  margin: var(--s-6) 0;
}
@media (min-width: 720px) {
  .areas-list-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1080px) {
  .areas-list-grid { grid-template-columns: repeat(3, 1fr); }
}
.area-card {
  display: block;
  padding: var(--s-4);
  background: #fff;
  border: 1px solid var(--line, #E2E6EC);
  border-radius: var(--radius-lg, 12px);
  text-decoration: none;
  color: inherit;
  transition: transform 0.15s ease, border-color 0.15s ease;
}
.area-card:hover {
  transform: translateY(-2px);
  border-color: var(--brass-500, #C18E3C);
}
.area-card h3 {
  margin: 0 0 4px;
  font-size: 18px;
  color: var(--ink-900, #0F1D2E);
}
.area-card p {
  margin: 0;
  font-size: 14px;
  color: var(--ink-600, #5C6878);
  line-height: 1.4;
}
.area-card .area-postal {
  display: inline-block;
  margin-top: 6px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--brass-700, #8C6628);
}

/* Make existing area-chip clickable + obvious */
.area-chip {
  display: inline-block;
  padding: 10px 16px;
  margin: 4px;
  border: 1px solid var(--line, #E2E6EC);
  border-radius: 999px;
  text-decoration: none;
  color: var(--ink-800, #2A3242);
  font-size: 14px;
  font-weight: 600;
  background: #fff;
  transition: all 0.15s ease;
}
.area-chip:hover {
  border-color: var(--brass-500, #C18E3C);
  background: var(--brass-50, #FBF4E5);
  color: var(--brass-700, #8C6628);
}

/* Card thumbnail (added for hero image scaffolding) */
.post-card-img {
  margin: calc(var(--s-5) * -1) calc(var(--s-5) * -1) var(--s-4);
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #F4F7FB 0%, #E5ECF4 100%);
  overflow: hidden;
  border-radius: var(--radius-lg, 12px) var(--radius-lg, 12px) 0 0;
}
.post-card-img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.post-card:hover .post-card-img img { transform: scale(1.03); }

/* Hero banner image on /blog/ index */
.blog-hero-image {
  margin: 0 0 var(--s-6);
  aspect-ratio: 21 / 9;
  background: linear-gradient(135deg, #1E3650 0%, #0F1D2E 100%);
  overflow: hidden;
  border-radius: var(--radius-lg, 12px);
}
.blog-hero-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Hero image inside a single blog post (top of article body) */
.post-article-hero {
  margin: 0 0 var(--s-6);
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #F4F7FB 0%, #E5ECF4 100%);
  overflow: hidden;
  border-radius: var(--radius-lg, 12px);
}
.post-article-hero img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
