/* ============================================================
   nav.css — ZENTRALES CSS für Topbar, Header/Nav, Footer
   ============================================================
   Diese Datei wird per <link rel="stylesheet" href="nav.css">
   von jeder Seite geladen. Änderungen hier wirken sofort auf
   allen Seiten — kein build-Skript nötig.

   Inhalt:
   1. Topbar (oberste Leiste mit Claims + Suchbutton)
   2. Search Overlay
   3. Header / Navigation (incl. Nav-CTA + Hamburger)
   4. Mobile Nav Panel
   5. Footer
   6. Responsive Breakpoints

   CSS-Variablen (--primary, --accent etc.) werden weiterhin
   pro Seite im <style>-Block definiert.
   ============================================================ */


/* ============ 1. TOPBAR ============ */
.topbar{
  background:var(--primary-dark);
  color:#f0ebdc;
  font-size:13px;
  padding:9px 0;
  letter-spacing:.01em;
}
.topbar-inner{
  display:flex;
  gap:28px;
  justify-content:flex-start;
  flex-wrap:wrap;
  align-items:center;
}
.topbar-item{display:flex;align-items:center;gap:8px}
.topbar-item svg{width:14px;height:14px;color:var(--accent)}
.topbar-item strong{color:#fff;font-weight:600}
.topbar-item .claim-explain{
  display:block;color:rgba(240,235,220,.75);
  font-size:11.5px;font-weight:400;
  margin-top:1px;line-height:1.35;max-width:280px;
}
.topbar-item.is-highlight{
  background:linear-gradient(90deg, rgba(201,168,106,.20), rgba(201,168,106,.05));
  padding:4px 14px;border-radius:999px;
  border:1px solid rgba(201,168,106,.40);
}
.topbar-item.is-highlight svg{color:#f0d27a}
.topbar-item.is-highlight strong{color:#fce8b6}

.topbar-search{
  margin-left:auto;
  margin-right:64px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  width:34px;height:30px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  color:#f0ebdc;cursor:pointer;flex-shrink:0;
  transition:background .15s,border-color .15s,color .15s;
}
.topbar-search:hover{background:rgba(255,255,255,.18);border-color:var(--accent);color:var(--accent)}
.topbar-search svg{width:14px;height:14px;display:block}


/* ============ 2. SEARCH OVERLAY ============ */
.search-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(20,48,39,.55);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:none;
  align-items:flex-start;justify-content:center;
  padding:80px 24px 24px;
  opacity:0;
  transition:opacity .15s;
}
.search-overlay.is-open{display:flex;opacity:1}
.search-overlay-inner{
  width:100%;max-width:720px;
  background:#fff;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  border:1px solid var(--line-soft);
  overflow:hidden;display:flex;flex-direction:column;
  max-height:calc(100vh - 120px);
}
.search-input-wrap{
  display:flex;align-items:center;gap:12px;
  padding:18px 22px;
  border-bottom:1px solid var(--line-soft);
}
.search-input-wrap .search-icon-svg{width:22px;height:22px;color:var(--ink-muted);flex-shrink:0}
.search-input-wrap input{
  flex:1;border:none;outline:none;
  font-family:inherit;font-size:17px;
  color:var(--ink);background:transparent;
  padding:6px 0;
}
.search-input-wrap input::placeholder{color:var(--ink-muted)}
.search-close{
  background:transparent;border:none;cursor:pointer;
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-muted);transition:background .15s,color .15s;
}
.search-close:hover{background:var(--bg-warm);color:var(--ink)}
.search-close svg{width:16px;height:16px}
.search-results{overflow-y:auto;flex:1;padding:8px 0}
.search-empty{padding:32px 22px;text-align:center;color:var(--ink-muted);font-size:14.5px}
.search-result{
  display:block;padding:14px 22px;
  border-bottom:1px solid var(--line-soft);
  color:var(--ink);transition:background .12s;
}
.search-result:last-child{border-bottom:none}
.search-result:hover,.search-result.is-active{background:var(--bg-warm)}
.search-result-title{
  font-size:13.5px;font-weight:600;color:var(--primary);
  text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;
}
.search-result-heading{
  font-family:var(--font-serif);font-size:18px;font-weight:400;
  color:var(--ink);margin-bottom:4px;line-height:1.3;
}
.search-result-snippet{font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.search-result mark{background:rgba(201,168,106,.35);color:inherit;padding:0 2px;border-radius:2px}


/* ============ 3. HEADER / NAVIGATION ============ */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,250,247,.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-soft);
}
header > .wrap{max-width:1240px;padding:0 32px}
.nav{
  display:flex;align-items:center;
  gap:48px;
  height:72px;
}
.nav .nav-hamburger{margin-left:auto}
.logo{
  display:flex;align-items:center;gap:12px;
  font-family:var(--font-serif);font-size:24px;
  color:var(--primary);
  letter-spacing:-.01em;
}
.logo-mark{
  width:38px;height:38px;border-radius:10px;
  background:var(--primary);
  display:grid;place-items:center;
  color:#fff;font-family:var(--font-sans);font-weight:700;font-size:15px;
  letter-spacing:.02em;
}
img.logo-mark{background:transparent;object-fit:cover;display:block}
.nav-links{display:flex;gap:32px;font-size:15px;font-weight:500}
.nav-links a{color:var(--ink-soft);transition:color .2s}
.nav-links a:hover,
.nav-links a.active{color:var(--primary)}

