/*
 * insights.css — Styles für das Insights-Blog (home.php + single.php).
 *
 * Quelle: design/brainfood-insights.html  + design/brainfood-insight-artikel.html
 * Alle Klassen wurden mit .bf- Prefix versehen, Layout-Werte (max-width,
 * gaps, padding) wurden 1:1 übernommen.
 *
 * Inhalt:
 *   1) Crumb
 *   2) Hero (.bf-ph)
 *   3) Filter (.bf-filter)
 *   4) Featured-Card (.bf-featured)
 *   5) Posts-Grid (.bf-post)
 *   6) Posts-Empty + Pagination
 *   7) Newsletter (.bf-news)
 *   8) Article-Head (.bf-article__head)
 *   9) Article-Cover (.bf-article__hero)
 *  10) Article-Layout + Sidebar (.bf-article__wrap / .bf-article__side)
 *  11) Prose (.bf-prose)
 *  12) Author-Box (.bf-author-box)
 *  13) Related-Posts (.bf-related)
 *  14) Responsive Breakpoints (1024 / 768 / 540)
 */


/* =========================================================================
 * 1) CRUMB
 * ========================================================================= */
.bf-crumb {
  padding: 24px 0 8px;
  font-size: 13px;
  color: var(--bf-gray-60);
}
.bf-crumb a {
  color: inherit;
  text-decoration: none;
  transition: color 0.16s var(--ease);
}
.bf-crumb a:hover {
  color: var(--bf-green-dark-1);
}
.bf-crumb__sep {
  margin: 0 8px;
  opacity: 0.5;
}


/* =========================================================================
 * 2) HERO  (.bf-ph)
 * ========================================================================= */
.bf-ph {
  padding: 40px 0 56px;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.bf-ph::before {
  content: '';
  position: absolute;
  top: -20%;
  left: 50%;
  transform: translateX(-50%);
  width: 80%;
  height: 80%;
  background: radial-gradient(ellipse at center, rgba(0, 195, 214, 0.08) 0%, transparent 60%);
  pointer-events: none;
}
.bf-ph__inner {
  position: relative;
  max-width: 760px;
  margin: 0 auto;
}
.bf-ph__eyebrow {
  display: inline-block;
  color: var(--bf-pink);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.bf-ph h1 {
  font-family: var(--font-display);
  font-size: clamp(44px, 5.2vw, 72px);
  font-weight: 400;
  line-height: 1.03;
  letter-spacing: -0.025em;
  color: var(--bf-gray-dark);
  margin-bottom: 20px;
}
.bf-ph h1 em {
  font-style: italic;
  color: var(--bf-turquoise-dark);
}
.bf-ph__lead {
  font-size: 19px;
  line-height: 1.55;
  color: var(--bf-gray-80);
  max-width: 600px;
  margin: 0 auto;
}


/* =========================================================================
 * 3) FILTER  (.bf-filter)
 * ========================================================================= */
.bf-filter {
  padding: 8px 0 48px;
}
.bf-filter__inner {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}
.bf-filter__btn {
  padding: 9px 18px;
  border-radius: var(--radius-pill);
  font-family: inherit;
  font-weight: 600;
  font-size: 14px;
  color: var(--bf-gray-60);
  background: var(--bf-beige-hell);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: all 0.18s var(--ease);
}
.bf-filter__btn:hover {
  color: var(--bf-green-dark-1);
  background: var(--bf-turquoise-20);
}
.bf-filter__btn.is-active {
  background: var(--bf-gray-dark);
  color: #fff;
}


/* =========================================================================
 * 4) FEATURED  (.bf-featured)
 * ========================================================================= */
.bf-featured {
  padding: 0 0 64px;
}
.bf-featured__card {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  background: #fff;
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--bf-gray-20);
  box-shadow: var(--shadow-md);
  transition: all 0.3s var(--ease);
  color: inherit;
  text-decoration: none;
}
.bf-featured__card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}
.bf-featured__media {
  position: relative;
  min-height: 380px;
  overflow: hidden;
}
.bf-featured__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
}
.bf-featured__flag {
  position: absolute;
  top: 22px;
  left: 22px;
  z-index: 1;
  background: var(--bf-pink);
  color: #fff;
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.bf-featured__body {
  padding: 48px 44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.bf-featured__cat {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bf-turquoise-dark);
  margin-bottom: 14px;
}
.bf-featured__title {
  font-family: var(--font-display);
  font-size: clamp(28px, 2.8vw, 40px);
  font-weight: 400;
  line-height: 1.12;
  letter-spacing: -0.02em;
  color: var(--bf-gray-dark);
  margin-bottom: 14px;
}
.bf-featured__excerpt {
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--bf-gray-80);
  margin-bottom: 24px;
}
.bf-featured__meta {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
}
.bf-featured__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--bf-green-dark-1), var(--bf-turquoise-dark));
  color: #fff;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-size: 17px;
  flex-shrink: 0;
}
.bf-featured__avatar--tb {
  background: linear-gradient(135deg, var(--bf-pink), var(--bf-orange));
}
.bf-featured__avatar--team {
  background: linear-gradient(135deg, var(--bf-turquoise), var(--bf-green));
}
.bf-featured__byline {
  font-size: 13.5px;
  color: var(--bf-gray-60);
  line-height: 1.4;
}
.bf-featured__byline strong {
  display: block;
  color: var(--bf-gray-dark);
  font-weight: 700;
  font-size: 14px;
}
.bf-featured__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  font-size: 15px;
  color: var(--bf-green-dark-1);
  align-self: flex-start;
}
.bf-featured__link i {
  transition: transform 0.18s var(--ease);
}
.bf-featured__card:hover .bf-featured__link i {
  transform: translateX(4px);
}


