/* ============================================================
   Landscapey — blog.css
   /blog index + /blog/<slug> article pages. Editorial-garden language.
   ============================================================ */

.bl { padding-top: 90px; }

/* ── Index hero ───────────────────────────────────────────── */
.bl-hero { padding: clamp(40px, 7vw, 80px) 0 clamp(22px, 3vw, 38px); }
.bl-headline {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(38px, 5.4vw, 58px);
  line-height: 1.06;
  margin: 14px 0 16px;
}
.bl-headline em { font-style: italic; color: var(--moss); }
.bl-sub { max-width: 620px; color: var(--ink-soft); font-size: clamp(16px, 1.8vw, 18px); margin: 0; }

/* ── Index grid ───────────────────────────────────────────── */
.bl-list { padding: clamp(20px, 3vw, 36px) 0 clamp(30px, 4vw, 50px); }
.bl-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 22px;
}
.bl-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-decoration: none;
  transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease), border-color 0.35s var(--ease);
}
.bl-card:hover {
  transform: translateY(-3px);
  border-color: var(--sage);
  box-shadow: 0 20px 44px -24px rgba(28, 31, 26, 0.28);
}
.bl-card-img { display: block; aspect-ratio: 16/9; overflow: hidden; background: var(--paper-deep); }
.bl-card-img img { width: 100%; height: 100%; object-fit: cover; }
.bl-card-img.is-fallback { display: flex; align-items: center; justify-content: center; color: var(--sage); }
.bl-card-img.is-fallback svg { width: 54px; height: 54px; }
.bl-card-body { display: flex; flex-direction: column; gap: 8px; padding: 20px 22px 22px; }
.bl-card-date {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mist);
}
.bl-card-body h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 23px;
  line-height: 1.2;
  margin: 0;
  color: var(--ink);
}
.bl-card-body p { font-size: 14.5px; line-height: 1.55; color: var(--ink-soft); margin: 0; }
.bl-card-more { margin-top: auto; padding-top: 10px; font-size: 13.5px; font-weight: 500; color: var(--moss-deep); }

.bl-empty { padding: clamp(30px, 5vw, 60px) 0; color: var(--ink-soft); }
.bl-empty h2 { font-family: var(--font-display); font-weight: 400; font-size: 28px; margin: 0 0 8px; }
.bl-empty a { color: var(--moss-deep); }

/* ── CTA band (shared) ────────────────────────────────────── */
.bl-cta {
  margin: 0 0 70px;
  background: var(--moss-deep);
  color: var(--paper);
  border-radius: var(--radius-xl);
  padding: clamp(26px, 4vw, 46px);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.bl-cta h2 { font-family: var(--font-display); font-weight: 400; font-size: clamp(22px, 3vw, 30px); margin: 0 0 6px; }
.bl-cta p { margin: 0; color: var(--sage-soft); max-width: 560px; }
.bl-cta.is-inline { margin: clamp(34px, 5vw, 54px) auto; max-width: 760px; }

/* ── Article ──────────────────────────────────────────────── */
.bl-article-head { padding: clamp(34px, 5.5vw, 64px) 0 8px; }
.bl-crumbs { margin-bottom: 18px; }
.bl-crumbs a { font-size: 13.5px; color: var(--mist); text-decoration: none; }
.bl-crumbs a:hover { color: var(--moss-deep); }
.bl-article-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(32px, 4.8vw, 52px);
  line-height: 1.1;
  margin: 0 0 14px;
  max-width: 820px;
  margin-inline: auto;
  text-align: center;
}
.bl-article-head .container { display: flex; flex-direction: column; align-items: center; }
.bl-article-meta {
  display: flex; gap: 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--mist);
  margin: 0 0 10px;
}
.bl-article-hero {
  margin: 18px auto 0;
  max-width: 880px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: 0 28px 60px -32px rgba(28, 31, 26, 0.25);
}
.bl-article-hero img { width: 100%; display: block; }

/* article typography — comfortable measure, branded headings */
.bl-article-body {
  max-width: 720px;
  margin: clamp(26px, 4vw, 44px) auto 0;
  font-size: 17px;
  line-height: 1.75;
  color: var(--ink-soft);
}
.bl-article-body h1, .bl-article-body h2, .bl-article-body h3, .bl-article-body h4 {
  font-family: var(--font-display);
  font-weight: 400;
  color: var(--ink);
  line-height: 1.2;
  margin: 1.6em 0 0.5em;
}
.bl-article-body h1 { font-size: 34px; }
.bl-article-body h2 { font-size: 30px; }
.bl-article-body h3 { font-size: 24px; }
.bl-article-body h4 { font-size: 19px; font-family: var(--font-sans); font-weight: 600; }
.bl-article-body p { margin: 0 0 1.15em; }
.bl-article-body a { color: var(--moss-deep); text-decoration-color: var(--sage); }
.bl-article-body a:hover { color: var(--ink); }
.bl-article-body ul, .bl-article-body ol { padding-left: 1.3em; margin: 0 0 1.15em; }
.bl-article-body li { margin-bottom: 0.45em; }
.bl-article-body img { border-radius: var(--radius); margin: 1.4em auto; border: 1px solid var(--line); }
.bl-article-body blockquote {
  margin: 1.5em 0;
  padding: 4px 0 4px 20px;
  border-left: 3px solid var(--sage);
  color: var(--ink);
  font-family: var(--font-display);
  font-size: 1.15em;
  font-style: italic;
}
.bl-article-body table { width: 100%; border-collapse: collapse; margin: 1.4em 0; font-size: 15px; }
.bl-article-body th, .bl-article-body td { border: 1px solid var(--line-strong); padding: 9px 12px; text-align: left; }
.bl-article-body th { background: var(--paper-deep); font-weight: 600; color: var(--ink); }
.bl-article-body code {
  font-family: var(--font-mono);
  font-size: 0.88em;
  background: var(--paper-deep);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 1px 6px;
}
.bl-article-body pre { background: var(--ink); color: var(--paper); border-radius: var(--radius); padding: 18px 20px; overflow-x: auto; }
.bl-article-body pre code { background: none; border: none; color: inherit; }
.bl-article-body hr { border: none; border-top: 1px solid var(--line); margin: 2em 0; }

/* ── Related ──────────────────────────────────────────────── */
.bl-related { max-width: 760px; margin: 0 auto 70px; }
.bl-related h2 { font-family: var(--font-display); font-weight: 400; font-size: 26px; margin: 0 0 14px; }
.bl-related-list { display: flex; flex-direction: column; }
.bl-related-list a {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 18px;
  padding: 13px 2px;
  border-top: 1px solid var(--line);
  text-decoration: none;
  color: var(--ink);
}
.bl-related-list a:hover span { color: var(--moss-deep); }
.bl-related-list a span { font-size: 16.5px; font-weight: 500; transition: color 0.25s var(--ease); }
.bl-related-list a em { font-style: normal; font-family: var(--font-mono); font-size: 11.5px; color: var(--mist); white-space: nowrap; }

.bl-notfound { padding: clamp(60px, 10vw, 120px) var(--gutter); }
.bl-notfound .btn { margin-top: 18px; }