/* Nav-CTA Button: Scheidungsrechner als visueller CTA */
.nav-cta{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 18px;border-radius:999px;
  background:var(--primary);color:#fff;
  font-size:14px;font-weight:700;
  text-decoration:none;
  transition:background .15s ease,transform .15s ease,box-shadow .15s ease;
  box-shadow:0 2px 0 var(--primary-dark),0 4px 12px -4px rgba(31,77,62,.35);
  flex-shrink:0;
}
.nav-cta:hover{background:var(--primary-soft);transform:translateY(-1px)}
.nav-cta svg{width:14px;height:14px}

/* Hamburger */
.nav-hamburger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  width:40px;height:40px;gap:5px;
  background:none;border:1.5px solid var(--line);cursor:pointer;
  border-radius:8px;padding:6px;flex-shrink:0;
}
.nav-hamburger span{
  display:block;width:20px;height:2px;
  background:var(--ink);border-radius:2px;
  transition:transform .28s ease,opacity .2s;
}
.nav-hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}


/* ============ 4. MOBILE NAV PANEL ============ */
.mobile-nav-panel{
  display:none;
  position:fixed;top:72px;left:0;right:0;
  background:#fff;
  border-top:1px solid var(--line);
  border-bottom:3px solid var(--primary);
  box-shadow:0 8px 32px -8px rgba(26,36,32,.18);
  z-index:998;
  padding:8px 0 16px;
}
.mobile-nav-panel.is-open{display:block}
.mobile-nav-panel a{
  display:block;padding:13px 28px;
  font-size:16px;font-weight:600;color:var(--ink);
  text-decoration:none;border-bottom:1px solid var(--line-soft);
}
.mobile-nav-panel a:last-child{border-bottom:none}
.mobile-nav-panel a:hover,
.mobile-nav-panel a.active{color:var(--primary)}
.mobile-nav-panel .mob-cta{
  margin:12px 28px 0;
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:var(--primary);color:#fff;
  border-radius:var(--radius-sm);padding:14px 20px;
  font-weight:700;font-size:15px;text-decoration:none;
}
.mobile-nav-panel .mob-cta:hover{background:var(--primary-soft)}


