/* Blog & Artikel — baut auf seiten.css auf (Tokens, Header site-nav, footer.site).
   Legacy-Aliase, damit aeltere Inline-Styles (--color-*) automatisch im neuen Palette landen. */
:root {
  --color-red:var(--accent); --color-red-dark:#9A330A;
  --color-black:var(--green-900);
  --color-gray-100:var(--bg-soft); --color-gray-200:var(--line);
  --color-gray-400:var(--muted); --color-gray-600:var(--muted); --color-gray-800:var(--text);
}

.nav-links a.active { color:var(--green-700); }

/* ---- Blog-Index ---- */
.blog-hero { background:var(--bg-soft); border-bottom:1px solid var(--line); padding:64px 0 40px; }
.blog-hero h1 { font-family:var(--display); font-weight:700; letter-spacing:-0.03em; font-size:clamp(34px,5vw,50px); color:var(--green-900); margin:0 0 12px; }
.blog-hero p { color:var(--muted); font-size:18px; max-width:600px; margin:0; }

.filter-section { padding:26px 0; border-bottom:1px solid var(--line); }
.filter-tags { display:flex; flex-wrap:wrap; gap:10px; }
.filter-tag { padding:8px 16px; background:var(--bg-soft); border:1px solid var(--line); border-radius:999px; font-size:14px; font-weight:500; color:var(--muted); cursor:pointer; font-family:var(--body); transition:all .2s; }
.filter-tag:hover, .filter-tag.active { background:var(--green-900); color:#fff; border-color:var(--green-900); }

.blog-section { padding:48px 0 16px; }
.blog-grid { display:grid; gap:36px; }
.blog-card { display:grid; grid-template-columns:180px 1fr; gap:32px; padding-bottom:36px; border-bottom:1px solid var(--line); }
@media (max-width:600px){ .blog-card{ grid-template-columns:1fr; gap:12px; } }
.blog-card:last-child { border-bottom:none; }
.blog-meta { font-size:14px; color:var(--muted); }
.blog-date { display:block; margin-bottom:8px; }
.blog-tags { display:flex; flex-wrap:wrap; gap:6px; }
.blog-tag { font-size:12px; color:var(--green-700); font-weight:600; }
.blog-content h2 { font-family:var(--display); font-size:23px; font-weight:700; letter-spacing:-0.02em; margin:0 0 10px; }
.blog-content h2 a { color:var(--green-900); }
.blog-content h2 a:hover { color:var(--green-700); text-decoration:none; }
.blog-content p { color:var(--text); margin:0 0 14px; }
.read-more { color:var(--accent); font-weight:600; font-size:15px; }
.read-more:hover { text-decoration:underline; }

/* ---- Artikel ---- */
article.post { max-width:760px; margin:0 auto; padding:56px 32px 24px; }
@media (max-width:600px){ article.post{ padding:40px 20px 16px; } }
.article-meta { margin-bottom:28px; }
.article-back { display:inline-block; color:var(--green-700); font-size:14px; font-weight:600; margin-bottom:20px; }
.article-date { font-size:14px; color:var(--muted); margin-bottom:8px; }
.article-tags { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:18px; }
.article-tag { font-size:13px; font-weight:600; color:var(--green-700); background:var(--green-50); padding:4px 12px; border-radius:999px; }
article.post h1 { font-family:var(--display); font-weight:700; letter-spacing:-0.03em; font-size:clamp(32px,5vw,46px); line-height:1.08; color:var(--green-900); margin:0 0 18px; }
.article-sub { font-size:21px; color:var(--muted); margin:0 0 28px; line-height:1.5; }
.article-intro { font-size:19px; color:var(--muted); margin:0 0 44px; padding-bottom:28px; border-bottom:1px solid var(--line); line-height:1.7; }
.article-content h2 { font-family:var(--display); font-weight:600; font-size:25px; letter-spacing:-0.02em; color:var(--green-900); margin:44px 0 16px; }
.article-content p { margin:0 0 22px; font-size:18px; line-height:1.85; color:var(--text); }
.article-content ul, .article-content ol { margin:0 0 22px 22px; font-size:18px; line-height:1.85; }
.article-content li { margin-bottom:8px; }
.article-content strong { font-weight:600; color:var(--green-900); }
.article-content a { color:var(--green-700); }
.article-content img { width:100%; border-radius:14px; margin:8px 0 28px; }
/* Hero-Bild: dezent, schmaler als die Textspalte, zentriert, kein Beschnitt */
.hero-img { display:block; width:100%; max-width:520px; height:auto; margin:8px auto 32px; border-radius:14px; }
.pull { font-size:20px; font-weight:600; color:var(--green-900); margin:30px 0; padding-left:20px; border-left:4px solid var(--accent); }

.spot { margin:26px 0; }
.spot video { width:100%; border-radius:14px; display:block; background:#000; }
.spot figcaption { font-size:14px; color:var(--muted); margin-top:8px; text-align:center; }

.article-author { display:flex; gap:20px; align-items:center; padding:28px; background:var(--bg-soft); border:1px solid var(--line); border-radius:14px; margin-top:56px; }
.author-image { width:76px; height:76px; border-radius:50%; object-fit:cover; }
.author-info h4 { font-size:16px; font-weight:600; color:var(--green-900); margin:0 0 4px; }
.author-info p { font-size:14px; color:var(--muted); margin:0 0 6px; }

.article-cta { text-align:center; padding:44px; background:var(--green-900); color:#fff; border-radius:16px; margin-top:44px; }
.article-cta h3 { font-family:var(--display); font-size:23px; margin:0 0 12px; }
.article-cta p { color:rgba(255,255,255,.72); margin:0 0 22px; }
.btn { display:inline-block; padding:14px 28px; background:var(--accent); color:#fff; border-radius:999px; font-weight:600; font-size:15px; }
.btn:hover { background:#9A330A; color:#fff; text-decoration:none; }

.article-share { margin-top:44px; padding-top:28px; border-top:1px solid var(--line); }
.article-share h4 { font-size:13px; font-weight:600; color:var(--muted); text-transform:uppercase; letter-spacing:1px; margin:0 0 14px; }
.share-links { display:flex; gap:12px; }
.share-link { padding:10px 20px; background:var(--bg-soft); border:1px solid var(--line); border-radius:999px; font-size:14px; font-weight:500; color:var(--text); }
.share-link:hover { background:var(--green-50); color:var(--green-900); text-decoration:none; }
