/* =====================================================================
   Freiheit mit Substanz — Design System
   CI: Deep Charcoal #1C1C1C · Subtle Red #B03A2E · Montserrat
   ===================================================================== */

:root{
  --bg:#1C1C1C;
  --bg-2:#222831;
  --surface:#2A2A2A;
  --surface-2:#31333a;
  --line:#3a3c43;
  --text:#FFFFFF;
  --text-2:#E6E6E6;
  --muted:#9aa0a6;
  --accent:#B03A2E;
  --accent-soft:rgba(176,58,46,.14);
  --radius:14px;
  --maxw:1120px;
  --font:'Montserrat', 'Inter', 'Helvetica Neue', Arial, sans-serif;
  --shadow:0 10px 40px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text-2);
  font-family:var(--font);
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--text);text-decoration:none}
a:hover{color:#fff}

h1,h2,h3,h4{color:var(--text);font-weight:800;line-height:1.15;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2rem,5vw,3.3rem)}
h2{font-size:clamp(1.6rem,3.4vw,2.3rem)}
h3{font-size:1.25rem}
p{margin:0 0 1.1em}
.muted{color:var(--muted)}
.accent{color:var(--accent)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:84px 0}
.section--tight{padding:54px 0}
.eyebrow{
  text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;
  font-weight:700;color:var(--accent);margin:0 0 14px
}
.lede{font-size:1.18rem;color:var(--text-2);max-width:680px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  background:var(--accent);color:#fff;font-weight:700;font-size:.95rem;
  padding:13px 22px;border-radius:10px;border:0;cursor:pointer;
  transition:transform .12s ease, filter .12s ease;
}
.btn:hover{filter:brightness(1.08);transform:translateY(-1px);color:#fff}
.btn--ghost{background:transparent;border:1px solid var(--line);color:var(--text)}
.btn--ghost:hover{border-color:var(--accent)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(28,28,28,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;flex-direction:column;line-height:1.05}
.brand b{font-size:1.05rem;color:#fff;font-weight:800;letter-spacing:-.01em}
.brand span{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.nav{display:flex;gap:26px;align-items:center}
.nav a{font-size:.92rem;color:var(--text-2);font-weight:600}
.nav a:hover{color:#fff}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-size:1.5rem;cursor:pointer}

/* ---------- Hero ---------- */
.hero{
  position:relative;padding:104px 0 92px;
  background:
    radial-gradient(900px 420px at 78% -10%, rgba(176,58,46,.16), transparent 60%),
    linear-gradient(180deg, #1C1C1C 0%, #202024 100%);
  border-bottom:1px solid var(--line);
}
.hero h1{max-width:14ch}
.hero .lede{margin-top:18px}
.hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.serie-tag{
  display:inline-block;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text);border:1px solid var(--line);border-radius:999px;
  padding:6px 14px;margin-bottom:22px
}

/* ---------- Cards / grid ---------- */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;transition:border-color .15s ease, transform .15s ease;
}
.card:hover{border-color:var(--accent);transform:translateY(-2px)}
.card h3{margin-bottom:.4em}
.card p{color:var(--text-2);font-size:.98rem;margin-bottom:0}
.pillar{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:700}

/* ---------- Video gallery ---------- */
.video-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:border-color .15s, transform .15s
}
.video-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.video-thumb{
  aspect-ratio:16/9;background:#15151a center/cover no-repeat;
  display:flex;align-items:flex-end;position:relative
}
.video-thumb .play{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:2.4rem;color:#fff;opacity:.0;transition:opacity .15s;background:rgba(0,0,0,.25)
}
.video-card:hover .play{opacity:1}
.video-num{
  position:absolute;top:12px;left:12px;background:var(--accent);color:#fff;
  font-weight:800;font-size:.74rem;padding:4px 9px;border-radius:6px;letter-spacing:.05em
}
.video-body{padding:20px 22px 24px}
.video-body .pillar{display:block;margin-bottom:8px}
.video-body h3{font-size:1.08rem;color:#fff;margin-bottom:.5em}
.video-body p{font-size:.92rem;color:var(--muted);margin-bottom:14px}

/* ---------- Tool shell ---------- */
.tool{
  background:var(--surface);border:1px solid var(--line);border-radius:18px;
  padding:30px;box-shadow:var(--shadow)
}
.tool h3{margin-top:0}
.field{margin-bottom:22px}
.field label{display:flex;justify-content:space-between;font-weight:600;color:var(--text);margin-bottom:8px;font-size:.95rem}
.field label .val{color:var(--accent);font-variant-numeric:tabular-nums}
input[type=range]{
  -webkit-appearance:none;width:100%;height:6px;border-radius:99px;
  background:linear-gradient(90deg,var(--accent) var(--p,50%),var(--line) var(--p,50%));outline:none
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:20px;height:20px;border-radius:50%;
  background:#fff;border:3px solid var(--accent);cursor:pointer;margin-top:-1px
}
input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--accent);cursor:pointer}
input[type=number],input[type=text],input[type=email]{
  width:100%;background:#191a1e;border:1px solid var(--line);border-radius:10px;
  color:#fff;padding:12px 14px;font-family:var(--font);font-size:1rem
}
input:focus{outline:none;border-color:var(--accent)}

/* ---------- Country ranking results ---------- */
.country-row{
  display:grid;grid-template-columns:36px 1fr auto;align-items:center;gap:16px;
  padding:16px 18px;background:var(--surface);border:1px solid var(--line);
  border-radius:12px;margin-bottom:10px;transition:border-color .15s
}
.country-row:hover{border-color:var(--accent)}
.country-row .rank{font-weight:800;color:var(--muted);font-size:1.1rem;text-align:center}
.country-row .flag{font-size:1.5rem}
.country-name{font-weight:700;color:#fff}
.country-sub{font-size:.82rem;color:var(--muted)}
.score-pill{font-weight:800;color:#fff;background:var(--accent-soft);border:1px solid var(--accent);
  padding:6px 12px;border-radius:999px;font-size:.92rem;font-variant-numeric:tabular-nums}
.bar{height:6px;border-radius:99px;background:var(--line);margin-top:8px;overflow:hidden}
.bar>i{display:block;height:100%;background:var(--accent)}

/* ---------- Calculator result ---------- */
.result-box{
  background:linear-gradient(180deg,#262b33,#222831);border:1px solid var(--line);
  border-radius:16px;padding:26px;text-align:center
}
.result-box .big{font-size:2.6rem;font-weight:800;color:#fff;font-variant-numeric:tabular-nums}
.result-box .label{color:var(--muted);text-transform:uppercase;letter-spacing:.15em;font-size:.72rem}

/* ---------- Bookmarks ---------- */
.bm-cat{margin-bottom:40px}
.bm-cat h3{display:flex;align-items:center;gap:10px}
.bm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:14px}
.bm{
  display:block;background:var(--surface);border:1px solid var(--line);border-radius:12px;
  padding:18px 20px;transition:border-color .15s, transform .15s
}
.bm:hover{border-color:var(--accent);transform:translateY(-2px)}
.bm b{color:#fff;font-size:1rem;display:block;margin-bottom:4px}
.bm span{color:var(--muted);font-size:.88rem}

/* ---------- Newsletter ---------- */
.cta-band{
  background:
    radial-gradient(700px 300px at 20% 0%, rgba(176,58,46,.18), transparent 60%),
    var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)
}
.newsletter-form{display:flex;gap:12px;max-width:520px;margin-top:24px;flex-wrap:wrap}
.newsletter-form input{flex:1;min-width:240px}

/* ---------- Footer ---------- */
.site-footer{padding:54px 0 40px;border-top:1px solid var(--line);background:#19191c}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:30px}
.site-footer a{color:var(--text-2);font-size:.92rem;display:block;margin-bottom:8px}
.site-footer a:hover{color:var(--accent)}
.footer-bottom{margin-top:40px;padding-top:24px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;color:var(--muted);font-size:.82rem;flex-wrap:wrap;gap:10px}

/* ---------- Page content (WP) ---------- */
.page-content{max-width:760px;margin:0 auto}
.page-content h2{margin-top:1.6em}
.page-content img{border-radius:12px;margin:1.4em 0}
.page-content blockquote{border-left:3px solid var(--accent);padding-left:18px;color:var(--text);font-style:italic;margin:1.5em 0}

/* ---------- Responsive ---------- */
@media(max-width:880px){
  .grid-3{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav{
    position:absolute;top:68px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--bg);border-bottom:1px solid var(--line);display:none;padding:8px 0
  }
  .nav.open{display:flex}
  .nav a{padding:14px 24px;width:100%}
  .nav-toggle{display:block}
  .grid-3,.grid-2,.bm-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .section{padding:60px 0}
}

/* ---------- Länderranking: Quellen-Fußnote ---------- */
.fms-sources{
  margin-top:28px;padding-top:20px;border-top:1px solid var(--line);
  font-size:.8rem;line-height:1.9;color:var(--muted)
}
.fms-sources strong{color:var(--text-2);font-size:.82rem}
.fms-sources span{white-space:nowrap}

/* ====================================================================
   v2.1 — Logo im Header + Layout-Fixes
   ==================================================================== */

/* Brand mit Logo */
.brand{flex-direction:row;align-items:center;gap:12px}
.brand-logo{
  width:48px;height:48px;border-radius:50%;display:block;flex:0 0 auto;
  object-fit:contain
}
.brand-txt{display:flex;flex-direction:column;line-height:1.05}
.brand-txt b{font-size:1rem;color:#fff;font-weight:800;letter-spacing:-.01em}
.brand-txt small{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
/* Falls eigenes WP-Logo gesetzt ist: rund + passend skalieren */
.custom-logo{width:48px;height:48px;border-radius:50%;object-fit:contain}
.custom-logo-link{display:inline-flex;align-items:center}

/* Header etwas höher, damit Logo Platz hat */
.site-header .wrap{height:76px}

/* WICHTIG: erste Sektion einer Seite braucht Abstand zum Sticky-Header.
   In der neuen Seitenstruktur gibt es keinen .hero mehr, daher: */
.page-template-default .section:first-of-type,
.home .section:first-of-type{padding-top:64px}

/* Auf der Startseite die H1 als Hero-Größe wirken lassen */
.home .page-content h1, .home .section h1{margin-bottom:.3em}

/* Block-Editor-Inhalte sollen im CI erscheinen (Seiten nutzen Gutenberg) */
.section h1,.section h2,.section h3{color:#fff}
.section p{color:var(--text-2)}
.section .wp-block-heading{color:#fff}

/* Buttons aus Gutenberg an CI anpassen */
.section .wp-block-button__link{
  background:var(--accent);color:#fff;border-radius:10px;font-weight:700;padding:13px 22px
}

/* Mehr Luft zwischen aufeinanderfolgenden Shortcode-Blöcken */
.section .grid{margin-top:8px;margin-bottom:36px}
.section .bm-cat{margin-top:24px}

/* Footer „Folgen": YouTube/Newsletter sauberer */
.site-footer .footer-grid a{margin-bottom:10px}

/* ====================================================================
   v2.4 — Hero-Shortcode + Startseiten-Sektionen
   ==================================================================== */
.hero-inner{
  padding:8px 0 28px;
  background:radial-gradient(700px 320px at 80% -40%, rgba(176,58,46,.16), transparent 60%);
  border-radius:14px;margin-bottom:8px;
}
.hero-inner .serie-tag{margin-bottom:18px}
.hero-inner h1{max-width:16ch;margin-bottom:.3em}
.hero-inner .lede{margin-top:14px}
.hero-inner .hero-cta{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}

/* H2-Sektionsüberschriften auf der Startseite mit etwas Abstand + Eyebrow-Optik */
.home .section h2,.page .wp-block-heading{scroll-margin-top:90px;margin-top:1.4em}

/* Abstand zwischen Shortcode-Sektionen */
.section .wp-block-heading + .wp-block-shortcode,
.section .wp-block-paragraph + .wp-block-shortcode{display:block;margin-top:10px}

/* ---------- Freiheitszahl: Ziel erreicht ---------- */
#calc-years-box.is-reached{
  background:linear-gradient(180deg,#1f3a2a,#1c3326);
  border-color:#2e7d52;
}
#calc-years-box.is-reached .big{color:#7ee2a8}
#calc-years-box.is-reached .label{color:#7ee2a8}


/* ====================================================================
   v2.6 — "Folge mir" + Interesse-Kontakt
   ==================================================================== */
.follow{margin-bottom:6px}
.follow-contact{max-width:560px}
.contact-form{display:flex;flex-direction:column;gap:12px;align-items:flex-start}
.contact-form input[type=email]{width:100%;max-width:420px}
.interest-row{display:flex;gap:18px;flex-wrap:wrap;color:var(--text-2);font-size:.95rem}
.interest-row label{display:flex;align-items:center;gap:8px;cursor:pointer}
.interest-row input{width:16px;height:16px;accent-color:var(--accent)}

/* ---------- Länderranking: Seiten-Pager mit Punkten ---------- */
.rank-pager{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:18px}
.pager-btn{
  width:38px;height:38px;border-radius:10px;border:1px solid var(--line);
  background:var(--surface);color:#fff;font-size:1.2rem;cursor:pointer;line-height:1;
  transition:border-color .15s, background .15s
}
.pager-btn:hover:not(:disabled){border-color:var(--accent)}
.pager-btn:disabled{opacity:.35;cursor:not-allowed}
.pager-dots{display:flex;gap:8px;align-items:center}
.pager-dot{
  width:9px;height:9px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:var(--line);transition:background .15s, transform .15s
}
.pager-dot:hover{background:#6b6f76}
.pager-dot.active{background:var(--accent);transform:scale(1.25)}
.pager-label{display:block;text-align:center;color:var(--muted);font-size:.8rem;margin-top:10px}

/* ---------- Video-Galerie Pager ---------- */
.video-pager{margin-top:22px}

/* ====================================================================
   v2.9 — Aufbrauch-Rechner (Die with Zero)
   ==================================================================== */
.calc-divider{height:1px;background:var(--line);margin:46px 0 36px}
.depletion h3{color:#fff}
.seg{display:inline-flex;background:#191a1e;border:1px solid var(--line);border-radius:10px;padding:4px;gap:4px}
.seg-btn{
  background:transparent;border:0;color:var(--text-2);font-weight:600;font-size:.9rem;
  padding:9px 16px;border-radius:7px;cursor:pointer;font-family:var(--font);transition:background .15s,color .15s
}
.seg-btn.active{background:var(--accent);color:#fff}
#dep-result-box.is-reached{background:linear-gradient(180deg,#1f3a2a,#1c3326);border-color:#2e7d52}
#dep-result-box.is-reached .big,#dep-result-box.is-reached .label{color:#7ee2a8}
#dep-result-box.is-warn{background:linear-gradient(180deg,#3a241f,#33201c);border-color:#7d3a2e}
#dep-result-box.is-warn .big,#dep-result-box.is-warn .label{color:#e8a08f}

/* ====================================================================
   v3.1 — Rechner 1: zwei Phasen sichtbar getrennt
   ==================================================================== */
.phase-tag{
  font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
  color:var(--accent);margin:0 0 14px
}
.phase-sep{height:1px;background:var(--line);margin:26px 0 22px}
.result-hint{font-size:.72rem;color:var(--muted);margin-top:8px;line-height:1.4}
.field .info{
  display:inline-block;width:16px;height:16px;line-height:16px;text-align:center;
  border-radius:50%;background:var(--line);color:#fff;font-size:.7rem;cursor:help;font-weight:700
}
.field label{align-items:center;gap:6px}

/* ====================================================================
   v3.2 — Länderranking: Perspektive, Tooltips, Gewicht + Mindestwert
   ==================================================================== */
.perspektive-box{
  background:var(--accent-soft);border:1px solid var(--accent);border-radius:12px;
  padding:16px 20px;margin-bottom:24px;font-size:.9rem;line-height:1.6;color:var(--text-2)
}
.perspektive-box strong{color:#fff}

.crit{margin-bottom:22px}
.crit-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.crit-label{font-weight:600;color:var(--text);font-size:.95rem;display:flex;align-items:center;gap:7px}
.crit-head .val{color:var(--accent);font-variant-numeric:tabular-nums;font-weight:700}
.info{
  display:inline-flex;align-items:center;justify-content:center;
  width:17px;height:17px;border-radius:50%;background:var(--line);color:#fff;
  font-size:.7rem;cursor:help;font-weight:700;user-select:none;flex:0 0 auto
}
.info:hover{background:var(--accent)}

.crit-min{margin-top:8px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.crit-min label{display:flex;align-items:center;gap:7px;font-size:.8rem;color:var(--muted);cursor:pointer}
.crit-min input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent)}
.min-wrap{display:inline-flex;align-items:center;gap:10px;flex:1;min-width:160px}
.min-slider{flex:1}
.min-val{color:var(--accent);font-size:.8rem;font-weight:700;font-variant-numeric:tabular-nums;min-width:24px;text-align:right}

.fms-tip{
  position:absolute;z-index:200;max-width:300px;background:#15151a;color:var(--text-2);
  border:1px solid var(--accent);border-radius:10px;padding:12px 14px;font-size:.82rem;
  line-height:1.5;box-shadow:0 10px 30px rgba(0,0,0,.45)
}