/* ============ 5. FOOTER ============ */
footer{
  background:var(--primary-dark);
  color:#b5c5bd;
  padding:56px 0 32px;
  font-size:14px;
}
.foot-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr 1fr;
  gap:40px;
  margin-bottom:40px;
}
.foot-col h3{
  color:#fff;font-size:14px;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  margin-bottom:16px;
}
.foot-col .logo{color:#fff;margin-bottom:16px}
.foot-col .logo-mark{background:var(--accent);color:var(--primary-dark)}
.foot-col p{line-height:1.6;opacity:.85}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{color:#b5c5bd;transition:color .15s}
.foot-col a:hover{color:var(--accent)}
.foot-col .more-all{
  display:inline-block;margin-top:6px;
  font-size:13px;font-weight:600;color:var(--accent);
  border-bottom:1px solid rgba(201,168,106,.35);padding-bottom:1px;
}
.foot-col .more-all:hover{color:#fff;border-bottom-color:#fff}
.foot-bottom{
  border-top:1px solid rgba(255,255,255,.1);padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px;
  font-size:13px;opacity:.7;
}
.version-tag{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 10px;border-radius:999px;
  background:rgba(255,255,255,.08);
  font-family:'SF Mono',ui-monospace,monospace;font-size:11px;
}


/* ============ FAQ-SEKTION (sichtbar, entspricht FAQPage-Schema) ============ */
.page-faq{
  padding:48px 0 24px;
  background:var(--bg);
}
.page-faq .wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.page-faq-title{
  font-family:var(--font-serif);
  font-size:clamp(26px,3vw,34px);
  font-weight:400;
  color:var(--ink);
  line-height:1.2;
  margin-bottom:24px;
}
.page-faq-title em{color:var(--primary);font-style:italic}
.page-faq-list{
  display:flex;
  flex-direction:column;
  gap:10px;
  max-width:880px;
}
.page-faq-item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:box-shadow .15s;
}
.page-faq-item[open]{box-shadow:var(--shadow-sm)}
.page-faq-item summary{
  padding:16px 22px;
  font-weight:600;
  font-size:16px;
  color:var(--ink);
  cursor:pointer;
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}
.page-faq-item summary::-webkit-details-marker{display:none}
.page-faq-item summary::after{
  content:"+";
  font-size:22px;
  font-weight:400;
  color:var(--primary);
  transform:rotate(0);
  transition:transform .35s ease;
}
.page-faq-item[open] summary::after{transform:rotate(45deg)}
.page-faq-item summary:hover{color:var(--primary)}

/* Animierter Inhaltsbereich (slide auf/zu) */
.page-faq-content{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .35s ease;
}
.page-faq-item[open] .page-faq-content{grid-template-rows:1fr}
/* Während des animierten Schließens bleibt open=true, aber Grid-Row geht zurück auf 0fr */
.page-faq-item.is-closing .page-faq-content{grid-template-rows:0fr}
.page-faq-item.is-closing summary::after{transform:rotate(0)}
.page-faq-content > div{
  overflow:hidden;
  min-height:0;
}
.page-faq-item p{
  padding:0 22px 18px;
  color:var(--ink-soft);
  line-height:1.65;
  font-size:15.5px;
  margin:0;
}

/* ============ MOBILE-WISSENSBAR (nur auf Mobile sichtbar) ============ */
.mobile-wissensbar{display:none}
@media (max-width:900px){
  .mobile-wissensbar{
    display:block;
    padding:32px 0 8px;
    background:var(--bg);
  }
  .mobile-wissensbar .wrap{max-width:1200px;margin:0 auto;padding:0 28px}
  /* 4er-Mobile-Karten als 2×2-Grid, kompakt (Icon + Titel + Pfeil) */
  .mw-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:10px;
  }
  .mw-card{
    display:flex;
    flex-direction:column;
    gap:8px;
    background:#fff;
    border:1px solid var(--line-soft);
    border-radius:12px;
    padding:14px;
    text-decoration:none;
    color:inherit;
    min-height:96px;
  }
  .mw-card-icon{
    width:32px;height:32px;
    border-radius:8px;
    background:var(--bg-warm);
    color:var(--primary);
    display:grid;place-items:center;
  }
  .mw-card-icon svg{width:16px;height:16px}
  .mw-card-title{
    font-size:13.5px;
    font-weight:700;
    color:var(--ink);
    line-height:1.25;
  }
  .mw-eyebrow{
    display:inline-block;
    font-size:12px;
    font-weight:600;
    color:var(--primary);
    text-transform:uppercase;
    letter-spacing:.06em;
    margin-bottom:8px;
  }
  .mw-heading{
    font-family:var(--font-serif);
    font-size:22px;
    font-weight:400;
    color:var(--ink);
    margin:0 0 14px;
    line-height:1.2;
  }
}

/* ============ VIDEO-LINKS (Hero-Hinweis + Karte am Artikelende) ============ */
/* Dezenter Hero-Hinweis: ein-zeilig, mit kleinem YouTube-Glyph */
.video-hint{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-top:18px;
  margin-bottom:24px;
  padding:8px 14px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:999px;
  font-size:13.5px;
  color:var(--ink-soft);
  text-decoration:none;
  transition:border-color .15s ease,color .15s ease,box-shadow .15s ease;
}
.video-hint:hover{
  border-color:var(--primary);
  color:var(--ink);
  box-shadow:0 4px 12px -6px rgba(20,48,39,.18);
}
.video-hint-icon{
  display:inline-grid;
  place-items:center;
  width:22px;height:16px;
  border-radius:4px;
  background:#FF0000;
  color:#fff;
  flex-shrink:0;
}
.video-hint-icon svg{width:11px;height:11px}
.video-hint strong{color:var(--ink);font-weight:600}
.video-hint .video-hint-note{opacity:.7;font-size:12.5px}

/* Größere Karte am Artikelende */
.video-card-block{
  max-width:880px;
  margin:32px 0 0;
  display:flex;
  align-items:center;
  gap:20px;
  padding:22px 24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  text-decoration:none;
  color:inherit;
  transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;
}
.video-card-block:hover{
  transform:translateY(-2px);
  border-color:var(--primary);
  box-shadow:0 12px 28px -12px rgba(20,48,39,.22);
}
.video-card-icon{
  flex-shrink:0;
  width:54px;height:38px;
  border-radius:8px;
  background:#FF0000;
  color:#fff;
  display:grid;place-items:center;
}
.video-card-icon svg{width:24px;height:24px}
.video-card-body{flex:1;min-width:0}
.video-card-eyebrow{
  display:inline-block;
  font-size:12px;
  font-weight:600;
  color:var(--primary);
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:4px;
}
.video-card-title{
  font-family:var(--font-serif);
  font-size:22px;
  font-weight:400;
  color:var(--ink);
  line-height:1.25;
  margin:0 0 4px;
}
.video-card-title em{color:var(--primary);font-style:italic}
.video-card-note{
  font-size:13.5px;
  color:var(--ink-muted);
}
.video-card-arrow{
  flex-shrink:0;
  width:32px;height:32px;
  border-radius:50%;
  background:var(--bg-warm);
  color:var(--primary);
  display:grid;place-items:center;
  transition:background .15s,color .15s;
}
.video-card-block:hover .video-card-arrow{background:var(--primary);color:#fff}
.video-card-arrow svg{width:15px;height:15px}
@media (max-width:600px){
  .video-card-block{flex-direction:row;padding:16px 18px;gap:14px}
  .video-card-title{font-size:18px}
}

/* ============ AUTOR-BLOCK (E-E-A-T) ============ */
.page-author{
  max-width:880px;
  margin:0 auto;
  padding:18px 28px;
  border-top:1px solid var(--line-soft);
  font-size:14px;
  color:var(--ink-muted);
}
.page-author strong{color:var(--ink);font-weight:400}
.page-author .author-date{opacity:.85}


/* ============ 6. RESPONSIVE ============ */
@media (max-width:900px){
  .nav-links{display:none !important}
  .nav-hamburger{display:flex !important}
  .nav-cta{display:none !important}
  .topbar-inner{gap:14px;font-size:12px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:600px){
  .topbar-search{margin-right:0}
  .topbar-inner{gap:14px;font-size:12px}
  .foot-grid{grid-template-columns:1fr}
  .search-overlay{padding:60px 12px 12px}
  .search-overlay-inner{max-height:calc(100vh - 80px)}
  .search-input-wrap{padding:14px 18px}
  .search-input-wrap input{font-size:16px}
  .search-result{padding:12px 18px}
}
