/* =================================================================
   TPN Blog-Manager · Frontend-Design (Blog + Beitrag)
   Markengrün #008c45 · self-contained (Container & Button inklusive)
   ================================================================= */
.tpn-post, .tpn-blog { font-family: 'Manrope', -apple-system, system-ui, sans-serif; color: #3b3b3b; background:#fff; }
.tpn-post *, .tpn-blog * { box-sizing: border-box; }
.tpn-container-wide { max-width: 1180px; margin: 0 auto; padding: 0 24px; }
.tpn-btn { display:inline-flex; align-items:center; gap:8px; padding:13px 26px; border-radius:8px; font-weight:700; font-size:.95rem; border:2px solid #008c45; background:#008c45; color:#fff; text-decoration:none; transition:all .25s; cursor:pointer; }
.tpn-btn:hover { background:#00733a; border-color:#00733a; color:#fff; transform:translateY(-2px); }
.tpn-btn-line { background:transparent; color:#fff; border-color:rgba(255,255,255,.6); }
.tpn-btn-line:hover { background:rgba(255,255,255,.12); border-color:#fff; }

/* ---- Hide doppelten Theme-Titel auf TPN-Seiten ---- */
body:has(.tpn-post) .post-header, body:has(.tpn-blog) .post-header { display: none !important; }

/* ============ ÜBERSICHT / ARCHIV ============ */
.tpn-blog-hero { background:linear-gradient(180deg,#f3f8f5 0%,#fff 100%); padding:56px 0 32px; text-align:center; }
.tpn-blog-hero h1 { font-family:'Fraunces','Georgia',serif; font-weight:700; font-size:clamp(2rem,4.5vw,3rem); line-height:1.12; margin:0 0 12px; color:#1f2a24; }
.tpn-blog-hero p { max-width:640px; margin:0 auto; font-size:1.05rem; line-height:1.65; color:#5b6168; }
.tpn-blog-eyebrow { font-size:.8rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:#008c45; margin:0 0 12px; }
.tpn-blog-crumbs { font-size:.85rem; color:#9aa3a0; margin:0 0 14px; }
.tpn-blog-crumbs a { color:#6b6560; text-decoration:none; }
.tpn-blog-crumbs a:hover { color:#008c45; }
.tpn-blog-crumbs span { margin:0 6px; }
.tpn-blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:26px; padding:32px 0; }
.tpn-blog-card { display:flex; flex-direction:column; background:#fff; border:1px solid #e8ece9; border-radius:16px; overflow:hidden; transition:transform .25s,box-shadow .25s; }
.tpn-blog-card:hover { transform:translateY(-5px); box-shadow:0 22px 48px rgba(0,92,47,.12); }
.tpn-blog-card-media { aspect-ratio:16/10; background:linear-gradient(135deg,#008c45,#00733a); overflow:hidden; }
.tpn-blog-card-media img { width:100%; height:100%; object-fit:cover; display:block; }
.tpn-blog-card-body { padding:22px; display:flex; flex-direction:column; flex:1; }
.tpn-blog-card-tag { align-self:flex-start; font-size:.72rem; font-weight:700; text-transform:uppercase; color:#00733a; background:#dcefe3; padding:4px 10px; border-radius:6px; margin-bottom:12px; }
.tpn-blog-card h2 { font-size:1.18rem; line-height:1.3; font-weight:700; color:#1f2a24; margin:0 0 10px; }
.tpn-blog-card h2 a { color:inherit; text-decoration:none; }
.tpn-blog-card h2 a:hover { color:#008c45; }
.tpn-blog-card p { font-size:.93rem; line-height:1.6; color:#6b6560; margin:0 0 16px; }
.tpn-blog-card-foot { margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:12px; }
.tpn-blog-card-meta { font-size:.8rem; color:#9aa3a0; }
.tpn-blog-card-link { font-weight:700; font-size:.9rem; color:#008c45; text-decoration:none; }
.tpn-blog-card-link:hover { color:#005c2f; }
.tpn-blog-note { text-align:center; color:#9aa3a0; padding:24px 0; }
.tpn-blog-pagination { text-align:center; padding:8px 0 48px; }
.tpn-blog-pagination .page-numbers { display:inline-block; padding:8px 14px; margin:0 3px; border:1px solid #e0e4e1; border-radius:8px; color:#3b3b3b; text-decoration:none; }
.tpn-blog-pagination .current { background:#008c45; border-color:#008c45; color:#fff; }

/* ============ BEITRAG ============ */
.tpn-post-head { background:linear-gradient(180deg,#f3f8f5 0%,#fff 100%); padding:36px 0 8px; }
.tpn-post-crumbs { font-size:.85rem; color:#9aa3a0; margin-bottom:18px; }
.tpn-post-crumbs a { color:#6b6560; text-decoration:none; }
.tpn-post-crumbs a:hover { color:#008c45; }
.tpn-post-crumbs span { margin:0 6px; }
.tpn-post-crumbs .tpn-post-crumb-cat { margin:0; color:#9aa3a0; }
.tpn-post-tag { display:inline-block; font-size:.72rem; font-weight:700; text-transform:uppercase; color:#00733a; background:#dcefe3; padding:5px 12px; border-radius:6px; }
.tpn-post-title { font-family:'Fraunces','Georgia',serif; font-weight:700; font-size:clamp(2rem,4.5vw,3.1rem); line-height:1.12; color:#1f2a24; margin:16px 0 14px; max-width:900px; }
.tpn-post-meta { display:flex; flex-wrap:wrap; gap:18px; color:#6b6560; font-size:.9rem; }
.tpn-post-hero { margin:28px 0 0; text-align:center; }
/* Beitragsbild als zentrierte Figur: vollständig sichtbar (kein Zuschnitt), Höhe
   begrenzt, keine Verzerrung – funktioniert für Banner, Quadrat und Infografik.
   Der Rahmen/Schatten umschließt exakt das Bild (keine leeren Seitenstreifen). */
.tpn-post-hero-img { display:inline-block; max-width:100%; max-height:560px; width:auto; height:auto; border-radius:16px; box-shadow:0 18px 44px rgba(0,92,47,.12); }
/* Platzhalter (kein Bild gesetzt): bleibt der 21:9-Banner. */
.tpn-post-hero-ph { width:100%; aspect-ratio:21/9; object-fit:cover; border-radius:18px; display:block; background:linear-gradient(135deg,#008c45,#00733a); box-shadow:0 24px 50px rgba(0,92,47,.16); }

.tpn-post-layout { display:grid; grid-template-columns:260px 1fr; gap:48px; padding:44px 0 8px; align-items:start; }
.tpn-post-toc { position:sticky; top:110px; align-self:start; background:#f5f7f5; border:1px solid #e8ece9; border-radius:14px; padding:22px; }
.tpn-post-toc:empty, .tpn-post-toc.is-empty { display:none; }
.tpn-post-toc h4 { font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:#008c45; margin:0 0 14px; font-weight:700; }
.tpn-post-toc ul { list-style:none; margin:0; padding:0; display:grid; gap:4px; }
.tpn-post-toc a { display:block; padding:6px 10px; border-left:2px solid transparent; border-radius:0 6px 6px 0; color:#5b6168; text-decoration:none; font-size:.9rem; line-height:1.4; transition:all .2s; }
.tpn-post-toc a:hover { color:#008c45; background:#ecf7f0; }
.tpn-post-toc a.is-active { color:#00733a; font-weight:700; border-left-color:#008c45; background:#ecf7f0; }
.tpn-post-layout.no-toc { grid-template-columns:1fr; }
.tpn-post-layout.no-toc .tpn-post-toc { display:none; }
.tpn-post-layout.no-toc .tpn-post-body { max-width:820px; }

.tpn-post-body { font-size:1.05rem; line-height:1.75; color:#2f3733; }
.tpn-post-body h2 { font-family:'Fraunces','Georgia',serif; font-weight:700; font-size:1.6rem; line-height:1.25; color:#1f2a24; margin:42px 0 14px; scroll-margin-top:110px; }
.tpn-post-body h3 { font-size:1.2rem; font-weight:700; color:#1f2a24; margin:28px 0 10px; }
.tpn-post-body p { margin:0 0 16px; }
.tpn-post-body a { color:#008c45; text-decoration:underline; text-underline-offset:2px; }
.tpn-post-body ul, .tpn-post-body ol { margin:0 0 18px; padding-left:24px; }
.tpn-post-body li { margin-bottom:8px; }
.tpn-post-body ul li::marker, .tpn-post-body ol li::marker { color:#008c45; }
.tpn-post-body img { max-width:100%; height:auto; border-radius:14px; margin:8px 0; }
.tpn-post-body blockquote { margin:24px 0; padding:18px 24px; border-left:4px solid #008c45; background:#f3f8f5; border-radius:0 12px 12px 0; font-style:italic; }
.tpn-post-body table { width:100%; border-collapse:collapse; margin:24px 0; font-size:.95rem; }
.tpn-post-body th, .tpn-post-body td { padding:12px 14px; text-align:left; border:1px solid #e8ece9; }
.tpn-post-body thead th { background:#008c45; color:#fff; }
.tpn-post-body tbody tr:nth-child(even) { background:#f5f7f5; }

/* FAQ (Shortcode) */
.tpn-post-faq { max-width:820px; margin:8px 0; }
.tpn-post-faq-item { border:1px solid #e8ece9; border-radius:12px; margin-bottom:12px; overflow:hidden; background:#fff; }
.tpn-post-faq-q { width:100%; text-align:left; background:none; border:none; cursor:pointer; padding:18px 20px; font-weight:700; font-size:1.02rem; color:#1f2a24; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.tpn-post-faq-q .pm { color:#008c45; font-size:1.4rem; line-height:1; transition:transform .25s; }
.tpn-post-faq-item.is-open .tpn-post-faq-q .pm { transform:rotate(45deg); }
.tpn-post-faq-a { max-height:0; overflow:hidden; transition:max-height .3s ease; }
.tpn-post-faq-a-inner { padding:0 20px 18px; color:#5b6168; line-height:1.65; }

/* CTA-Box */
.tpn-post-promo { margin:40px 0; padding:32px; border-radius:18px; color:#fff; background:linear-gradient(135deg,#008c45,#00733a); }
.tpn-post-promo small { font-size:.74rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:#cfe9d9; }
.tpn-post-promo h3 { font-family:'Fraunces','Georgia',serif; font-weight:700; font-size:1.5rem; margin:8px 0; }
.tpn-post-promo p { opacity:.92; margin:0 0 20px; }
.tpn-post-promo .tpn-btn { background:#fff; color:#00733a; border-color:#fff; }
.tpn-post-promo .tpn-btn:hover { background:#eef7f1; color:#005c2f; }

/* Weitere Beiträge */
.tpn-post-related-wrap { padding:24px 0 56px; }
.tpn-post-related-h { font-family:'Fraunces','Georgia',serif; font-weight:700; font-size:1.6rem; color:#1f2a24; text-align:center; margin:24px 0 0; }
.tpn-post-related-wrap .tpn-blog-grid { padding-top:24px; }

/* ============ ÜBERSICHT: KATEGORIE-KACHELN + FILTER ============ */
.tpn-blog-cats { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; padding:28px 0 4px; }
.tpn-blog-cat { display:flex; flex-direction:column; gap:8px; padding:22px 24px; background:#fff; border:1px solid #e8ece9; border-radius:16px; text-decoration:none; transition:transform .2s,box-shadow .2s,border-color .2s; }
.tpn-blog-cat:hover { transform:translateY(-4px); box-shadow:0 18px 40px rgba(0,92,47,.12); border-color:#cfe6d9; }
.tpn-blog-cat-name { font-family:'Fraunces','Georgia',serif; font-weight:700; font-size:1.25rem; line-height:1.2; color:#1f2a24; }
.tpn-blog-cat-desc { font-size:.95rem; line-height:1.55; color:#5b6168; }
.tpn-blog-cat-foot { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:auto; padding-top:12px; }
.tpn-blog-cat-count { font-size:.74rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:#00733a; background:#dcefe3; padding:4px 10px; border-radius:6px; }
.tpn-blog-cat-go { font-size:.9rem; font-weight:700; color:#008c45; white-space:nowrap; }

.tpn-blog-filter { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; padding:30px 0 0; }
.tpn-blog-filter button { font:inherit; font-size:.9rem; font-weight:600; cursor:pointer; padding:8px 18px; border-radius:999px; border:1px solid #d7e2db; background:#fff; color:#3f4a44; transition:background .18s,border-color .18s,color .18s; }
.tpn-blog-filter button:hover { border-color:#008c45; color:#008c45; }
.tpn-blog-filter button.is-active { background:#008c45; border-color:#008c45; color:#fff; }

@media (max-width:980px){
	.tpn-blog-grid { grid-template-columns:repeat(2,1fr); }
	.tpn-blog-cats { grid-template-columns:repeat(2,1fr); }
	.tpn-post-layout { grid-template-columns:1fr; gap:24px; }
	.tpn-post-toc { position:static; }
}
@media (max-width:600px){
	.tpn-blog-grid { grid-template-columns:1fr; }
	.tpn-blog-cats { grid-template-columns:1fr; }
}
