/*
Theme Name: Jugend-Verbraucher-Dialog
Theme URI: https://www.jugendverbraucherdialog.de
Author: Maik Möhring Media
Author URI: https://maik-moehring.de
Description: Modernes, EEAT-optimiertes Magazin-Theme für jugendverbraucherdialog.de – Verbraucherschutz für junge Erwachsene. Sechs Themen-Cluster, redaktionelles Autorensystem, JSON-LD-Schema, Rank-Math-kompatibel, PHP 7.4+ kompatibel.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: jvd
Tags: blog, magazine, news, two-columns, right-sidebar, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* CSS-Variablen ----------------------------------------------------- */
:root {
  --jvd-primary: #0F6E56;
  --jvd-primary-dark: #085041;
  --jvd-primary-light: #E1F5EE;
  --jvd-accent: #D85A30;
  --jvd-text: #1a1a1a;
  --jvd-text-muted: #5f5e5a;
  --jvd-text-light: #888780;
  --jvd-bg: #ffffff;
  --jvd-bg-soft: #f8f7f3;
  --jvd-border: rgba(0,0,0,0.08);
  --jvd-border-strong: rgba(0,0,0,0.15);
  --jvd-radius: 8px;
  --jvd-radius-lg: 12px;
  --jvd-max-width: 1200px;
  --jvd-content-width: 720px;
  --jvd-font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --jvd-font-serif: Georgia, "Times New Roman", serif;
}

/* Reset ------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
body { margin: 0; font-family: var(--jvd-font-sans); font-size: 17px; line-height: 1.7; color: var(--jvd-text); background: var(--jvd-bg); -webkit-font-smoothing: antialiased; }
h1, h2, h3, h4, h5, h6 { font-weight: 600; line-height: 1.3; margin: 0 0 0.6em; color: var(--jvd-text); }
h1 { font-size: 36px; letter-spacing: -0.01em; }
h2 { font-size: 26px; letter-spacing: -0.005em; }
h3 { font-size: 21px; }
h4 { font-size: 18px; }
p { margin: 0 0 1.2em; }
a { color: var(--jvd-primary); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 2px; }
a:hover { color: var(--jvd-primary-dark); }
img { max-width: 100%; height: auto; display: block; }
ul, ol { padding-left: 1.4em; margin: 0 0 1.2em; }
li { margin-bottom: 0.4em; }
blockquote { margin: 1.5em 0; padding: 1em 1.4em; border-left: 4px solid var(--jvd-primary); background: var(--jvd-primary-light); font-style: italic; border-radius: 0 var(--jvd-radius) var(--jvd-radius) 0; }
code { font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 0.9em; background: var(--jvd-bg-soft); padding: 0.15em 0.4em; border-radius: 4px; }
hr { border: 0; border-top: 1px solid var(--jvd-border); margin: 2em 0; }

/* Layout ------------------------------------------------------------ */
.jvd-container { max-width: var(--jvd-max-width); margin: 0 auto; padding: 0 24px; }
.jvd-content-grid { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 48px; padding: 32px 0; }
@media (max-width: 900px) { .jvd-content-grid { grid-template-columns: 1fr; gap: 32px; } }