/* =========================================================================
 * 5) POSTS GRID  (.bf-post)
 * ========================================================================= */
.bf-posts {
  padding: 0 0 80px;
}
.bf-posts__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.bf-post {
  background: #fff;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--bf-gray-20);
  transition: all 0.25s var(--ease);
  display: flex;
  flex-direction: column;
}
.bf-post:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.bf-post__media {
  aspect-ratio: 5 / 3;
  position: relative;
  overflow: hidden;
  display: block;
}
.bf-post__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s var(--ease);
}
.bf-post:hover .bf-post__media img {
  transform: scale(1.04);
}
.bf-post__cat {
  position: absolute;
  top: 14px;
  left: 14px;
  padding: 5px 12px;
  border-radius: var(--radius-pill);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
  color: var(--bf-gray-dark);
}
/* Color-Varianten je Category-Slug (greift, wenn Slugs entsprechend angelegt sind). */
.bf-post__cat--lernpsychologie { color: var(--bf-turquoise-dark); }
.bf-post__cat--praxis          { color: var(--bf-green-dark-1); }
.bf-post__cat--haltung         { color: var(--bf-pink); }
.bf-post__cat--ki              { color: var(--bf-orange); }
.bf-post__cat--produkt         { color: #b8920a; }

.bf-post__body {
  padding: 24px 26px 26px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.bf-post__title {
  font-family: var(--font-display);
  font-size: 23px;
  font-weight: 400;
  line-height: 1.18;
  letter-spacing: -0.015em;
  color: var(--bf-gray-dark);
  margin: 0 0 10px;
}
.bf-post__title a {
  color: inherit;
  text-decoration: none;
}
.bf-post__title a:hover {
  color: var(--bf-green-dark-1);
}
.bf-post__excerpt {
  font-size: 14px;
  line-height: 1.6;
  color: var(--bf-gray-80);
  margin-bottom: 20px;
  flex-grow: 1;
}
.bf-post__foot {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-top: 18px;
  border-top: 1px solid var(--bf-gray-20);
}
.bf-post__avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: #fff;
  font-family: var(--font-display);
  font-size: 13px;
  flex-shrink: 0;
  background: linear-gradient(135deg, var(--bf-green-dark-1), var(--bf-turquoise-dark));
}
.bf-post__avatar--fb   { background: linear-gradient(135deg, var(--bf-green-dark-1), var(--bf-turquoise-dark)); }
.bf-post__avatar--tb   { background: linear-gradient(135deg, var(--bf-pink), var(--bf-orange)); }
.bf-post__avatar--team { background: linear-gradient(135deg, var(--bf-turquoise), var(--bf-green)); }
.bf-post__foot-meta {
  font-size: 12px;
  color: var(--bf-gray-60);
  line-height: 1.4;
}
.bf-post__foot-meta strong {
  color: var(--bf-gray-dark);
  font-weight: 600;
  font-size: 12.5px;
  display: block;
}
.bf-post__readtime {
  margin-left: auto;
  font-size: 12px;
  color: var(--bf-gray-60);
  display: flex;
  align-items: center;
  gap: 5px;
}
.bf-post__readtime i {
  font-size: 13px;
  line-height: 1;
}


/* =========================================================================
 * 6) POSTS-EMPTY + PAGINATION
 * ========================================================================= */
.bf-posts__empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--bf-gray-60);
  display: none;
}
.bf-posts__empty--visible {
  display: block;
}
.bf-posts__empty-title {
  font-family: var(--font-display);
  font-size: 26px;
  color: var(--bf-gray-dark);
  font-weight: 400;
  margin-bottom: 6px;
}
.bf-pagination {
  margin-top: 48px;
  display: flex;
  justify-content: center;
  gap: 12px;
}
.bf-pagination .nav-links {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.bf-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 14px;
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: 14px;
  color: var(--bf-gray-80);
  background: var(--bf-beige-hell);
  text-decoration: none;
  transition: all 0.16s var(--ease);
}
.bf-pagination .page-numbers:hover {
  background: var(--bf-turquoise-20);
  color: var(--bf-green-dark-1);
}
.bf-pagination .page-numbers.current {
  background: var(--bf-gray-dark);
  color: #fff;
}
.bf-pagination .page-numbers.dots {
  background: transparent;
}


