/* =========================================================
   wissen-PKV.de – Designvariante A
   "Trust Navy" – seriös, ruhig, vertrauensbildend
   Markenfarben: #395e77 (Steel-Blue) + #3c8323 (Brand-Grün, Akzent)
   ========================================================= */

/* Lokal gehostete Variable Fonts (DSGVO-konform, keine Google-Fonts-Einbindung) */
@font-face {
  font-family: 'Manrope';
  src: url('/assets/fonts/Manrope-VariableFont.woff2') format('woff2');
  font-weight: 200 800;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Fraunces';
  src: url('/assets/fonts/Fraunces-VariableFont.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  /* Brand-Steelblue (Logo-Wortmarke) */
  --navy-900:#2d4a5f;
  --navy-800:#395e77;
  --navy-700:#4a7390;
  --navy-100:#e1e8ee; --navy-50:#eef3f7;

  /* Brand-Grün (Logo, Primär-Akzent) */
  --brand-900:#2a5d18;
  --brand-800:#33701d;
  --brand-700:#3c8323;
  --brand-600:#4a9a2d;
  --brand-500:#5cb13a;
  --brand-100:#dcefd1;
  --brand-50:#eef8e7;

  --ink:#1f2e3b; --ink-soft:#3f5260; --muted:#6e7d8a;
  --line:#e3e7eb; --bg:#ffffff; --bg-soft:#f6f8fa;
  --ok:#3c8323; --warn:#b35309; --err:#b3261e;

  --font-display:"Fraunces", Georgia, "Times New Roman", serif;
  --font-body:"Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;

  --container:1080px;
  --radius:14px; --radius-sm:8px; --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(45,74,95,.06), 0 1px 3px rgba(45,74,95,.04);
  --shadow-md:0 4px 14px rgba(45,74,95,.08), 0 2px 4px rgba(45,74,95,.04);
  --shadow-lg:0 18px 50px rgba(45,74,95,.12), 0 6px 16px rgba(45,74,95,.06);
  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;margin:0;padding:0}
body{margin:0;padding:0;font-family:var(--font-body);font-size:17px;line-height:1.65;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand-700);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--brand-600)}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;color:var(--navy-900);letter-spacing:-.01em;line-height:1.2;margin:0 0 .6em;font-variation-settings:"opsz" 36,"SOFT" 30}
h1{font-size:clamp(2.1rem,4vw,3.2rem);font-variation-settings:"opsz" 144,"SOFT" 50}
h2{font-size:clamp(1.55rem,2.6vw,2.05rem)}
h3{font-size:1.25rem}
h4{font-size:1.05rem;font-family:var(--font-body);font-weight:700;letter-spacing:0}
p{margin:0 0 1em}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}
@media(max-width:600px){.container{padding:0 16px}}
.section{padding:48px 0;scroll-margin-top:140px}
.section--sm{padding:24px 0}
.section--soft{background:var(--bg-soft)}
.section--tint{background:linear-gradient(180deg,var(--brand-50) 0%,#fff 100%)}

.eyebrow{display:inline-block;font-size:.82rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand-700);margin-bottom:.8em}
.lead{font-size:1.18rem;color:var(--ink-soft);max-width:62ch}

/* ===== Site-Header (zweizeilig, gleiche Container-Breite) ===== */
.site-header{position:sticky;top:0;z-index:50;background:#fff}
.header-stack{display:block}

/* Obere weiße Zeile (Logo + Slogan) */
.header-main{background:#fff;border-bottom:1px solid var(--line);position:relative}

/* "Seit 2008"-Siegel, oben rechts, hängt leicht über die Header-Unterkante */
.seit-2008{
  position:absolute;
  top:-4px;
  right:24px;
  height:96px;
  width:auto;
  z-index:60;
  display:block;
  filter:drop-shadow(0 4px 6px rgba(45,74,95,.15));
  pointer-events:none;
}
@media(max-width:960px){.seit-2008{height:78px;right:18px}}
@media(max-width:560px){.seit-2008{height:62px;right:12px}}
.header-main__inner{max-width:var(--container);margin:0 auto;padding:12px 24px 18px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}

/* Suchformular im Header (oben rechts) */
.header-search{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:4px 4px 4px 14px;min-width:280px;max-width:380px;flex:1;margin-left:auto;transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}
.header-search:focus-within{border-color:var(--brand-700);box-shadow:0 0 0 4px var(--brand-50)}
.header-search__icon{width:18px;height:18px;color:var(--muted);flex-shrink:0}
.header-search input[type="search"]{flex:1;border:0;background:transparent;font:inherit;font-size:.95rem;color:var(--ink);padding:7px 4px;outline:none;min-width:0}
.header-search input[type="search"]::placeholder{color:var(--muted)}
.header-search button{background:var(--brand-700);color:#fff;border:0;border-radius:999px;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s var(--ease)}
.header-search button:hover{background:var(--brand-800)}
.header-search button svg{width:16px;height:16px}
@media(max-width:720px){.header-search{min-width:0;max-width:none;width:100%;margin-left:0}}

/* Suchformular im Footer (über dem Disclaimer) */
.footer-search{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:6px 6px 6px 16px;max-width:560px;margin:0 0 32px;transition:border-color .15s var(--ease),background .15s var(--ease)}
.footer-search:focus-within{border-color:var(--brand-500);background:rgba(255,255,255,.12)}
.footer-search__icon{width:20px;height:20px;color:#c8d3dc;flex-shrink:0}
.footer-search input[type="search"]{flex:1;border:0;background:transparent;font:inherit;font-size:1rem;color:#fff;padding:10px 4px;outline:none;min-width:0}
.footer-search input[type="search"]::placeholder{color:#8b9aa6}
.footer-search button{background:var(--brand-700);color:#fff;border:0;border-radius:var(--radius-sm);padding:10px 18px;font:inherit;font-weight:600;font-size:.92rem;cursor:pointer;flex-shrink:0;transition:background .15s var(--ease)}
.footer-search button:hover{background:var(--brand-600)}

/* Untere blaue Menüleiste – volle Breite (Header ist bereits randlos) */
.menu-bar{background:var(--navy-800);position:relative;z-index:45;isolation:isolate}
.menu-bar__inner{max-width:var(--container);margin:0 auto;padding:0 24px;display:flex;align-items:stretch}

/* Wimpel "Seit 2008" – mit Pol links und Triangel-Spitze rechts */
.wimpel{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:var(--brand-700);
  color:#fff;
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:5px 18px 5px 12px;
  position:relative;
  border-left:3px solid var(--brand-900);
  clip-path:polygon(0 0, calc(100% - 9px) 0, 100% 50%, calc(100% - 9px) 100%, 0 100%);
  white-space:nowrap;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.18);
}
.wimpel__star{
  display:inline-block;width:10px;height:10px;
  background:#fff;
  clip-path:polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
  flex-shrink:0;
}
.wimpel__num{font-family:var(--font-display);font-size:1rem;letter-spacing:0;font-weight:600;font-variation-settings:"opsz" 36}

@media(max-width:760px){
  .topbar__slogan{font-size:.78rem;gap:8px}
  .topbar__slogan-text{display:none}
}

/* Brand / Logo */
.brand{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.brand img{height:72px;width:auto;max-width:none;display:block;object-fit:contain}
@media(max-width:960px){.brand img{height:62px}}
@media(max-width:560px){.brand img{height:56px}}
/* Mobil: Logo etwas größer + weiter nach links (weniger Rand) */
@media(max-width:560px){.header-main__inner{padding:10px 12px 14px}}

/* Home-Icon in blauer Menüleiste – fester Anker links */
.nav-home{display:inline-flex;align-items:center;justify-content:center;width:52px;color:#fff;text-decoration:none;background:var(--navy-900);transition:background .2s var(--ease),color .2s var(--ease);flex-shrink:0}
.nav-home:hover{background:var(--brand-700);color:#fff}
.nav-home.is-active{background:var(--brand-700);color:#fff}
.nav-home svg{width:22px;height:22px;display:block}

/* Hauptnav (in der blauen Leiste) – Items linksbündig direkt nach Home */
.main-nav{flex:1;display:flex;align-items:stretch;justify-content:flex-start}
.main-nav > ul{list-style:none;display:flex;align-items:stretch;margin:0;padding:0}
.main-nav > ul > li{position:static;display:flex;align-items:stretch}
.main-nav > ul > li > a{
  display:inline-flex;align-items:center;gap:6px;
  padding:16px 20px;color:#fff;font-weight:600;font-size:.98rem;
  text-decoration:none;white-space:nowrap;
  border-right:1px solid rgba(255,255,255,.08);
  transition:background .2s var(--ease),color .2s var(--ease);
  position:relative;
}
.main-nav > ul > li:first-child > a{border-left:1px solid rgba(255,255,255,.08)}
.main-nav > ul > li > a:hover,
.main-nav > ul > li.has-dropdown.is-open > a{background:var(--navy-900);color:#fff}
.main-nav > ul > li > a.is-active{background:var(--brand-700);color:#fff}
.main-nav .caret{font-size:.65rem;opacity:.7;transition:transform .2s var(--ease)}
.main-nav li.has-dropdown.is-open > a .caret{transform:rotate(180deg);opacity:1}

/* Akzent-Strich unten bei Hover */
.main-nav > ul > li > a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;
  height:3px;background:var(--brand-700);
  transform:scaleX(0);transform-origin:left;
  transition:transform .25s var(--ease);
}
.main-nav > ul > li:hover > a::after,
.main-nav > ul > li.has-dropdown.is-open > a::after{transform:scaleX(1)}
.main-nav > ul > li > a.is-active::after{transform:scaleX(1);background:var(--brand-500)}

/* DROPDOWN – Karte direkt unter dem Menüpunkt (nicht mehr full-bleed) */
.main-nav > ul > li.has-dropdown{position:relative}
.main-nav .dropdown{
  display:none;
  position:absolute;left:0;top:100%;
  background:#fff;
  border:1px solid var(--line);
  border-top:3px solid var(--brand-700);
  box-shadow:0 18px 40px -12px rgba(12,22,32,.22);
  list-style:none;
  padding:0;
  margin:0;
  z-index:60;
}
.main-nav li.has-dropdown.is-open > .dropdown{display:block}
/* Desktop: Mouseover öffnet das Dropdown (Mobil = Klick, s. Media Query) */
@media(min-width:981px){
  .main-nav li.has-dropdown:hover > .dropdown{display:block}
  .main-nav li.has-dropdown:hover > a{background:var(--navy-900);color:#fff}
  .main-nav li.has-dropdown:hover > a .caret{transform:rotate(180deg);opacity:1}
  .main-nav li.has-dropdown:hover > a::after{transform:scaleX(1)}
}

.dropdown__inner{
  display:grid;
  gap:26px;
  padding:22px 24px 20px;
}
.dropdown__inner--cols-1{grid-template-columns:240px}
.dropdown__inner--cols-2{grid-template-columns:repeat(2, 220px)}
.dropdown__inner--cols-3{grid-template-columns:repeat(3, 210px)}
.dropdown__inner--cols-4{grid-template-columns:repeat(4, 200px)}
/* Breite Dropdowns nicht rechts aus dem Bild laufen lassen */
.main-nav > ul > li:nth-last-child(-n+2) .dropdown{left:auto;right:0}
@media(max-width:900px){
  .dropdown__inner,.dropdown__inner--cols-2,.dropdown__inner--cols-3,.dropdown__inner--cols-4{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}
}

.dropdown__col{display:flex;flex-direction:column}
.dropdown__col h4{
  font-family:var(--font-body);font-size:.78rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  margin:0 0 12px;padding-bottom:10px;border-bottom:2px solid var(--brand-700);
}
.dropdown__col-pillar{color:var(--navy-900);text-decoration:none;transition:color .12s var(--ease)}
.dropdown__col-pillar:hover{color:var(--brand-700)}
.dropdown__col ul{list-style:none;padding:0;margin:0 0 12px;flex:1}
.dropdown__col li{margin:0}
.dropdown__col ul a{
  display:block;padding:5px 0;
  color:var(--ink);font-size:.9rem;font-weight:500;line-height:1.35;
  text-decoration:none;
  transition:color .12s var(--ease),padding-left .12s var(--ease);
  border-left:2px solid transparent;padding-left:0;
}
.dropdown__col ul a:hover{color:var(--brand-700);padding-left:8px;border-left-color:var(--brand-700)}
.dropdown__all{
  font-size:.8rem;font-weight:700;color:var(--brand-700);text-decoration:none;
  letter-spacing:.02em;margin-top:auto;
}
.dropdown__all:hover{color:var(--brand-800);text-decoration:underline}

/* Mobile-Toggle */
.nav-toggle{display:none;background:transparent;border:0;width:54px;cursor:pointer;align-items:center;justify-content:center;color:#fff;padding:0;margin-left:auto}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:'';display:block;width:22px;height:2px;background:#fff;position:relative;transition:transform .25s var(--ease)}
.nav-toggle span::before{position:absolute;top:-7px}
.nav-toggle span::after{position:absolute;top:7px}
/* Burger -> X wenn offen */
.nav-toggle.is-active span{background:transparent}
.nav-toggle.is-active span::before{top:0;transform:rotate(45deg)}
.nav-toggle.is-active span::after{top:0;transform:rotate(-45deg)}

@media(max-width:980px){
  /* Blaue Leiste kräftiger + Home links, Burger mit Label rechts */
  .menu-bar__inner{padding:0;min-height:56px;align-items:center}
  .nav-home{width:56px;min-height:56px;flex-shrink:0}
  .nav-toggle{display:inline-flex;align-items:center;gap:10px;width:auto;min-height:56px;padding:0 22px 0 18px;margin-left:auto;color:#fff}
  .nav-toggle::after{content:"Menü";font-weight:700;font-size:.95rem;letter-spacing:.04em}
  .nav-toggle.is-active::after{content:"Schließen"}

  /* Off-Canvas-Menü */
  .main-nav{position:absolute;top:100%;left:0;right:0;background:var(--navy-800);display:none;max-height:80vh;overflow-y:auto;flex:none;width:100%;box-shadow:0 18px 40px -10px rgba(0,0,0,.35)}
  .main-nav.is-open{display:block}
  .main-nav > ul{flex-direction:column;width:100%}
  .main-nav > ul > li{display:block;border-bottom:1px solid rgba(255,255,255,.08)}
  .main-nav > ul > li > a{padding:16px 22px;border-right:0;width:100%;font-size:1.02rem;justify-content:space-between}
  .main-nav > ul > li > a::after{display:none}
  .main-nav .caret{margin-left:auto;font-size:.8rem;opacity:.8;transition:transform .25s var(--ease)}
  .main-nav > ul > li.is-open > a .caret{transform:rotate(180deg)}
  .main-nav > ul > li.is-open > a{background:var(--navy-900)}

  /* Dropdown = Akkordeon: standardmäßig zu, nur bei .is-open auf */
  .main-nav .dropdown{position:static;display:none;border:none;box-shadow:none;background:var(--navy-900)}
  .main-nav > ul > li.is-open > .dropdown{display:block}
  .dropdown__inner,
  .dropdown__inner--cols-1,.dropdown__inner--cols-2,.dropdown__inner--cols-3,.dropdown__inner--cols-4{
    display:block;padding:4px 22px 16px;max-width:none;margin:0;gap:0;
  }
  .dropdown__col{margin:14px 0 0}
  .dropdown__col h4{border-bottom-color:rgba(255,255,255,.12);margin-bottom:8px}
  .dropdown__col-pillar{color:var(--brand-500)}
  .dropdown__col-pillar:hover{color:#fff}
  .dropdown__col ul a{color:#dde6ec;padding:8px 0}
  .dropdown__col ul a:hover{color:#fff;background:transparent;border-left-color:var(--brand-500)}
  .dropdown__all{color:var(--brand-500);padding:6px 0 2px}
}

/* Breadcrumbs */
.breadcrumbs{font-size:.9rem;color:var(--muted);padding:14px 0;border-bottom:1px solid var(--line);background:#fff}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--brand-700)}
.breadcrumbs .sep{margin:0 .5em;opacity:.5}
.breadcrumbs .current{color:var(--ink)}

/* Hero – linksbündig, im einspaltigen Content-Bereich zentriert */
.hero{padding:42px 0 16px;background:radial-gradient(1200px 500px at 80% -10%,var(--brand-50),transparent 60%),radial-gradient(900px 400px at -10% 10%,var(--navy-50),transparent 70%)}
.hero > .container{max-width:760px}
.hero h1{max-width:24ch;margin:0 0 14px}
.hero .lead{margin:0 0 18px;max-width:62ch}

.trust-row{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 8px;padding:0;list-style:none}
.trust-row li{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--brand-100);color:var(--ink);padding:6px 12px;border-radius:99px;font-size:.86rem;font-weight:600;box-shadow:0 2px 6px rgba(20,30,60,.04)}
.trust-row__icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;background:var(--brand-600);color:#fff;border-radius:50%;font-size:.62rem;font-weight:900}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;font-family:inherit;font-weight:600;font-size:1rem;border-radius:999px;border:1.5px solid transparent;cursor:pointer;text-decoration:none;transition:transform .15s var(--ease),background .2s var(--ease),box-shadow .2s var(--ease)}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:var(--brand-700);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:var(--brand-800);color:#fff;box-shadow:var(--shadow-md)}
.btn--accent{background:var(--brand-700);color:#fff;box-shadow:var(--shadow-sm)}
.btn--accent:hover{background:var(--brand-800);color:#fff}
.btn--ghost{background:transparent;color:var(--navy-800);border-color:var(--line)}
.btn--ghost:hover{background:var(--navy-50);color:var(--navy-900)}
.btn-row{display:flex;gap:12px;flex-wrap:wrap}

/* Artikel-Layout (einspaltig, zentriert) */
.article-layout{display:block;padding:8px 0 64px}
.article{max-width:760px;margin:0 auto;text-align:left}
.article p,.article ul,.article ol{max-width:none}
.article ul,.article ol{list-style-position:outside;padding-left:1.3em;display:block}
.article h2{margin-top:1.6em}
.article h3{margin-top:1.4em}
.article p,.article li{font-size:1.05rem;color:var(--ink)}
.article ul,.article ol{padding-left:1.3em}
.article a{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.article blockquote{margin:1.5em 0;padding:18px 22px;border-left:4px solid var(--brand-600);background:var(--brand-50);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--ink-soft);font-style:italic}

/* Byline – linksbündig */
.byline{display:flex;align-items:center;gap:14px;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:20px 0 28px;text-align:left}
.byline__avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--navy-800),var(--brand-600));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--font-display);font-size:1.1rem;flex-shrink:0}
.byline__meta{display:flex;flex-direction:column;line-height:1.3;flex:1}
.byline__author{font-weight:700;color:var(--navy-900)}
.byline__author a{color:var(--navy-900)}
.byline__role{font-size:.88rem;color:var(--muted)}
.byline__dates{font-size:.86rem;color:var(--muted);text-align:right}
.byline__dates strong{color:var(--ink);font-weight:600}
@media(max-width:560px){.byline{flex-wrap:wrap}.byline__dates{text-align:left;width:100%}}

/* TL;DR Box – linksbündig */
.tldr{background:var(--navy-50);border:1px solid var(--navy-100);border-radius:var(--radius);padding:20px 24px;margin:8px 0 32px}
.tldr__title{display:flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:700;color:var(--navy-900);margin:0 0 12px;font-size:1rem;letter-spacing:.02em;text-transform:uppercase}
.tldr__title::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--brand-600)}
.tldr ul{margin:0;padding-left:1.2em}
.tldr li{margin:.3em 0}

/* Sidebar */
.sidebar{position:sticky;top:96px;align-self:start;display:flex;flex-direction:column;gap:20px}
@media(max-width:960px){.sidebar{position:static}}

.toc{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px}
.toc h4{margin:0 0 10px;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.toc ol{margin:0;padding-left:1.2em;font-size:.95rem}
.toc a{color:var(--ink-soft)}
.toc a:hover{color:var(--brand-700)}

.cta-card{background:linear-gradient(160deg,var(--navy-800) 0%,var(--navy-700) 100%);color:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-md)}
.cta-card h4{color:#fff;margin:0 0 6px}
.cta-card p{color:#cdd6e6;font-size:.94rem;margin-bottom:14px}
.cta-card .btn--accent{width:100%;justify-content:center}

/* ===== Hinweis-Boxen (Tipp / Wichtig / Hinweis / Beispiel) ===== */
.box{position:relative;border-radius:var(--radius);padding:18px 22px 18px 64px;margin:1.4em 0;line-height:1.6;font-size:1rem}
.box::before{position:absolute;left:18px;top:18px;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-family:var(--font-display);font-size:1rem;line-height:1;color:#fff}
.box > *:first-child{margin-top:0}
.box > *:last-child{margin-bottom:0}
.box__title{display:block;font-family:var(--font-body);font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px}
.box p,.box ul,.box ol{margin:0 0 .6em}
.box p:last-child,.box ul:last-child,.box ol:last-child{margin-bottom:0}

/* Tipp – grün */
.box-tipp{background:var(--brand-50);border-left:4px solid var(--brand-700)}
.box-tipp::before{content:"i";background:var(--brand-700);font-style:italic;font-family:var(--font-display);font-weight:600}
.box-tipp .box__title{color:var(--brand-800)}

/* Wichtig – warn-orange */
.box-wichtig{background:#fff5e6;border-left:4px solid var(--warn)}
.box-wichtig::before{content:"!";background:var(--warn)}
.box-wichtig .box__title{color:var(--warn)}

/* Hinweis / Info – blau */
.box-hinweis,.box-info{background:var(--navy-50);border-left:4px solid var(--navy-800)}
.box-hinweis::before,.box-info::before{content:"i";background:var(--navy-800);font-style:italic;font-family:var(--font-display);font-weight:600}
.box-hinweis .box__title,.box-info .box__title{color:var(--navy-900)}

/* Beispiel – neutral grau */
.box-beispiel{background:var(--bg-soft);border-left:4px solid var(--muted)}
.box-beispiel::before{content:"§";background:var(--muted);font-family:var(--font-display)}
.box-beispiel .box__title{color:var(--ink)}

/* Alt-Klassen aus dem Drupal (p.wichtig, p.hinweis, p.tipp) – gleiche Optik */
.article p.wichtig,.article div.wichtig{background:#fff5e6;border-left:4px solid var(--warn);padding:14px 18px;border-radius:var(--radius);margin:1.4em 0}
.article p.tipp,.article div.tipp{background:var(--brand-50);border-left:4px solid var(--brand-700);padding:14px 18px;border-radius:var(--radius);margin:1.4em 0}
.article p.hinweis,.article div.hinweis{background:var(--navy-50);border-left:4px solid var(--navy-800);padding:14px 18px;border-radius:var(--radius);margin:1.4em 0}

/* Bilder im Artikel – mit Rahmen und Caption */
.article figure{margin:1.6em 0;padding:0}
.article figure img{border:1px solid var(--line);border-radius:var(--radius-sm);width:100%;height:auto}
.article figcaption{margin-top:8px;font-size:.86rem;color:var(--muted);font-style:italic;text-align:left}
.article img{border-radius:var(--radius-sm)}

/* Titelbild oben im Artikel */
.article > .hero-figure:first-child,
.article .hero-figure{margin:0 0 28px;padding:0}
.article .hero-figure img{width:100%;height:auto;border-radius:var(--radius);border:1px solid var(--line);display:block}
.article .hero-figure figcaption{margin-top:8px;font-size:.82rem;color:var(--muted);font-style:italic;text-align:right}

/* Tabellen */
.article table{width:100%;border-collapse:collapse;margin:1.6em 0;font-size:.95rem}
.article th,.article td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.article th{background:var(--bg-soft);font-weight:700;color:var(--navy-900);border-bottom:2px solid var(--navy-800)}
.article tr:hover td{background:var(--bg-soft)}

/* Quellen – linksbündig */
.sources{margin:48px 0 0;padding:24px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius)}
.sources h3{font-size:1.05rem;font-family:var(--font-body);font-weight:700;color:var(--navy-900);margin:0 0 12px;letter-spacing:.02em;text-transform:uppercase}
.sources ol{margin:0;padding-left:1.4em;font-size:.94rem;color:var(--ink-soft)}
.sources li{margin:.4em 0}
.sources a{word-break:break-word}

/* Related */
.related{margin-top:48px}
.related__title{margin:0 0 18px}
.related__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.related__grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.related__grid{grid-template-columns:1fr}}
.related-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease);color:inherit;text-decoration:none}
.related-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--navy-100);color:inherit}
.related-card__cat{display:inline-block;font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brand-700);font-weight:700;margin-bottom:8px}
.related-card h3{font-family:var(--font-body);font-size:1.05rem;font-weight:700;margin:0 0 6px;color:var(--navy-900);letter-spacing:0}
.related-card p{color:var(--ink-soft);font-size:.94rem;margin:0}

/* Footer */
.site-footer{background:var(--navy-800);color:#c8d3dc;padding:64px 0 24px;margin-top:64px}
.site-footer h4{color:#fff;font-family:var(--font-body);font-weight:700;font-size:.95rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px}
.site-footer a{color:#c8d3dc;display:block;padding:4px 0}
.site-footer a:hover{color:var(--brand-500)}
.site-footer__grid{display:grid;grid-template-columns:2.4fr 1fr 1fr;gap:40px;margin-bottom:32px}
@media(max-width:900px){.site-footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.site-footer__grid{grid-template-columns:1fr}}
.site-footer__brand{display:flex;flex-direction:column;gap:14px;max-width:38ch}
.site-footer__brand p{color:#8b9aa6;font-size:.92rem;margin:0;line-height:1.6}
.site-footer__disclaimer{border-top:1px solid rgba(255,255,255,.1);padding:22px 0 18px;font-size:.86rem;line-height:1.65;color:#8b9aa6;max-width:980px}
.site-footer__disclaimer strong{color:#c8d3dc;font-weight:600}
.site-footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.88rem;color:#8b9aa6}
.site-footer__bottom a{display:inline}

/* Kategorie-Liste */
.cat-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(max-width:760px){.cat-list{grid-template-columns:1fr}}
.cat-list li{margin:0}
.cat-list a{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 18px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--ink);font-weight:500;text-decoration:none;transition:transform .15s var(--ease),border-color .15s var(--ease),background .15s var(--ease)}
.cat-list a:hover{transform:translateY(-1px);border-color:var(--brand-600);background:var(--brand-50);color:var(--brand-700)}
.cat-list__arrow{color:var(--brand-700);font-weight:700}

/* ===== Artikel-Meta-Block (oben an dem Related, schmaler Streifen) ===== */
.article-meta{padding:32px 0 8px}
.article-meta__box{border-top:2px solid var(--navy-800);padding-top:18px;margin-top:24px}
.article-meta__head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.article-meta__avatar{flex-shrink:0;width:44px;height:44px;border-radius:50%;background:var(--brand-50);color:var(--brand-700);display:inline-flex;align-items:center;justify-content:center}
.article-meta__avatar svg{width:24px;height:24px}
.article-meta__meta{display:flex;flex-direction:column;line-height:1.4;min-width:0}
.article-meta__author{font-weight:700;color:var(--navy-900);font-size:.98rem}
.article-meta__author a{color:var(--navy-900);text-decoration:none;border-bottom:1.5px solid var(--brand-600);padding-bottom:1px}
.article-meta__author a:hover{color:var(--brand-700)}
.article-meta__role{font-size:.84rem;color:var(--muted)}
.article-meta__disclaimer{font-size:.84rem;color:var(--muted);line-height:1.55;margin:0;max-width:none}
.article-meta__disclaimer strong{color:var(--ink-soft)}
.article-meta__disclaimer a{color:var(--brand-700);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}
.article-meta__disclaimer a:hover{color:var(--brand-800)}

/* ===== Related-Block (unten am Artikel, mit Bildvorschau) ===== */
.related-section{padding:56px 0 24px;margin-top:64px;background:linear-gradient(180deg,#fff 0,var(--bg-soft) 60px)}
.related-section__title{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(1.5rem,2.4vw,2rem);color:var(--navy-900);
  margin:0 0 32px;letter-spacing:-.015em;
  font-variation-settings:"opsz" 72;line-height:1.15;
  display:flex;align-items:center;gap:14px;
}
.related-section__title::before{
  content:"";width:36px;height:2px;background:var(--brand-700);
  flex-shrink:0;
}

/* 2 Karten nebeneinander auf Desktop, 1 auf Mobil */
.related-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin:0 0 32px}
@media(max-width:780px){.related-cards{grid-template-columns:1fr;gap:18px}}

/* Karte: horizontales Layout (Bild links, Text rechts) */
.related-card-thumb{
  display:grid;
  grid-template-columns:200px minmax(0,1fr);
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  text-decoration:none !important;color:inherit;
  position:relative;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);
  box-shadow:0 1px 2px rgba(45,74,95,.04);
}
.related-card-thumb,
.related-card-thumb *{text-decoration:none !important}
.related-card-thumb:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 28px -8px rgba(45,74,95,.18),0 4px 8px rgba(45,74,95,.06);
  border-color:var(--brand-100);
  color:inherit;
}
/* Grün-Akzent links bei Hover */
.related-card-thumb::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--brand-700);
  transform:scaleY(0);transform-origin:top;
  transition:transform .3s var(--ease);
  z-index:2;
}
.related-card-thumb:hover::before{transform:scaleY(1)}

/* Bild-Bereich */
.related-card-thumb__media{
  aspect-ratio:auto;height:100%;min-height:160px;
  overflow:hidden;background:var(--navy-50);
  position:relative;
}
.related-card-thumb__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(45,74,95,.0),rgba(45,74,95,.08));
  opacity:0;transition:opacity .25s var(--ease);
}
.related-card-thumb:hover .related-card-thumb__media::after{opacity:1}
.related-card-thumb__media img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .45s var(--ease);
}
.related-card-thumb:hover .related-card-thumb__media img{transform:scale(1.05)}

/* Text-Bereich */
.related-card-thumb__body{
  padding:20px 24px 22px;
  display:flex;flex-direction:column;gap:8px;
  min-width:0;justify-content:center;
}
.related-card-thumb__cat{
  font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand-700);font-weight:700;
  display:inline-flex;align-items:center;gap:8px;
}
.related-card-thumb__cat::after{
  content:"";width:18px;height:1px;background:var(--brand-700);opacity:.5;
}
.related-card-thumb__title{
  font-family:var(--font-display);font-weight:500;
  font-size:1.1rem;line-height:1.3;
  color:var(--navy-900);margin:0;
  letter-spacing:-.01em;
  font-variation-settings:"opsz" 36;
  transition:color .2s var(--ease);
  word-wrap:break-word;
  hyphens:auto;
}
.related-card-thumb:hover .related-card-thumb__title{color:var(--brand-800)}
.related-card-thumb__desc{
  color:var(--ink-soft);font-size:.88rem;line-height:1.55;
  margin:0;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

/* Mobile: Bild oben, Text unten */
@media(max-width:560px){
  .related-card-thumb{grid-template-columns:1fr;grid-template-rows:auto auto}
  .related-card-thumb__media{aspect-ratio:16/9;height:auto;min-height:0}
  .related-card-thumb__body{padding:18px 20px 22px}
}

/* ===== Suchformular ===== */
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.search-form{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--line);border-radius:var(--radius);padding:6px 6px 6px 14px;margin:0 0 28px;position:relative;transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}
.search-form:focus-within{border-color:var(--brand-700);box-shadow:0 0 0 4px var(--brand-50)}
.search-form__icon{width:20px;height:20px;color:var(--muted);flex-shrink:0}
.search-form input[type="search"]{flex:1;border:0;background:transparent;font:inherit;font-size:1rem;color:var(--ink);padding:10px 4px;outline:none;min-width:0}
.search-form input[type="search"]::placeholder{color:var(--muted)}
.search-form .btn{padding:10px 18px;font-size:.92rem}
.search-form__clear{position:absolute;right:120px;top:50%;transform:translateY(-50%);color:var(--muted);text-decoration:none;font-size:1.4rem;line-height:1;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s var(--ease),color .15s var(--ease)}
.search-form__clear:hover{background:var(--bg-soft);color:var(--err)}
@media(max-width:640px){.search-form{flex-wrap:wrap}.search-form .btn{width:100%;justify-content:center}.search-form__clear{right:14px}}

/* ===== Mobile-Suchzeile (volle Breite unter der Menüleiste) ===== */
.mobile-search{display:none}
@media(max-width:980px){
  /* Desktop-Suche im Logo-Bereich ausblenden, Mobil-Suche zeigen */
  .header-search{display:none}
  .mobile-search{
    display:flex;align-items:center;gap:8px;width:100%;
    background:var(--bg-soft);
    border-bottom:1px solid var(--line);
    padding:10px 16px;
  }
  .mobile-search__icon{width:20px;height:20px;color:var(--muted);flex-shrink:0}
  .mobile-search input[type="search"]{
    flex:1;border:1.5px solid var(--line);background:#fff;border-radius:999px;
    font:inherit;font-size:1rem;color:var(--ink);padding:11px 16px;outline:none;min-width:0;
    transition:border-color .15s var(--ease),box-shadow .15s var(--ease);
  }
  .mobile-search input[type="search"]:focus{border-color:var(--brand-700);box-shadow:0 0 0 3px var(--brand-50)}
  .mobile-search input[type="search"]::placeholder{color:var(--muted)}
  .mobile-search button{
    background:var(--brand-700);color:#fff;border:0;border-radius:50%;
    width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;
    cursor:pointer;flex-shrink:0;transition:background .15s var(--ease);
  }
  .mobile-search button:hover{background:var(--brand-800)}
  .mobile-search button svg{width:18px;height:18px}
}

/* ===== Header-Such-Icon (in der blauen Menüleiste, rechts) ===== */
.nav-search{display:inline-flex;align-items:center;justify-content:center;width:52px;color:#fff;text-decoration:none;background:var(--navy-900);transition:background .2s var(--ease);flex-shrink:0;border-left:1px solid rgba(255,255,255,.08)}
.nav-search:hover{background:var(--brand-700);color:#fff}
.nav-search svg{width:20px;height:20px}

/* ===== News-Liste (chronologische Übersicht aller Artikel) ===== */
.news-list{list-style:none;padding:0;margin:0;border-top:1px solid var(--line)}
.news-item{margin:0;border-bottom:1px solid var(--line)}
.news-item__link{display:block;padding:20px 0;color:var(--ink);text-decoration:none;transition:background .15s var(--ease),padding .15s var(--ease)}
.news-item__link:hover{background:var(--bg-soft);padding-left:14px;padding-right:14px}
.news-item__meta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-weight:600}
.news-item__meta time{color:var(--navy-900);font-weight:700}
.news-item__cat{color:var(--brand-700)}
.news-item__cat::before{content:"·";margin-right:8px;color:var(--line);font-weight:400}
.news-item__reading::before{content:"·";margin-right:8px;color:var(--line);font-weight:400}
.news-item__title{font-family:var(--font-display);font-size:1.3rem;font-weight:500;color:var(--navy-900);margin:0 0 6px;line-height:1.25;letter-spacing:-.01em;font-variation-settings:"opsz" 36}
.news-item__link:hover .news-item__title{color:var(--brand-700)}
.news-item__desc{color:var(--ink-soft);font-size:.95rem;margin:0;line-height:1.55}

/* Pagination */
.pagination{display:flex;justify-content:space-between;align-items:center;gap:14px;margin:32px 0 0;padding:20px 0;border-top:1px solid var(--line)}
.pagination__link{color:var(--brand-700);font-weight:600;text-decoration:none;padding:8px 14px;border:1px solid var(--brand-100);border-radius:var(--radius-sm);transition:background .15s var(--ease),color .15s var(--ease)}
.pagination__link:hover{background:var(--brand-700);color:#fff}
.pagination__info{color:var(--muted);font-size:.92rem}

/* Preview-Banner */
.preview-banner{position:fixed;top:0;left:0;right:0;z-index:200;background:var(--navy-800);color:#fff;text-align:center;padding:8px 16px;font-size:.86rem;font-weight:600;letter-spacing:.04em}
.preview-banner a{color:var(--brand-500);margin-left:14px}
.preview-pad{height:36px}

/* ============ Startseite ============ */
.home-search{display:flex;align-items:center;gap:8px;max-width:640px;margin:26px 0 8px;background:#fff;border:2px solid var(--brand-600);border-radius:999px;padding:7px 7px 7px 22px;box-shadow:0 10px 28px rgba(57,94,119,.18)}
.home-search input{flex:1;border:0;outline:0;font-size:1.12rem;background:transparent;color:var(--ink);padding:14px 0}
.home-search button{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border:0;border-radius:999px;background:var(--brand-700);color:#fff;cursor:pointer;transition:background .15s var(--ease)}
.home-search button:hover{background:var(--navy-800)}
.home-search button svg{width:23px;height:23px}
.home-hint{color:var(--muted);font-size:.9rem;margin:6px 0 0}

/* Themen-Kacheln mit Icon + Farbakzent */
.topic-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:1000px){.topic-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.topic-grid{grid-template-columns:1fr}}
.topic-card{display:block;border:1px solid var(--line);border-top:3px solid var(--accent,var(--brand-700));border-radius:var(--radius);padding:22px;text-decoration:none;color:inherit;transition:transform .18s var(--ease),box-shadow .18s var(--ease),border-color .18s var(--ease);background:#f7f9fb;background:linear-gradient(165deg, color-mix(in srgb, var(--accent, #395e77) 14%, #fff) 0%, #fff 72%)}
.topic-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--accent,var(--brand-700));background:linear-gradient(165deg, color-mix(in srgb, var(--accent, #395e77) 22%, #fff) 0%, #fff 78%)}
.topic-card__icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:13px;margin-bottom:14px;color:var(--accent,var(--brand-700));background:#fff;box-shadow:0 2px 6px rgba(20,40,60,.08)}
.topic-card__icon svg{width:25px;height:25px}
.topic-card h3{margin:0 0 6px;font-size:1.06rem;font-weight:700;color:var(--navy-900);letter-spacing:0}
.topic-card p{margin:0;color:var(--ink-soft);font-size:.92rem;line-height:1.5}

.home-section{padding:46px 0}
.home-section--alt{background:var(--brand-50)}
.section-head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin:0 0 22px}
.section-head h2{margin:0}
.section-head__link{flex:0 0 auto;color:var(--brand-700);font-weight:600;text-decoration:none;white-space:nowrap}
.section-head__link:hover{text-decoration:underline}

.home-about{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px}
.home-about h2{margin-top:0}
.home-about p{color:var(--ink-soft);max-width:70ch}
.home-about .btn-row{margin-top:18px}
