/* Blog index — editorial layout */

.blog { padding-bottom: 0; }

section.blog-hero {
  padding: 60px 0 24px;
  border-bottom: 1px solid var(--rule);
}
.blog-hero__title { max-width: 16ch; margin: 18px 0 20px; }
.blog-hero__body { max-width: 60ch; margin: 0 0 28px; }

.blog-cats {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 6px;
}
.blog-cat {
  font: inherit;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: transparent;
  border: 1px solid var(--rule-strong);
  color: var(--ink-2);
  padding: 7px 12px 8px;
  border-radius: 999px;
  cursor: pointer;
  transition: border-color 160ms, color 160ms, background 160ms;
}
.blog-cat:hover { color: var(--ink); border-color: var(--ink); }
.blog-cat.is-active {
  color: var(--paper);
  background: var(--ink);
  border-color: var(--ink);
}

/* Featured */
section.blog-featured { padding: 8px 0 36px; border-bottom: 1px solid var(--rule); }
.feat-card {
  margin-top: 20px;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: 48px;
  align-items: center;
  color: inherit;
}
.feat-card__img {
  position: relative;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  border-radius: 4px;
  background: var(--paper-2);
}
.feat-card__img img,
.feat-card__img svg {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 600ms cubic-bezier(.2,.7,.2,1);
}
.feat-card:hover .feat-card__img img,
.feat-card:hover .feat-card__img svg { transform: scale(1.025); }
.feat-card__title { margin: 16px 0 18px; max-width: 18ch; }
.feat-card__excerpt { margin: 0 0 28px; max-width: 52ch; color: var(--ink-2); }
.feat-card__meta {
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  display: flex;
  align-items: center;
  gap: 8px;
  text-transform: uppercase;
}
.feat-card__meta .dot { color: var(--ink-3); opacity: 0.6; }
.feat-card__cta {
  margin-left: auto;
  color: var(--ink);
  border-bottom: 1px solid var(--ink);
  padding-bottom: 1px;
}

/* Post grid */
section.blog-grid-section { padding: 40px 0 64px; }
.blog-grid {
  list-style: none;
  margin: 24px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px 40px;
}
.post-card a { display: block; color: inherit; }
.post-card__img {
  aspect-ratio: 3 / 2;
  overflow: hidden;
  border-radius: 4px;
  background: var(--paper-2);
  margin-bottom: 20px;
}
.post-card__img img,
.post-card__img svg {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 600ms cubic-bezier(.2,.7,.2,1);
}
.post-card:hover .post-card__img img,
.post-card:hover .post-card__img svg { transform: scale(1.04); }

.post-cats {
  list-style: none; margin: 0 0 12px; padding: 0;
  display: flex; flex-wrap: wrap; gap: 6px 10px;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--accent, #c9a227);
  text-transform: uppercase;
}
.post-cats li { position: relative; padding-right: 10px; }
.post-cats li + li::before {
  content: "·";
  position: absolute;
  left: -8px;
  color: var(--ink-3);
}

.post-card__title {
  font-size: 22px;
  font-weight: 460;
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin: 0 0 12px;
  color: var(--ink);
  transition: color 160ms;
}
.post-card:hover .post-card__title { color: var(--ink); text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 1px; }
.post-card__excerpt {
  color: var(--ink-2);
  font-size: 15px;
  line-height: 1.55;
  margin: 0 0 16px;
  max-width: 42ch;
}
.post-card__meta {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  display: flex; align-items: center; gap: 8px;
  text-transform: uppercase;
}
.post-card__meta .dot { opacity: 0.6; }
.post-card__weiter {
  margin-left: auto;
  color: var(--ink);
  border-bottom: 1px solid var(--ink);
  padding-bottom: 1px;
  cursor: pointer;
}
.post-card__weiter:hover { opacity: 0.7; }

.blog-foot {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  text-transform: uppercase;
}
.blog-foot__src { color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 1px; }

@media (max-width: 1000px) {
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .feat-card { grid-template-columns: 1fr; gap: 24px; }
  .blog-grid { grid-template-columns: 1fr; }
  .blog-hero { padding-top: 56px; }
}
