/* COMPASS blog — self-contained styles for the temporary static blog.
   Scoped under .blog-listing / .blog-article so nothing here leaks into the
   rest of the site. Colors track the brand palette:
     navy  #121D2D / #17263B   indigo accent #4f46e5 / #4338ca
     gold  #E2C045             text gray #374151 / #6b7280 */

:root {
  --blog-navy: #121D2D;
  --blog-navy-2: #17263B;
  --blog-indigo: #4f46e5;
  --blog-indigo-dk: #4338ca;
  --blog-gold: #E2C045;
  --blog-ink: #1f2937;
  --blog-body: #374151;
  --blog-muted: #6b7280;
  --blog-line: rgba(17, 24, 39, 0.08);
  --blog-surface: #f9fafb;
}

.blog-listing,
.blog-article {
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--blog-surface);
  color: var(--blog-body);
  -webkit-font-smoothing: antialiased;
}

.blog-wrap {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ===== Listing ========================================================= */
.blog-listing-head {
  text-align: center;
  padding: 64px 24px 8px;
}
.blog-listing-head h1 {
  font-size: 40px;
  line-height: 1.1;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--blog-navy);
  margin: 0;
}
.blog-divider {
  height: 4px;
  margin: 20px auto;
  display: block;
}
.blog-listing-head p {
  font-size: 18px;
  color: var(--blog-muted);
  max-width: 620px;
  margin: 0 auto;
}

.blog-feature {
  display: grid;
  grid-template-columns: 1fr;
  margin: 40px 0 48px;
  background: #fff;
  border: 1px solid var(--blog-line);
  border-radius: 16px;
  overflow: hidden;
  text-decoration: none;
  box-shadow: 0 10px 30px rgba(18, 29, 45, 0.06);
  transition: box-shadow .2s ease, transform .2s ease;
}
.blog-feature:hover {
  box-shadow: 0 18px 44px rgba(18, 29, 45, 0.12);
  transform: translateY(-2px);
}
.blog-feature-media { overflow: hidden; background: #eef0f4; }
.blog-feature-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.blog-feature-body { padding: 32px; display: flex; flex-direction: column; justify-content: center; }
.blog-feature-tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--blog-indigo);
  margin-bottom: 12px;
}
.blog-feature-body h2 {
  font-size: 30px;
  line-height: 1.12;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--blog-navy);
  margin: 0 0 12px;
}
.blog-feature-body p { font-size: 16px; color: var(--blog-muted); margin: 0 0 16px; }

@media (min-width: 900px) {
  .blog-feature { grid-template-columns: 1.4fr 1fr; }
}

.blog-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  padding-bottom: 72px;
}
@media (min-width: 640px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .blog-grid { grid-template-columns: repeat(3, 1fr); } }