/* =========================================================================
 * 7) NEWSLETTER  (.bf-news)
 * ========================================================================= */
.bf-news {
  padding: 0 0 100px;
}
.bf-news__inner {
  background: linear-gradient(135deg, var(--bf-gray-dark) 0%, var(--bf-green-dark-1) 100%);
  border-radius: var(--radius-xl);
  padding: 64px 56px;
  color: #fff;
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 48px;
  align-items: center;
}
.bf-news__inner::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 85% 20%, rgba(0, 195, 214, 0.2) 0%, transparent 50%),
    radial-gradient(circle at 10% 90%, rgba(221, 31, 90, 0.12) 0%, transparent 45%);
  pointer-events: none;
}
.bf-news__content {
  position: relative;
}
.bf-news__eyebrow {
  display: inline-block;
  color: var(--bf-turquoise-40);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.bf-news__title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 12px;
}
.bf-news__title em {
  font-style: italic;
  color: var(--bf-turquoise-40);
}
.bf-news__text {
  font-size: 15px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
}
.bf-news__form {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.bf-news__field {
  width: 100%;
  padding: 15px 20px;
  font-family: inherit;
  font-size: 15px;
  background: rgba(255, 255, 255, 0.1);
  border: 1.5px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--radius-pill);
  color: #fff;
  outline: none;
  transition: all 0.18s var(--ease);
}
.bf-news__field::placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.bf-news__field:focus {
  border-color: var(--bf-turquoise-40);
  background: rgba(255, 255, 255, 0.14);
}
.bf-news__submit {
  justify-content: center;
  width: 100%;
}
.bf-news__hint {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.5);
  text-align: center;
  line-height: 1.5;
}


/* =========================================================================
 * 8) ARTICLE HEADER  (.bf-article__head)
 * ========================================================================= */
.bf-article__head {
  padding: 24px 0 40px;
  text-align: center;
}
.bf-article__head-inner {
  max-width: 780px;
  margin: 0 auto;
}
.bf-article__cat {
  display: inline-block;
  color: var(--bf-turquoise-dark);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.bf-article__title {
  font-family: var(--font-display);
  font-size: clamp(34px, 4.4vw, 58px);
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.022em;
  color: var(--bf-gray-dark);
  margin-bottom: 22px;
}
.bf-article__standfirst {
  font-size: 20px;
  line-height: 1.55;
  color: var(--bf-gray-80);
  margin-bottom: 30px;
}
.bf-article__meta {
  display: inline-flex;
  align-items: center;
  gap: 16px;
}
.bf-article__avatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--bf-green-dark-1), var(--bf-turquoise-dark));
  color: #fff;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-size: 20px;
  flex-shrink: 0;
}
.bf-article__avatar--tb   { background: linear-gradient(135deg, var(--bf-pink), var(--bf-orange)); }
.bf-article__avatar--team { background: linear-gradient(135deg, var(--bf-turquoise), var(--bf-green)); }
.bf-article__byline {
  text-align: left;
  font-size: 13.5px;
  color: var(--bf-gray-60);
  line-height: 1.5;
}
.bf-article__byline strong {
  display: block;
  color: var(--bf-gray-dark);
  font-weight: 700;
  font-size: 14.5px;
}


/* =========================================================================
 * 9) ARTICLE COVER  (.bf-article__hero)
 * ========================================================================= */
.bf-article__hero {
  padding: 0 0 8px;
}
.bf-article__hero-img {
  width: 100%;
  aspect-ratio: 21 / 9;
  object-fit: cover;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
}