/* Header ------------------------------------------------------------ */
.jvd-site-header { border-bottom: 1px solid var(--jvd-border); background: var(--jvd-bg); position: sticky; top: 0; z-index: 100; }
.jvd-header-inner { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; gap: 24px; }
.jvd-brand { display: flex; align-items: center; gap: 12px; text-decoration: none; }
.jvd-brand-mark { width: 38px; height: 38px; border-radius: var(--jvd-radius); background: var(--jvd-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 15px; letter-spacing: 0.5px; }
.jvd-brand-text { line-height: 1.2; }
.jvd-brand-name { font-size: 17px; font-weight: 700; color: var(--jvd-text); display: block; }
.jvd-brand-claim { font-size: 11.5px; color: var(--jvd-text-muted); text-transform: uppercase; letter-spacing: 0.5px; }
.jvd-main-nav { display: flex; gap: 28px; }
.jvd-main-nav a { color: var(--jvd-text); text-decoration: none; font-size: 15px; font-weight: 500; }
.jvd-main-nav a:hover { color: var(--jvd-primary); }
.jvd-mobile-toggle { display: none; background: none; border: 0; cursor: pointer; font-size: 24px; color: var(--jvd-text); padding: 4px 8px; }
@media (max-width: 760px) {
  .jvd-mobile-toggle { display: block; }
  .jvd-main-nav { display: none; position: absolute; top: 100%; left: 0; right: 0; background: var(--jvd-bg); flex-direction: column; gap: 0; padding: 8px 24px; border-bottom: 1px solid var(--jvd-border); }
  .jvd-main-nav.is-open { display: flex; }
  .jvd-main-nav a { padding: 12px 0; border-bottom: 1px solid var(--jvd-border); }
  .jvd-main-nav a:last-child { border-bottom: 0; }
}

/* Hero (Front Page) ------------------------------------------------- */
.jvd-hero { background: var(--jvd-primary-light); padding: 64px 24px; text-align: center; }
.jvd-hero-inner { max-width: 720px; margin: 0 auto; }
.jvd-hero-badge { display: inline-block; padding: 5px 14px; background: #fff; border-radius: 999px; font-size: 11px; color: var(--jvd-primary); font-weight: 600; letter-spacing: 0.6px; margin-bottom: 18px; }
.jvd-hero-title { font-size: 44px; line-height: 1.15; margin: 0 0 14px; color: var(--jvd-primary-dark); letter-spacing: -0.015em; }
.jvd-hero-sub { font-size: 18px; color: var(--jvd-primary-dark); max-width: 540px; margin: 0 auto 28px; line-height: 1.55; }
.jvd-hero-cta { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.jvd-btn { display: inline-flex; align-items: center; gap: 6px; padding: 11px 22px; border-radius: var(--jvd-radius); font-size: 15px; font-weight: 600; text-decoration: none; transition: transform 0.1s, background 0.15s; cursor: pointer; border: 0; }
.jvd-btn-primary { background: var(--jvd-primary); color: #fff; }
.jvd-btn-primary:hover { background: var(--jvd-primary-dark); color: #fff; }
.jvd-btn-secondary { background: #fff; color: var(--jvd-primary-dark); border: 1px solid #5DCAA5; }
.jvd-btn-secondary:hover { background: var(--jvd-primary-light); color: var(--jvd-primary-dark); }
@media (max-width: 600px) {
  .jvd-hero { padding: 44px 24px; }
  .jvd-hero-title { font-size: 32px; }
  .jvd-hero-sub { font-size: 16px; }
}

/* Trust Bar --------------------------------------------------------- */
.jvd-trust-bar { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; padding: 24px 0; border-bottom: 1px solid var(--jvd-border); text-align: center; }
.jvd-trust-num { font-size: 24px; font-weight: 700; color: var(--jvd-text); display: block; }
.jvd-trust-label { font-size: 12px; color: var(--jvd-text-muted); }
@media (max-width: 600px) { .jvd-trust-bar { grid-template-columns: repeat(2, 1fr); gap: 16px; } }

/* Cluster Cards (Homepage) ------------------------------------------ */
.jvd-section { padding: 48px 0; }
.jvd-section-header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 24px; }
.jvd-section-title { font-size: 24px; font-weight: 700; margin: 0; }
.jvd-section-link { font-size: 14px; color: var(--jvd-primary); text-decoration: none; font-weight: 500; }
.jvd-cluster-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 900px) { .jvd-cluster-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .jvd-cluster-grid { grid-template-columns: 1fr; } }
.jvd-cluster-card { background: #fff; border: 1px solid var(--jvd-border); border-radius: var(--jvd-radius-lg); padding: 22px; text-decoration: none; transition: transform 0.15s, border-color 0.15s, box-shadow 0.15s; display: block; }
.jvd-cluster-card:hover { transform: translateY(-2px); border-color: var(--jvd-border-strong); box-shadow: 0 4px 12px rgba(0,0,0,0.04); }
.jvd-cluster-icon { width: 44px; height: 44px; border-radius: var(--jvd-radius); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; font-size: 22px; }
.jvd-cluster-name { font-size: 17px; font-weight: 700; color: var(--jvd-text); margin: 0 0 6px; }
.jvd-cluster-desc { font-size: 13.5px; color: var(--jvd-text-muted); margin: 0; line-height: 1.5; }
/* Cluster Farben */
.jvd-cluster-digital .jvd-cluster-icon { background: #EEEDFE; color: #534AB7; }
.jvd-cluster-finanzen .jvd-cluster-icon { background: #E1F5EE; color: #0F6E56; }
.jvd-cluster-wohnen .jvd-cluster-icon { background: #FAECE7; color: #993C1D; }
.jvd-cluster-mobilitaet .jvd-cluster-icon { background: #FBEAF0; color: #993556; }
.jvd-cluster-gesundheit .jvd-cluster-icon { background: #E6F1FB; color: #185FA5; }
.jvd-cluster-nachhaltig .jvd-cluster-icon { background: #EAF3DE; color: #3B6D11; }

/* Article Cards (Listings) ------------------------------------------ */
.jvd-card-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
@media (max-width: 700px) { .jvd-card-grid { grid-template-columns: 1fr; } }
.jvd-card { background: #fff; border: 1px solid var(--jvd-border); border-radius: var(--jvd-radius-lg); overflow: hidden; transition: transform 0.15s, box-shadow 0.15s; }
.jvd-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.04); }
.jvd-card-thumb { aspect-ratio: 16 / 9; background: var(--jvd-bg-soft); overflow: hidden; }
.jvd-card-thumb img { width: 100%; height: 100%; object-fit: cover; }
.jvd-card-body { padding: 18px 20px; }
.jvd-card-cat { display: inline-block; padding: 3px 10px; background: var(--jvd-primary-light); color: var(--jvd-primary-dark); border-radius: 999px; font-size: 11px; font-weight: 600; text-decoration: none; letter-spacing: 0.3px; margin-bottom: 10px; }
.jvd-card-title { font-size: 18px; font-weight: 700; line-height: 1.35; margin: 0 0 8px; }
.jvd-card-title a { color: var(--jvd-text); text-decoration: none; }
.jvd-card-title a:hover { color: var(--jvd-primary); }
.jvd-card-meta { font-size: 12.5px; color: var(--jvd-text-muted); display: flex; gap: 8px; align-items: center; }
.jvd-card-meta-sep { width: 3px; height: 3px; background: var(--jvd-text-light); border-radius: 50%; display: inline-block; }

/* Single Post ------------------------------------------------------- */
.jvd-article { max-width: var(--jvd-content-width); }
.jvd-breadcrumbs { font-size: 13px; color: var(--jvd-text-muted); margin: 0 0 20px; }
.jvd-breadcrumbs a { color: var(--jvd-text-muted); text-decoration: none; }
.jvd-breadcrumbs a:hover { color: var(--jvd-primary); text-decoration: underline; }
.jvd-breadcrumbs-sep { margin: 0 6px; color: var(--jvd-text-light); }
.jvd-article-cat { display: inline-block; padding: 4px 12px; background: var(--jvd-primary-light); color: var(--jvd-primary-dark); border-radius: 999px; font-size: 12px; font-weight: 600; text-decoration: none; margin-bottom: 14px; }
.jvd-article-title { font-size: 38px; line-height: 1.2; margin: 0 0 14px; letter-spacing: -0.01em; }
@media (max-width: 600px) { .jvd-article-title { font-size: 28px; } }
.jvd-article-excerpt { font-size: 19px; color: var(--jvd-text-muted); line-height: 1.55; margin: 0 0 24px; font-weight: 400; }
.jvd-article-meta { display: flex; align-items: center; gap: 12px; padding: 16px 0; border-top: 1px solid var(--jvd-border); border-bottom: 1px solid var(--jvd-border); margin: 0 0 32px; flex-wrap: wrap; }
.jvd-article-thumb { margin: 0 0 32px; border-radius: var(--jvd-radius-lg); overflow: hidden; }
.jvd-article-content { font-size: 17px; line-height: 1.75; }
.jvd-article-content > * + h2 { margin-top: 1.8em; }
.jvd-article-content > * + h3 { margin-top: 1.4em; }
.jvd-article-content figure { margin: 1.5em 0; }
.jvd-article-content figcaption { font-size: 13px; color: var(--jvd-text-muted); text-align: center; margin-top: 8px; }
.jvd-article-content table { width: 100%; border-collapse: collapse; margin: 1.5em 0; font-size: 15px; }
.jvd-article-content th, .jvd-article-content td { border: 1px solid var(--jvd-border); padding: 10px 14px; text-align: left; }
.jvd-article-content th { background: var(--jvd-bg-soft); font-weight: 600; }

/* Avatar Initialien ------------------------------------------------- */
.jvd-avatar { width: 44px; height: 44px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-weight: 600; font-size: 15px; color: #fff; flex-shrink: 0; }
.jvd-avatar-sm { width: 32px; height: 32px; font-size: 12px; }
.jvd-avatar-lg { width: 72px; height: 72px; font-size: 24px; }
.jvd-avatar-LH { background: #0F6E56; }
.jvd-avatar-TK { background: #D85A30; }
.jvd-avatar-MA { background: #D4537E; }
.jvd-avatar-JB { background: #639922; }
.jvd-avatar-MM { background: #185FA5; }
.jvd-avatar-default { background: var(--jvd-text-muted); }

/* Author Byline ----------------------------------------------------- */
.jvd-byline { display: flex; align-items: center; gap: 10px; }
.jvd-byline-text { line-height: 1.3; }
.jvd-byline-name { font-size: 14px; font-weight: 600; color: var(--jvd-text); text-decoration: none; }
.jvd-byline-name:hover { color: var(--jvd-primary); }
.jvd-byline-role { font-size: 12px; color: var(--jvd-text-muted); display: block; }
.jvd-meta-date { font-size: 13px; color: var(--jvd-text-muted); }
.jvd-meta-reading { font-size: 13px; color: var(--jvd-text-muted); }
.jvd-meta-updated { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; background: var(--jvd-bg-soft); border-radius: 999px; font-size: 12px; color: var(--jvd-text-muted); }

/* Author Box -------------------------------------------------------- */
.jvd-author-box { background: var(--jvd-bg-soft); border-radius: var(--jvd-radius-lg); padding: 24px; margin: 40px 0; }
.jvd-author-box-header { display: flex; gap: 16px; align-items: center; margin-bottom: 14px; }
.jvd-author-box-name { font-size: 17px; font-weight: 700; margin: 0; }
.jvd-author-box-role { font-size: 13px; color: var(--jvd-text-muted); }
.jvd-author-box-bio { font-size: 14.5px; line-height: 1.65; color: var(--jvd-text); margin: 0 0 12px; }
.jvd-author-box-links { display: flex; gap: 16px; font-size: 13px; }
.jvd-author-box-links a { color: var(--jvd-primary); text-decoration: none; font-weight: 500; }

/* Editorial Standards Box ------------------------------------------- */
.jvd-editorial-box { background: #fff; border: 1px solid var(--jvd-border); border-radius: var(--jvd-radius-lg); padding: 18px 22px; margin: 32px 0; font-size: 13.5px; color: var(--jvd-text-muted); line-height: 1.55; }
.jvd-editorial-box strong { color: var(--jvd-text); display: block; font-size: 13px; margin-bottom: 4px; letter-spacing: 0.3px; text-transform: uppercase; }
.jvd-editorial-box a { color: var(--jvd-primary); }

/* FAQ Block --------------------------------------------------------- */
.jvd-faq { margin: 32px 0; }
.jvd-faq-item { border: 1px solid var(--jvd-border); border-radius: var(--jvd-radius); margin-bottom: 8px; background: #fff; overflow: hidden; }
.jvd-faq-question { padding: 14px 18px; font-weight: 600; font-size: 15px; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 12px; user-select: none; }
.jvd-faq-question::after { content: "+"; font-size: 22px; color: var(--jvd-text-muted); flex-shrink: 0; transition: transform 0.2s; }
.jvd-faq-item.is-open .jvd-faq-question::after { transform: rotate(45deg); }
.jvd-faq-answer { padding: 0 18px 14px; font-size: 15px; line-height: 1.65; display: none; }
.jvd-faq-item.is-open .jvd-faq-answer { display: block; }

/* Sidebar ----------------------------------------------------------- */
.jvd-sidebar { font-size: 14.5px; }
.jvd-widget { margin-bottom: 32px; padding: 20px; background: var(--jvd-bg-soft); border-radius: var(--jvd-radius-lg); }
.jvd-widget-title { font-size: 13px; font-weight: 700; color: var(--jvd-text); margin: 0 0 14px; text-transform: uppercase; letter-spacing: 0.6px; }
.jvd-widget ul { list-style: none; padding: 0; margin: 0; }
.jvd-widget li { padding: 8px 0; border-bottom: 1px solid var(--jvd-border); }
.jvd-widget li:last-child { border-bottom: 0; }
.jvd-widget a { color: var(--jvd-text); text-decoration: none; line-height: 1.4; display: block; }
.jvd-widget a:hover { color: var(--jvd-primary); }

.jvd-widget-popular .jvd-popular-item { display: grid; grid-template-columns: 28px 1fr; gap: 12px; align-items: start; padding: 10px 0; border-bottom: 1px solid var(--jvd-border); }
.jvd-widget-popular .jvd-popular-item:last-child { border-bottom: 0; }
.jvd-popular-num { font-size: 18px; font-weight: 700; color: var(--jvd-primary); line-height: 1; }
.jvd-popular-title { font-size: 14px; font-weight: 600; color: var(--jvd-text); text-decoration: none; line-height: 1.35; }
.jvd-popular-title:hover { color: var(--jvd-primary); }
.jvd-popular-cat { font-size: 11px; color: var(--jvd-text-muted); display: block; margin-top: 3px; }

.jvd-widget-newsletter { background: #2C2C2A; color: #fff; }
.jvd-widget-newsletter .jvd-widget-title { color: #fff; }
.jvd-widget-newsletter p { font-size: 13px; color: #B4B2A9; margin: 0 0 14px; }
.jvd-widget-newsletter input[type="email"] { width: 100%; padding: 10px 12px; border: 0; border-radius: var(--jvd-radius); background: #444441; color: #fff; font-size: 13px; margin-bottom: 8px; font-family: inherit; }
.jvd-widget-newsletter input[type="email"]::placeholder { color: #888780; }
.jvd-widget-newsletter button { width: 100%; padding: 10px; border: 0; border-radius: var(--jvd-radius); background: #fff; color: #2C2C2A; font-size: 13px; font-weight: 600; cursor: pointer; }
.jvd-widget-newsletter .jvd-newsletter-disclaimer { font-size: 11px; color: #888780; margin-top: 8px; line-height: 1.45; }

/* Pagination -------------------------------------------------------- */
.jvd-pagination { display: flex; gap: 6px; justify-content: center; padding: 32px 0; flex-wrap: wrap; }
.jvd-pagination a, .jvd-pagination span { padding: 8px 14px; border: 1px solid var(--jvd-border); border-radius: var(--jvd-radius); font-size: 14px; text-decoration: none; color: var(--jvd-text); }
.jvd-pagination .current { background: var(--jvd-primary); color: #fff; border-color: var(--jvd-primary); }
.jvd-pagination a:hover { border-color: var(--jvd-primary); color: var(--jvd-primary); }

/* Archive Header ---------------------------------------------------- */
.jvd-archive-header { padding: 40px 0 24px; border-bottom: 1px solid var(--jvd-border); margin-bottom: 32px; }
.jvd-archive-title { font-size: 32px; margin: 0 0 8px; }
.jvd-archive-desc { font-size: 16px; color: var(--jvd-text-muted); max-width: 700px; line-height: 1.55; margin: 0; }

/* Footer ------------------------------------------------------------ */
.jvd-site-footer { background: #1a1a1a; color: #B4B2A9; padding: 48px 0 24px; margin-top: 64px; }
.jvd-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 32px; }
@media (max-width: 800px) { .jvd-footer-grid { grid-template-columns: 1fr 1fr; gap: 24px; } }
@media (max-width: 480px) { .jvd-footer-grid { grid-template-columns: 1fr; } }
.jvd-footer h3 { color: #fff; font-size: 14px; margin: 0 0 14px; text-transform: uppercase; letter-spacing: 0.6px; }
.jvd-footer ul { list-style: none; padding: 0; margin: 0; }
.jvd-footer li { padding: 4px 0; }
.jvd-footer a { color: #B4B2A9; text-decoration: none; font-size: 14px; }
.jvd-footer a:hover { color: #fff; }
.jvd-footer-about { font-size: 14px; line-height: 1.6; max-width: 380px; }
.jvd-footer-bottom { display: flex; justify-content: space-between; align-items: center; margin-top: 32px; padding-top: 24px; border-top: 1px solid #444441; font-size: 12px; flex-wrap: wrap; gap: 12px; }

/* 404 / Search Empty ------------------------------------------------ */
.jvd-empty { text-align: center; padding: 80px 24px; }
.jvd-empty h1 { font-size: 64px; margin: 0; color: var(--jvd-primary); }
.jvd-empty p { font-size: 18px; color: var(--jvd-text-muted); }

/* Comments ---------------------------------------------------------- */
.jvd-comments { margin: 48px 0; }
.jvd-comments h2 { font-size: 22px; }
.jvd-comments ol { list-style: none; padding: 0; }
.jvd-comments .comment { border-bottom: 1px solid var(--jvd-border); padding: 16px 0; }
.jvd-comments .comment-meta { font-size: 13px; color: var(--jvd-text-muted); margin-bottom: 6px; }

/* Utility ----------------------------------------------------------- */
.jvd-sr-only { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.alignleft { float: left; margin: 0 1.5em 1em 0; }
.alignright { float: right; margin: 0 0 1em 1.5em; }
.aligncenter { display: block; margin: 1em auto; }
.alignwide { margin-left: -40px; margin-right: -40px; max-width: calc(100% + 80px); }
@media (max-width: 800px) { .alignwide { margin-left: 0; margin-right: 0; max-width: 100%; } }
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: 13px; color: var(--jvd-text-muted); text-align: center; margin-top: 8px; }
.screen-reader-text { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