.blog-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--blog-line);
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none;
  transition: box-shadow .2s ease, transform .2s ease;
}
.blog-card:hover {
  box-shadow: 0 14px 34px rgba(18, 29, 45, 0.10);
  transform: translateY(-2px);
}
.blog-card-media { aspect-ratio: 16 / 9; overflow: hidden; background: #eef0f4; }
.blog-card-img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.blog-card:hover .blog-card-img { transform: scale(1.03); }
.blog-card-body { padding: 22px; display: flex; flex-direction: column; flex: 1; }
.blog-card-cat {
  font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--blog-indigo); margin: 0 0 8px;
}
.blog-card-title { font-size: 18px; font-weight: 600; color: var(--blog-navy); line-height: 1.3; margin: 0 0 8px; }
.blog-card:hover .blog-card-title { color: var(--blog-indigo); }
.blog-card-excerpt { font-size: 14px; color: var(--blog-muted); line-height: 1.55; flex: 1; margin: 0; }
.blog-card-meta { font-size: 12px; color: #9aa1ab; margin: 14px 0 0; }

/* ===== Article ========================================================= */
.blog-article-head {
  max-width: 760px;
  margin: 0 auto;
  padding: 64px 24px 24px;
}
.blog-crumbs { font-size: 14px; color: var(--blog-muted); margin-bottom: 20px; }
.blog-crumbs a { color: var(--blog-indigo); text-decoration: none; }
.blog-crumbs a:hover { text-decoration: underline; }
.blog-crumbs span { margin: 0 8px; color: #c3c8d0; }

.blog-tags { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-bottom: 18px; }
.blog-cat-pill {
  font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--blog-indigo-dk); background: rgba(79, 70, 229, 0.10);
  border-radius: 5px; padding: 4px 10px;
}
.blog-meta-sm { font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: #9aa1ab; }

.blog-article-head h1 {
  font-size: 44px; line-height: 1.08; font-weight: 600; letter-spacing: -0.02em;
  color: var(--blog-navy); margin: 0 0 18px;
}
.blog-lede { font-size: 20px; line-height: 1.5; color: var(--blog-muted); margin: 0 0 24px; }

.blog-author { display: flex; align-items: center; gap: 12px; font-size: 14px; }
.blog-author strong { color: var(--blog-ink); font-weight: 600; }
.blog-author span:last-child { color: var(--blog-muted); line-height: 1.4; }
.blog-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(79, 70, 229, 0.10); color: var(--blog-indigo-dk);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 15px; flex-shrink: 0;
}

.blog-hero {
  max-width: 1000px; margin: 8px auto 0; padding: 0 24px;
}
.blog-hero img {
  width: 100%; height: auto; display: block; border-radius: 16px;
  border: 1px solid var(--blog-line); box-shadow: 0 10px 40px rgba(18, 29, 45, 0.10);
}

.blog-body { max-width: 760px; margin: 0 auto; padding: 48px 24px 8px; }
.blog-body > * { margin: 0; }            /* reset, so the rhythm rule below is authoritative */
.blog-body > * + * { margin-top: 26px; } /* vertical rhythm between blocks */
.blog-h2 {
  font-size: 26px; font-weight: 600; letter-spacing: -0.015em; line-height: 1.25;
  color: var(--blog-navy); margin-top: 44px;
}
.blog-p { font-size: 18px; line-height: 1.75; color: var(--blog-body); }
.blog-ol, .blog-ul { font-size: 18px; line-height: 1.7; color: var(--blog-body); padding-left: 26px; }
.blog-ol { list-style: decimal; }
.blog-ul { list-style: disc; }
.blog-ol li, .blog-ul li { margin-top: 8px; padding-left: 4px; }
.blog-ol li::marker, .blog-ul li::marker { color: var(--blog-indigo); }

.blog-pullquote {
  background: rgba(79, 70, 229, 0.06);
  border-left: 3px solid var(--blog-indigo);
  border-radius: 0 12px 12px 0;
  padding: 24px;
  margin: 32px 0;
}
.blog-pullquote p { font-size: 19px; font-style: italic; color: var(--blog-navy); margin: 0 0 10px; }
.blog-pullquote cite { font-size: 14px; color: var(--blog-muted); font-style: normal; }

/* Related posts */
.blog-related { background: #fff; border-top: 1px solid var(--blog-line); margin-top: 56px; padding: 56px 0 72px; }
.blog-related-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 24px; }
.blog-related-head h2 { font-size: 26px; font-weight: 600; color: var(--blog-navy); margin: 0; letter-spacing: -0.015em; }
.blog-related-head a { font-size: 14px; font-weight: 600; color: var(--blog-indigo); text-decoration: none; }
.blog-related-head a:hover { text-decoration: underline; }
.blog-related .blog-grid { padding-bottom: 0; }
.blog-related .blog-card { background: var(--blog-surface); }

@media (max-width: 640px) {
  .blog-listing-head h1 { font-size: 32px; }
  .blog-article-head h1 { font-size: 32px; }
  .blog-feature-body h2 { font-size: 24px; }
}