/* =========================================================================
 * 10) ARTICLE LAYOUT + SIDEBAR  (.bf-article__wrap / .bf-article__side)
 * ========================================================================= */
.bf-article__wrap {
  padding: 48px 0 80px;
}
.bf-article__grid {
  display: grid;
  grid-template-columns: minmax(0, 680px) minmax(0, 320px);
  gap: 48px;
  justify-content: center;
}
.bf-article__body {
  min-width: 0;
}
.bf-article__side {
  min-width: 0;
}

.bf-article__meta-foot {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--bf-gray-20);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
}
.bf-article__tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.bf-article__tag {
  font-size: 12px;
  font-weight: 600;
  color: var(--bf-gray-60);
  background: var(--bf-beige-hell);
  padding: 5px 12px;
  border-radius: var(--radius-pill);
}
.bf-article__tag--cat {
  color: var(--bf-green-dark-1);
  background: var(--bf-turquoise-20);
}
.bf-article__updated {
  font-size: 12.5px;
  color: var(--bf-gray-60);
}


/* =========================================================================
 * 11) PROSE  (.bf-prose) — Standard-Editor-Inhalt
 * ========================================================================= */
.bf-prose {
  font-size: 17.5px;
  line-height: 1.72;
  color: var(--bf-gray-80);
}
.bf-prose > p {
  margin-bottom: 24px;
}
.bf-prose > p:first-of-type {
  font-size: 19px;
  color: var(--bf-gray-dark);
}
.bf-prose h2 {
  font-family: var(--font-display);
  font-size: 30px;
  font-weight: 400;
  line-height: 1.18;
  letter-spacing: -0.018em;
  color: var(--bf-gray-dark);
  margin: 48px 0 16px;
  scroll-margin-top: 108px;
}
.bf-prose h3 {
  font-family: var(--font-display);
  font-size: 23px;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -0.015em;
  color: var(--bf-gray-dark);
  margin: 36px 0 12px;
}
.bf-prose strong {
  color: var(--bf-gray-dark);
  font-weight: 700;
}
.bf-prose em {
  font-style: italic;
}
.bf-prose a {
  color: var(--bf-green-dark-1);
  font-weight: 600;
  border-bottom: 1.5px solid var(--bf-turquoise);
  transition: color 0.16s;
}
.bf-prose a:hover {
  color: var(--bf-turquoise-dark);
}
.bf-prose ul,
.bf-prose ol {
  margin: 0 0 24px;
  padding-left: 4px;
  list-style: none;
}
.bf-prose ul li,
.bf-prose ol li {
  position: relative;
  padding-left: 30px;
  margin-bottom: 12px;
}
.bf-prose ul li::before {
  content: '';
  position: absolute;
  left: 2px;
  top: 10px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--bf-turquoise), var(--bf-green));
}
.bf-prose ol {
  counter-reset: li;
}
.bf-prose ol li {
  counter-increment: li;
}
.bf-prose ol li::before {
  content: counter(li);
  position: absolute;
  left: 0;
  top: 2px;
  width: 22px;
  height: 22px;
  border-radius: 7px;
  background: var(--bf-turquoise-20);
  color: var(--bf-green-dark-1);
  font-family: var(--font-display);
  font-size: 13px;
  display: grid;
  place-items: center;
}
.bf-prose blockquote {
  margin: 40px 0;
  padding: 32px 36px;
  background: linear-gradient(135deg, var(--bf-gray-dark) 0%, var(--bf-green-dark-1) 100%);
  color: #fff;
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
}
.bf-prose blockquote p {
  font-family: var(--font-display);
  font-size: 25px;
  font-weight: 400;
  line-height: 1.32;
  letter-spacing: -0.012em;
  position: relative;
  margin-bottom: 0;
}
.bf-prose blockquote em {
  color: var(--bf-turquoise-40);
  font-style: italic;
}
.bf-prose img,
.bf-prose figure img {
  width: 100%;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}
.bf-prose figure {
  margin: 36px 0;
}
.bf-prose figcaption {
  text-align: center;
  font-size: 12.5px;
  color: var(--bf-gray-60);
  margin-top: 10px;
  font-style: italic;
}


/* =========================================================================
 * 12) AUTHOR-BOX  (.bf-author-box)
 * ========================================================================= */
.bf-author-box {
  padding: 28px;
  background: var(--bf-beige-hell);
  border-radius: var(--radius-xl);
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-bottom: 32px;
}
.bf-author-box__avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--bf-green-dark-1), var(--bf-turquoise-dark));
  color: #fff;
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  font-size: 28px;
  flex-shrink: 0;
}
.bf-author-box__avatar--tb   { background: linear-gradient(135deg, var(--bf-pink), var(--bf-orange)); }
.bf-author-box__avatar--team { background: linear-gradient(135deg, var(--bf-turquoise), var(--bf-green)); }
.bf-author-box__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bf-pink);
  margin-bottom: 6px;
}
.bf-author-box__name {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 400;
  letter-spacing: -0.015em;
  color: var(--bf-gray-dark);
  margin-bottom: 4px;
}
.bf-author-box__role {
  font-size: 13.5px;
  color: var(--bf-gray-60);
  margin-bottom: 12px;
}
.bf-author-box__bio {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--bf-gray-80);
  margin-bottom: 14px;
}
.bf-author-box__links {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.bf-author-box__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--bf-green-dark-1);
  padding: 6px 12px;
  background: #fff;
  border-radius: var(--radius-pill);
  border: 1px solid var(--bf-turquoise-20);
  text-decoration: none;
  transition: all 0.16s var(--ease);
}
.bf-author-box__link:hover {
  background: var(--bf-turquoise-20);
}


/* =========================================================================
 * 13) RELATED-POSTS  (.bf-related)
 * ========================================================================= */
.bf-related {
  padding: 24px;
  background: #fff;
  border: 1px solid var(--bf-gray-20);
  border-radius: var(--radius-lg);
}
.bf-related__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bf-pink);
  margin-bottom: 16px;
}
.bf-related__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.bf-related__item {
  border-bottom: 1px solid var(--bf-gray-20);
  padding-bottom: 18px;
}
.bf-related__item:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}
.bf-related__card {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 14px;
  color: inherit;
  text-decoration: none;
  transition: transform 0.18s var(--ease);
}
.bf-related__card:hover {
  transform: translateX(2px);
}
.bf-related__media {
  width: 88px;
  height: 64px;
  border-radius: var(--radius-md);
  overflow: hidden;
}
.bf-related__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s var(--ease);
}
.bf-related__card:hover .bf-related__media img {
  transform: scale(1.04);
}
.bf-related__body {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.bf-related__cat {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--bf-turquoise-dark);
  margin-bottom: 4px;
}
.bf-related__title {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.22;
  letter-spacing: -0.012em;
  color: var(--bf-gray-dark);
  margin: 0 0 4px;
}
.bf-related__meta {
  font-size: 12px;
  color: var(--bf-gray-60);
}


/* =========================================================================
 * 14) RESPONSIVE BREAKPOINTS — wie in den Design-Vorlagen
 *      (1024 / 768 / 540)
 * ========================================================================= */
@media (max-width: 1024px) {
  .bf-featured__card {
    grid-template-columns: 1fr;
  }
  .bf-featured__media {
    min-height: 280px;
    aspect-ratio: 16 / 9;
  }
  .bf-featured__body {
    padding: 36px 32px;
  }
  .bf-posts__grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .bf-news__inner {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 48px 36px;
  }
  .bf-article__grid {
    grid-template-columns: 1fr;
    max-width: 720px;
    margin: 0 auto;
    gap: 32px;
  }
  .bf-article__side {
    order: 2;
  }
}

@media (max-width: 768px) {
  .bf-posts__grid {
    grid-template-columns: 1fr;
  }
  .bf-article__hero-img {
    aspect-ratio: 16 / 10;
  }
  .bf-prose {
    font-size: 16.5px;
  }
  .bf-prose h2 {
    font-size: 26px;
  }
  .bf-prose blockquote {
    padding: 24px 26px;
  }
  .bf-prose blockquote p {
    font-size: 21px;
  }
  .bf-author-box {
    text-align: center;
    align-items: center;
  }
  .bf-author-box__avatar {
    margin: 0 auto;
  }
  .bf-author-box__links {
    justify-content: center;
  }
  .bf-related__card {
    grid-template-columns: 72px 1fr;
  }
  .bf-related__media {
    width: 72px;
    height: 54px;
  }
}

@media (max-width: 540px) {
  .bf-featured__body {
    padding: 28px 24px;
  }
  .bf-news__inner {
    padding: 36px 24px;
  }
  .bf-article__meta {
    flex-direction: column;
    text-align: center;
    gap: 10px;
  }
  .bf-article__byline {
    text-align: center;
  }
}
