/*
Theme Name: SpVgg Grün-Weiss Deggendorf 03
Theme URI: https://spvgg-gw-deggendorf.de
Author: SpVgg Grün-Weiss Deggendorf 03
Description: Offizielles Theme mit Pinselstrich-Design.
Version: 1.4.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: spvgg
*/

:root {
  --green:      #6ab42b;
  --green-dark: #5a9a22;
  --black:      #1a1a1a;
  --dark-gray:  #2d2d2d;
  --mid-gray:   #666;
  --light-gray: #f5f5f5;
  --border:     #e0e0e0;
  --white:      #ffffff;
  --font-h: 'Oswald','Arial Narrow',Arial,sans-serif;
  --font-b: 'Open Sans',Arial,sans-serif;
  --max-w:  1200px;
  --hh:     80px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);font-size:16px;line-height:1.7;color:var(--black);background:#fff}
img{max-width:100%;height:auto;display:block}
a{color:var(--green);text-decoration:none;transition:color .2s}
a:hover{color:var(--green-dark)}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-h);font-weight:700;line-height:1.15;color:var(--black);text-transform:uppercase}
p{margin-bottom:1em}
p:last-child{margin-bottom:0}

/* ── LAYOUT ─────────────────────────────────────────────────────────── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.site-content{padding:48px 0 60px}
.content-sidebar-wrap{display:grid;grid-template-columns:1fr 330px;gap:52px;align-items:start}

/* ── HEADER ─────────────────────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:#fff;box-shadow:0 2px 12px rgba(0,0,0,.08);
  height:var(--hh);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--hh)}
.site-branding{display:flex;align-items:center;gap:14px;flex-shrink:0}
.site-logo img{width:64px;height:64px;object-fit:contain}
.site-title{font-family:var(--font-h);font-size:14px;font-weight:800;color:var(--black);text-transform:uppercase;letter-spacing:.5px;line-height:1.15}
.site-title a{color:inherit}
.site-title a:hover{color:var(--green)}

/* ── NAVIGATION – Desktop mit hover-Dropdown ───────────────────────── */
.main-nav{display:flex;align-items:center}
.nav-menu{display:flex;align-items:center;list-style:none;gap:0}
.nav-menu > li{position:relative}

/* Hauptlinks */
.nav-menu > li > a{
  display:block;
  padding:10px 14px;
  font-family:var(--font-h);font-size:13px;font-weight:600;
  letter-spacing:1px;text-transform:uppercase;
  color:var(--black);
  white-space:nowrap;
  position:relative;
  transition:color .2s;
}
/* Grüner Unterstrich aktiv / hover */
.nav-menu > li > a::after{
  content:'';
  position:absolute;bottom:0;left:14px;right:14px;
  height:3px;background:var(--green);
  transform:scaleX(0);transform-origin:center;
  transition:transform .2s;
}
.nav-menu > li > a:hover::after,
.nav-menu > li.current-menu-item > a::after,
.nav-menu > li.current-menu-ancestor > a::after{transform:scaleX(1)}
.nav-menu > li > a:hover,
.nav-menu > li.current-menu-item > a,
.nav-menu > li.current-menu-ancestor > a{color:var(--green)}

/* ── DROPDOWN – zeigt bei hover ───────────────────────────────────── */
.nav-menu .sub-menu{
  position:absolute;top:100%;left:0;
  min-width:210px;
  background:#fff;
  box-shadow:0 8px 28px rgba(0,0,0,.15);
  border-top:3px solid var(--green);
  list-style:none;
  /* Versteckt – aber nicht display:none damit hover greift */
  opacity:0;
  visibility:hidden;
  transform:translateY(-6px);
  transition:opacity .2s ease, visibility .2s ease, transform .2s ease;
  z-index:9999;
  pointer-events:none;
}
/* Hover auf LI öffnet Dropdown */
.nav-menu > li:hover > .sub-menu,
.nav-menu > li:focus-within > .sub-menu{
  opacity:1;visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}
.nav-menu .sub-menu li a{
  display:block;padding:10px 18px;
  font-size:13px;color:var(--black);
  border-bottom:1px solid var(--border);
  white-space:nowrap;
  transition:background .15s,color .15s;
}
.nav-menu .sub-menu li:last-child a{border-bottom:none}
.nav-menu .sub-menu li a:hover{background:var(--light-gray);color:var(--green)}

/* CTA Button */
.nav-cta{
  margin-left:12px;
  display:inline-block!important;
  padding:11px 20px!important;
  background:var(--green);color:#fff!important;
  font-family:var(--font-h);font-size:12px!important;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;
  transition:background .2s;white-space:nowrap;
}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--green-dark)!important;color:#fff!important}

/* Mobile hamburger */
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.menu-toggle span{display:block;width:26px;height:3px;background:var(--black);border-radius:2px;transition:all .3s}

/* ── HERO BANNER ─────────────────────────────────────────────────────── */
.hero-banner{
  position:relative;
  min-height:380px;
  display:flex;align-items:center;
  overflow:hidden;
  background:#6ab42b; /* Fallback – wird per Customizer-CSS auf #fff gesetzt wenn Grafik aktiv */
}
/* Wenn Hero-Brush-Grafik gesetzt: Hintergrund wird weiss, kein gruener Tint */
.hero-banner.has-brush-image {
  background: #ffffff !important;
}

/* Hintergrundfoto */
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.3;filter:saturate(.4) brightness(.8)}

/* Grüne SVG-Brush-Fläche – überlagert das Foto */
.hero-bg-brush{position:absolute;inset:0;z-index:1}

/* Linker Pinselstrich-Rand */
.hero-brush-left{
  position:absolute;top:0;left:-5px;bottom:0;
  width:180px;z-index:2;
  background-size:100% 100%;background-repeat:no-repeat;
  background-position:left center;pointer-events:none;
}
/* Rechter Pinselstrich-Rand */
.hero-brush-right{
  position:absolute;top:0;right:-5px;bottom:0;
  width:180px;z-index:2;
  background-size:100% 100%;background-repeat:no-repeat;
  background-position:right center;pointer-events:none;
  transform:scaleX(-1);
}

/* Text über Brushes */
.hero-content{position:relative;z-index:3;padding:68px 24px;width:100%}
.hero-title{
  font-family:var(--font-h);
  font-size:clamp(60px,10vw,120px);
  font-weight:900;color:#fff;
  text-transform:uppercase;
  line-height:.88;letter-spacing:-2px;
  margin-bottom:28px;
  text-shadow:3px 4px 0 rgba(0,0,0,.2);
}

/* Weißer Brush-Untertitel-Balken */
.hero-subtitle-wrap{position:relative;display:inline-block}
.hero-subtitle-brush{
  position:absolute;inset:-8px -28px;z-index:0;
  background-size:100% 100%;background-repeat:no-repeat;background-position:center;
}
.hero-subtitle{
  position:relative;z-index:1;
  font-family:var(--font-h);font-size:clamp(13px,2vw,19px);
  font-weight:700;letter-spacing:3px;text-transform:uppercase;
  color:var(--black);padding:10px 28px;display:block;white-space:nowrap;
}

/* Small hero (Einzelbeitrag) */
.hero-banner--small{min-height:200px}
.hero-banner--small .hero-title{font-size:clamp(28px,5vw,50px);margin-bottom:12px}

/* ── WIDGET TITEL – grüner Brush-Block ─────────────────────────────── */
.widget-title{
  position:relative;display:inline-block;
  font-family:var(--font-h);font-size:13px;font-weight:800;
  letter-spacing:2px;text-transform:uppercase;
  color:#fff;
  padding:8px 22px 8px 14px;
  margin-bottom:20px;
  min-width:120px;z-index:0;
}
.widget-title::before{
  content:'';position:absolute;
  top:0;bottom:0;left:-6px;right:-14px;
  background-size:100% 100%;background-repeat:no-repeat;
  background-position:left center;z-index:-1;
}

/* ── ARCHIVE / GRID ──────────────────────────────────────────────────── */
.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:28px}
.post-card{background:#fff;border:1px solid var(--border);overflow:visible;transition:box-shadow .25s,transform .25s}
.post-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.12);transform:translateY(-3px)}

.post-card-image{height:210px;position:relative;overflow:visible}
.post-card-image > a{display:block;height:100%;overflow:hidden;position:relative}
.post-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s;display:block}
.post-card:hover .post-card-image img{transform:scale(1.05)}

/* Brush am unteren Bildrand */
.card-brush-top{
  position:absolute;bottom:-18px;left:-4%;right:-4%;height:40px;
  display:block;
  background-size:108% 100%;background-repeat:no-repeat;background-position:center;
  transform:rotate(180deg);z-index:5;pointer-events:none;
}
/* Kategorie-Badge */
.card-cat-badge{position:absolute;bottom:10px;left:10px;background:var(--green);color:#fff;font-family:var(--font-h);font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;z-index:10}

.post-card-body{padding:24px 16px 16px}
.post-card-title{font-size:15px;font-weight:700;margin-bottom:10px;text-transform:uppercase;line-height:1.3}
.post-card-title a{color:var(--black)}
.post-card-title a:hover{color:var(--green)}
.post-card-meta{font-size:12px;color:var(--mid-gray);display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.post-card-meta span{display:flex;align-items:center;gap:4px}
.post-card-meta svg{color:var(--green);flex-shrink:0}

/* ── SINGLE POST ─────────────────────────────────────────────────────── */
.post-label{display:inline-block;font-family:var(--font-h);font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--green);margin-bottom:12px}
.entry-title{font-size:clamp(24px,4vw,36px);font-weight:800;margin-bottom:16px;text-transform:uppercase}
.entry-meta{display:flex;align-items:center;gap:20px;font-size:13px;color:var(--mid-gray);margin-bottom:28px;flex-wrap:wrap}
.entry-meta span{display:flex;align-items:center;gap:5px}
.entry-meta .meta-icon{color:var(--green)}

/* Featured Image mit Brush-Rahmen oben+unten */
.entry-thumbnail{position:relative;margin:10px 0 44px}
.entry-thumbnail::before{
  content:'';position:absolute;
  top:-22px;left:-4%;right:-4%;height:50px;
  background-size:108% 100%;background-repeat:no-repeat;background-position:center top;
  z-index:2;pointer-events:none;
}
.entry-thumbnail::after{
  content:'';position:absolute;
  bottom:-22px;left:-4%;right:-4%;height:50px;
  background-size:108% 100%;background-repeat:no-repeat;background-position:center bottom;
  z-index:2;pointer-events:none;transform:rotate(180deg);
}
.entry-thumbnail img{width:100%;height:340px;object-fit:cover;display:block}

.entry-content{font-size:15.5px;line-height:1.8;color:#333}
.entry-content>p:first-child{font-weight:700;font-size:16px;color:var(--black)}
.entry-content p{margin-bottom:1.2em}
.entry-content h2,.entry-content h3{margin:1.5em 0 .6em}

/* Brush-Button "Zurück" */
.btn-back-wrap{position:relative;display:inline-block;margin-top:40px}
.btn-back-brush-bg{position:absolute;inset:-8px -20px;background-size:100% 100%;background-repeat:no-repeat;background-position:center;z-index:0;pointer-events:none}
.btn-back{position:relative;z-index:1;display:inline-block;padding:12px 28px;background:transparent;color:#fff;font-family:var(--font-h);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase}
.btn-back:hover{color:rgba(255,255,255,.8)}

/* ── SIDEBAR ─────────────────────────────────────────────────────────── */
.sidebar{position:sticky;top:100px}
.widget{margin-bottom:36px}

.widget-recent-posts .recent-post-item{display:flex;gap:12px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border);align-items:flex-start}
.widget-recent-posts .recent-post-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.recent-post-thumb{width:68px;height:68px;flex-shrink:0;overflow:hidden}
.recent-post-thumb img{width:100%;height:100%;object-fit:cover}
.recent-post-info{flex:1;min-width:0}
.recent-post-date{font-size:11px;color:var(--green);font-weight:700;text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:3px}
.recent-post-title{font-family:var(--font-h);font-size:13.5px;font-weight:700;line-height:1.3;text-transform:uppercase;color:var(--black)}
.recent-post-title a{color:inherit}
.recent-post-title a:hover{color:var(--green)}

.widget-categories ul li{padding:9px 0;border-bottom:1px solid var(--border);font-size:14px}
.widget-categories ul li:last-child{border-bottom:none}
.widget-categories ul li a{color:var(--black);font-weight:500}
.widget-categories ul li a:hover{color:var(--green)}

/* ── PARTNER-SEKTION ─────────────────────────────────────────────────── */
.partners-section{
  position:relative;
  padding:80px 20px 85px;
  text-align:center;
  overflow:visible;
  background:transparent;
}
/* SVG-Brush nimmt die volle Section ein */
.partners-bg-brush{
  position:absolute;inset:0;z-index:0;
  pointer-events:none;
}
.partners-section > *{position:relative;z-index:1}
.partners-label{font-family:var(--font-h);font-size:12px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:#fff;margin-bottom:36px;opacity:.92}
.partners-logos{display:flex;align-items:center;justify-content:center;gap:70px;flex-wrap:wrap}
.partner-logo{
  filter: none;          /* Originalfarbe behalten */
  opacity: 1;
  max-height: 90px;      /* Größer */
  max-width: 220px;
  width: auto;
  transition: transform .25s ease, box-shadow .25s ease, filter .25s ease;
  background: #fff;
  padding: 8px 14px;
  border-radius: 4px;
}
.partner-logo:hover{
  transform: scale(1.12);
  box-shadow: 0 8px 24px rgba(0,0,0,.18);
  filter: brightness(1.05);
}
.partner-logo-text{color:#fff;font-family:var(--font-h);font-size:22px;font-weight:800;text-transform:uppercase}

/* ── FOOTER ──────────────────────────────────────────────────────────── */
.site-footer{background:var(--dark-gray);color:rgba(255,255,255,.75);padding:55px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:40px;padding-bottom:50px}
.footer-col-title{font-family:var(--font-h);font-size:13px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#fff;margin-bottom:20px}
.footer-col p{font-size:13.5px;line-height:1.8;margin-bottom:20px}
.footer-nav-list li{margin-bottom:8px}
.footer-nav-list li a{font-size:13.5px;color:rgba(255,255,255,.7);transition:color .2s}
.footer-nav-list li a:hover{color:var(--green)}
.footer-contact-item{display:flex;align-items:flex-start;gap:8px;font-size:13.5px;margin-bottom:8px;color:rgba(255,255,255,.75)}
.footer-contact-item .contact-icon{color:var(--green);margin-top:2px;flex-shrink:0}
.footer-address{font-size:13.5px;line-height:1.9;margin-bottom:14px;color:rgba(255,255,255,.75)}
.social-links{display:flex;gap:10px;margin-top:4px}
.social-link{width:34px;height:34px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;transition:background .2s;border-radius:2px}
.social-link:hover{background:var(--green)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:18px 0;text-align:center;font-size:12.5px;color:rgba(255,255,255,.4)}

/* ── MISC ────────────────────────────────────────────────────────────── */
.breadcrumbs{font-size:12.5px;color:var(--mid-gray);margin-bottom:30px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.breadcrumbs a{color:var(--green)}
.btn{display:inline-block;padding:12px 28px;font-family:var(--font-h);font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;transition:background .2s,color .2s;cursor:pointer;border:none}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-dark);color:#fff}
.pagination{display:flex;gap:6px;flex-wrap:wrap;margin-top:40px;align-items:center}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:var(--light-gray);color:var(--black);font-family:var(--font-h);font-size:14px;font-weight:600;transition:all .2s}
.pagination .page-numbers.current,.pagination .page-numbers:hover{background:var(--green);color:#fff}
.search-form{display:flex}
.search-form input{flex:1;padding:10px 14px;border:2px solid var(--border);border-right:none;font-family:var(--font-b);font-size:14px;outline:none;transition:border-color .2s}
.search-form input:focus{border-color:var(--green)}
.search-form button{padding:10px 16px;background:var(--green);border:none;color:#fff;cursor:pointer;font-size:14px;transition:background .2s}
.search-form button:hover{background:var(--green-dark)}
.no-results{text-align:center;padding:60px 20px}
.no-results h1{font-size:80px;color:var(--green)}

/* ── RESPONSIVE ──────────────────────────────────────────────────────── */
@media(max-width:1024px){
  .content-sidebar-wrap{grid-template-columns:1fr}
  .sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  :root{--hh:70px}
  .menu-toggle{display:flex}
  .main-nav{
    position:fixed;top:var(--hh);left:0;right:0;
    background:#fff;flex-direction:column;align-items:stretch;
    padding:20px;box-shadow:0 10px 30px rgba(0,0,0,.15);
    transform:translateY(-110%);transition:transform .35s ease;z-index:999;
  }
  .main-nav.is-open{transform:translateY(0)}
  .nav-menu{flex-direction:column;gap:0}
  .nav-menu > li > a{padding:12px 0;border-bottom:1px solid var(--border);font-size:15px}
  .nav-menu > li > a::after{display:none}
  /* Mobile: dropdown immer sichtbar eingebettet */
  .nav-menu .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border-top:none;padding-left:16px;pointer-events:auto}
  .nav-cta{margin:16px 0 0;text-align:center}
  .hero-title{font-size:52px;letter-spacing:-1px}
  .hero-brush-left,.hero-brush-right{width:120px}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .posts-grid{grid-template-columns:1fr}
  .partners-logos{gap:40px}
  .partner-logo{max-height:70px;padding:6px 10px}
}
@media(max-width:480px){
  .hero-banner{min-height:240px}
  .hero-title{font-size:38px}
  .entry-thumbnail img{height:200px}
  .hero-subtitle{font-size:12px;padding:8px 16px;white-space:normal}
}

/* =============================================
   SLIDER
   ============================================= */
.spvgg-slider {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: #1a1a1a;
  margin-bottom: 0;
}
.slider-track { position: relative; height: 420px; }
.slide {
  position: absolute; inset: 0;
  opacity: 0; transition: opacity .6s ease;
  pointer-events: none;
}
.slide.is-active { opacity: 1; pointer-events: auto; }
.slide-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
}
.slide-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(0,0,0,.55) 0%, rgba(0,0,0,.2) 60%, transparent 100%);
}
.slide-content {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 40px 24px;
  max-width: 1200px; margin: 0 auto;
}
.slide-title {
  font-family: var(--font-h);
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 900; color: #fff;
  text-transform: uppercase;
  text-shadow: 2px 2px 8px rgba(0,0,0,.4);
  margin-bottom: 12px;
}
.slide-text {
  font-size: 16px; color: rgba(255,255,255,.9);
  max-width: 520px; margin-bottom: 20px;
  text-shadow: 1px 1px 4px rgba(0,0,0,.4);
}
.slide-btn {
  display: inline-block;
  padding: 12px 28px;
  background: var(--green); color: #fff;
  font-family: var(--font-h); font-size: 13px;
  font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase;
  transition: background .2s;
}
.slide-btn:hover { background: var(--green-dark); color: #fff; }

/* Arrows */
.slider-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(106,180,43,.85); border: none;
  color: #fff; width: 44px; height: 44px;
  font-size: 18px; cursor: pointer; z-index: 10;
  transition: background .2s;
  display: flex; align-items: center; justify-content: center;
}
.slider-arrow:hover { background: var(--green-dark); }
.slider-prev { left: 16px; }
.slider-next { right: 16px; }

/* Dots */
.slider-dots {
  position: absolute; bottom: 14px; left: 50%;
  transform: translateX(-50%);
  display: flex; gap: 8px; z-index: 10;
}
.slider-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: rgba(255,255,255,.5); border: none; cursor: pointer;
  transition: background .2s, transform .2s;
}
.slider-dot.is-active {
  background: var(--green); transform: scale(1.3);
}

/* =============================================
   NAV ARROW ICON
   ============================================= */
.nav-arrow { font-size: 10px; margin-left: 2px; pointer-events: none; }

/* =============================================
   HERO CUSTOMIZER TWEAKS
   ============================================= */
.hero-title { transition: color .3s; }
.hero-subtitle { transition: color .3s; }

/* ── MOBILE SUB-MENU ACCORDION ── */
@media (max-width: 768px) {
  .nav-menu .sub-menu {
    max-height: 0;
    overflow: hidden;
    transition: max-height .3s ease;
    /* override the desktop opacity/visibility */
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    position: static !important;
    box-shadow: none !important;
    border-top: none !important;
    background: var(--light-gray) !important;
    padding-left: 12px;
  }
  .nav-menu > li.sub-open > .sub-menu { max-height: 400px; }
  .nav-menu .sub-menu li a {
    padding: 10px 14px;
    border-bottom: 1px solid var(--border);
    font-size: 14px;
  }
}

/* ╔══════════════════════════════════════════════════════════════════╗
   ║  HEADER & NAVIGATION – komplett neu v1.5                        ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* Header */
.site-header {
  position: sticky; top: 0; z-index: 1000;
  background: #fff;
  box-shadow: 0 2px 0 rgba(106,180,43,.25), 0 3px 16px rgba(0,0,0,.08);
  height: 76px;
}
.header-inner {
  display: flex; align-items: center;
  justify-content: space-between;
  max-width: 1360px; margin: 0 auto;
  padding: 0 28px; height: 76px;
  gap: 24px;
}

/* Branding */
.site-branding { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.site-logo img,
.site-logo svg { width: 60px; height: 60px; object-fit: contain; display: block; }
.site-title-link {
  display: flex; flex-direction: column; gap: 0;
  text-decoration: none; line-height: 1;
}
.site-title-top {
  font-family: var(--font-h); font-size: 17px; font-weight: 900;
  color: var(--black); letter-spacing: .5px; text-transform: uppercase;
}
.site-title-mid {
  font-family: var(--font-h); font-size: 13px; font-weight: 700;
  color: var(--green); letter-spacing: .5px; text-transform: uppercase;
}
.site-title-bot {
  font-family: var(--font-h); font-size: 9px; font-weight: 600;
  color: var(--mid-gray); letter-spacing: 1.5px; text-transform: uppercase;
}
.site-title-link:hover .site-title-top { color: var(--green); }

/* ── DESKTOP NAV ── */
.main-nav { flex: 1; display: flex; justify-content: flex-end; }

.nav-menu {
  display: flex; align-items: stretch;
  list-style: none; gap: 0; height: 76px;
}

.nav-menu > li {
  position: relative;
  display: flex; align-items: center;
}

/* Top-level links */
.nav-menu > li > a {
  display: flex; align-items: center; gap: 4px;
  padding: 0 14px;
  height: 100%;
  font-family: var(--font-h);
  font-size: 12.5px; font-weight: 700;
  letter-spacing: 1.2px; text-transform: uppercase;
  color: var(--black);
  white-space: nowrap;
  position: relative;
  transition: color .2s;
  text-decoration: none;
}

/* Animated underline */
.nav-menu > li > a::before {
  content: '';
  position: absolute; bottom: 0; left: 14px; right: 14px;
  height: 3px; background: var(--green);
  transform: scaleX(0); transform-origin: left;
  transition: transform .25s ease;
}
.nav-menu > li > a:hover::before,
.nav-menu > li.current-menu-item > a::before,
.nav-menu > li.current-menu-ancestor > a::before { transform: scaleX(1); }
.nav-menu > li > a:hover,
.nav-menu > li.current-menu-item > a,
.nav-menu > li.current-menu-ancestor > a { color: var(--green); }

/* Dropdown arrow */
.nav-arrow {
  font-size: 8px; opacity: .6;
  transition: transform .2s, opacity .2s;
  display: inline-block;
}
.nav-menu > li:hover .nav-arrow { transform: rotate(180deg); opacity: 1; }

/* ── DROPDOWN ── */
.nav-menu > li > .sub-menu {
  position: absolute;
  top: calc(100% + 1px);
  left: 0;
  min-width: 220px;
  background: #fff;
  list-style: none;
  /* Green left border accent */
  border-left: 3px solid var(--green);
  border-bottom: 3px solid var(--green);
  box-shadow: 4px 8px 32px rgba(0,0,0,.14);
  /* Hidden state */
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity .22s ease, transform .22s ease, visibility .22s;
  z-index: 2000;
  pointer-events: none;
}

/* Open on hover */
.nav-menu > li:hover > .sub-menu,
.nav-menu > li:focus-within > .sub-menu {
  opacity: 1; visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.nav-menu .sub-menu > li > a {
  display: flex; align-items: center;
  padding: 11px 18px 11px 16px;
  font-family: var(--font-h);
  font-size: 12px; font-weight: 600;
  letter-spacing: .8px; text-transform: uppercase;
  color: var(--black);
  border-bottom: 1px solid #f0f0f0;
  transition: background .15s, color .15s, padding-left .15s;
  text-decoration: none; white-space: nowrap;
}
.nav-menu .sub-menu > li:last-child > a { border-bottom: none; }
.nav-menu .sub-menu > li > a:hover {
  background: var(--green);
  color: #fff;
  padding-left: 22px;
}

/* 2nd level nested */
.nav-menu .sub-menu .sub-menu {
  left: 100%; top: 0;
  border-left: 3px solid var(--green-dark);
}
.nav-menu .sub-menu > li:hover > .sub-menu { opacity:1; visibility:visible; transform:translateY(0); pointer-events:auto; }

/* ── CTA BUTTON ── */
.nav-menu > li > a.nav-cta {
  margin-left: 10px;
  padding: 0 20px;
  background: var(--green);
  color: #fff !important;
  height: 40px; border-radius: 2px;
  align-self: center;
  font-size: 12px; font-weight: 800;
  letter-spacing: 1.5px;
  transition: background .2s, transform .15s, box-shadow .2s;
  box-shadow: 0 3px 10px rgba(106,180,43,.4);
}
.nav-menu > li > a.nav-cta::before { display: none; }
.nav-menu > li > a.nav-cta:hover {
  background: var(--green-dark);
  transform: translateY(-1px);
  box-shadow: 0 5px 16px rgba(106,180,43,.5);
}

/* ── HAMBURGER ── */
.menu-toggle {
  display: none;
  flex-direction: column; justify-content: center; align-items: center;
  gap: 5px;
  width: 44px; height: 44px;
  background: var(--green); border: none;
  cursor: pointer; border-radius: 3px;
  flex-shrink: 0;
  transition: background .2s;
}
.menu-toggle:hover { background: var(--green-dark); }
.bar {
  display: block; width: 22px; height: 2.5px;
  background: #fff; border-radius: 2px;
  transition: transform .3s ease, opacity .3s ease, width .3s ease;
  transform-origin: center;
}
/* Open state */
.menu-toggle.is-open .bar-1 { transform: translateY(7.5px) rotate(45deg); }
.menu-toggle.is-open .bar-2 { opacity: 0; transform: scaleX(0); }
.menu-toggle.is-open .bar-3 { transform: translateY(-7.5px) rotate(-45deg); }

/* ╔══════════════════════════════════════════════════════════════════╗
   ║  MOBILE DRAWER                                                   ║
   ╚══════════════════════════════════════════════════════════════════╝ */
.mobile-drawer {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(340px, 88vw);
  background: var(--dark-gray);
  z-index: 9999;
  transform: translateX(100%);
  transition: transform .35s cubic-bezier(.4,0,.2,1);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.mobile-drawer.is-open { transform: translateX(0); }

.mobile-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 9998;
  opacity: 0; visibility: hidden;
  transition: opacity .3s, visibility .3s;
  backdrop-filter: blur(2px);
}
.mobile-overlay.is-open { opacity: 1; visibility: visible; }

/* Drawer header */
.mobile-drawer-header {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid rgba(255,255,255,.1);
  background: rgba(106,180,43,.15);
}
.mobile-drawer-logo {
  font-family: var(--font-h); font-size: 16px;
  font-weight: 800; color: var(--green);
  text-transform: uppercase; letter-spacing: 1px;
}
.mobile-drawer-close {
  background: none; border: none;
  color: rgba(255,255,255,.7); font-size: 20px;
  cursor: pointer; width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  transition: background .2s, color .2s;
}
.mobile-drawer-close:hover { background: rgba(255,255,255,.1); color: #fff; }

/* Mobile nav list */
.mobile-drawer-inner {
  flex: 1; overflow-y: auto;
  display: flex; flex-direction: column;
}
.mobile-nav-menu { list-style: none; flex: 1; padding: 8px 0; }

.mobile-nav-menu > li {
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.mobile-nav-menu > li > a,
.mobile-has-sub > a {
  display: block;
  padding: 14px 24px;
  font-family: var(--font-h);
  font-size: 14px; font-weight: 700;
  letter-spacing: 1.2px; text-transform: uppercase;
  color: rgba(255,255,255,.9);
  text-decoration: none;
  transition: color .2s, background .2s;
}
.mobile-nav-menu > li > a:hover,
.mobile-has-sub > a:hover { color: var(--green); background: rgba(255,255,255,.04); }
.mobile-nav-menu > li.current-menu-item > a { color: var(--green); }

/* Has-sub row */
.mobile-has-sub {
  display: flex; align-items: center;
}
.mobile-has-sub > a { flex: 1; }
.mobile-sub-toggle {
  background: none; border: none;
  color: rgba(255,255,255,.5);
  cursor: pointer;
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: color .2s, transform .3s;
}
.mobile-sub-toggle:hover { color: var(--green); }
.mobile-sub-toggle.is-open { transform: rotate(180deg); color: var(--green); }

/* Mobile submenu */
.mobile-sub-menu {
  list-style: none;
  background: rgba(0,0,0,.25);
  max-height: 0; overflow: hidden;
  transition: max-height .35s ease;
}
.mobile-sub-menu.is-open { max-height: 500px; }
.mobile-sub-menu li a {
  display: block;
  padding: 11px 24px 11px 36px;
  font-family: var(--font-h); font-size: 12px;
  font-weight: 600; letter-spacing: 1px; text-transform: uppercase;
  color: rgba(255,255,255,.65); text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,.04);
  transition: color .2s, padding-left .2s;
}
.mobile-sub-menu li a::before { content: '→ '; opacity: .4; }
.mobile-sub-menu li a:hover { color: var(--green); padding-left: 40px; }

/* Mobile CTA */
.mobile-drawer-cta {
  padding: 20px 24px 12px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.mobile-cta-btn {
  display: block; text-align: center;
  padding: 14px 24px;
  background: var(--green); color: #fff;
  font-family: var(--font-h); font-size: 13px;
  font-weight: 800; letter-spacing: 1.5px;
  text-transform: uppercase; text-decoration: none;
  border-radius: 2px;
  box-shadow: 0 4px 16px rgba(106,180,43,.4);
  transition: background .2s, transform .15s;
}
.mobile-cta-btn:hover { background: var(--green-dark); color: #fff; transform: translateY(-1px); }

/* Mobile contact */
.mobile-drawer-contact {
  padding: 12px 24px 24px;
}
.mobile-contact-link {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: rgba(255,255,255,.5);
  text-decoration: none; transition: color .2s;
}
.mobile-contact-link:hover { color: var(--green); }

/* ── RESPONSIVE BREAKPOINTS ── */
@media (max-width: 1100px) {
  .nav-menu > li > a { padding: 0 10px; font-size: 11.5px; }
}
@media (max-width: 900px) {
  .main-nav { display: none; }
  .menu-toggle { display: flex; }
  .header-inner { padding: 0 20px; }
}
.site-header.scrolled {
  box-shadow: 0 2px 0 rgba(106,180,43,.3), 0 4px 24px rgba(0,0,0,.13);
}

/* Untertitel ohne SVG-Brush (wenn eigene Grafik aktiv) */
.hero-subtitle--solid {
  background: rgba(255,255,255,0.92);
  padding: 10px 28px;
  display: inline-block;
  color: var(--black) !important;
}

/* ── HERO BRUSH GRAFIK (eigenes Bild via img-Tag) ── */
.hero-banner.has-brush-image {
  background: #ffffff !important;
  min-height: 0;        /* Höhe kommt vom Bild selbst */
}
/* Das Bild-Wrapper – füllt den ganzen Banner */
.hero-brush-graphic {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.hero-brush-graphic img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
/* Inhalt über dem Bild */
.hero-banner.has-brush-image .hero-content {
  position: relative;
  z-index: 2;
}
/* Untertitel-Balken ohne SVG-Brush */
.hero-subtitle--plain {
  display: inline-block;
  background: rgba(255,255,255,0.92);
  padding: 10px 28px;
  color: #1a1a1a !important;
}

/* ── PARTNER LOGOS – Originalfarbe, größer, weißer Hintergrund pro Logo ── */
.partners-logos {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
  flex-wrap: wrap;
}
/* Weißer Hintergrund damit Logos auf grünem Brush gut lesbar sind */
.partners-logos a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-radius: 6px;
  padding: 12px 20px;
  box-shadow: 0 2px 10px rgba(0,0,0,.10);
  transition: transform .25s ease, box-shadow .25s ease;
  text-decoration: none;
}
.partners-logos a:hover {
  transform: scale(1.1) translateY(-3px);
  box-shadow: 0 10px 28px rgba(0,0,0,.20);
}
/* Logo-Bild selbst: kein Filter, Originalfarbe */
.partners-logos a .partner-logo {
  filter: none !important;
  opacity: 1 !important;
  max-height: 70px;
  max-width: 180px;
  width: auto;
  background: transparent;
  padding: 0;
  border-radius: 0;
  box-shadow: none;
  transition: none;
}
.partners-logos a:hover .partner-logo {
  transform: none;
  box-shadow: none;
  filter: none !important;
}

/* =============================================
   SLIDER BRUSH RAHMEN
   ============================================= */
.slider-wrap {
  position: relative;
  /* Brush-Elemente dürfen über den Slider hinausragen */
  overflow: visible;
  /* Abstand zum nächsten Bereich */
  margin-bottom: 16px;
}

/* Brush oben – liegt ÜBER dem Slider, deckt die obere Kante ab */
.slider-brush-top {
  position: absolute;
  top: -2px;
  left: -2%;
  right: -2%;
  height: 65px;
  z-index: 10;
  pointer-events: none;
  background-size: 104% 100%;
  background-repeat: no-repeat;
  background-position: center top;
}

/* Brush unten – liegt UNTER dem Slider-Inhalt, überlappt die untere Kante */
.slider-brush-bottom {
  position: absolute;
  bottom: -2px;
  left: -2%;
  right: -2%;
  height: 65px;
  z-index: 10;
  pointer-events: none;
  background-size: 104% 100%;
  background-repeat: no-repeat;
  background-position: center bottom;
}

/* Slider selbst: overflow hidden damit Inhalt nicht überläuft,
   aber der Wrapper (slider-wrap) bleibt overflow:visible für die Brushes */
.spvgg-slider {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: #1a1a1a;
}

/* =============================================
   SIDEBAR – weisser Hintergrund & Widget-Styling
   ============================================= */

/* Jedes Widget bekommt weissen Hintergrund */
.sidebar .widget {
  background: #ffffff;
  border-radius: 3px;
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
  margin-bottom: 28px;
  overflow: hidden;
}

/* Widget-Inhalt mit Innenabstand */
.sidebar .widget > *:not(.widget-title) {
  padding: 0 16px 16px;
}

/* Widget-Titel (Brush-Block) braucht keinen extra Abstand */
.sidebar .widget .widget-title {
  margin-bottom: 0;
  display: block;
  width: 100%;
}

/* FuPa & externe Plugin-Widgets: iframe/embed sauber darstellen */
.sidebar .widget iframe,
.sidebar .widget .fupa-widget,
.sidebar .widget [class*="fupa"] {
  max-width: 100% !important;
  background: #fff !important;
}

/* Sicherstellen dass die Brush-Klassen auch bei Plugin-Widgets greifen */
.sidebar .widget.widget-brush-1 .widget-title::before,
.sidebar .widget.widget-brush-2 .widget-title::before,
.sidebar .widget.widget-brush-3 .widget-title::before,
.sidebar .widget.widget-brush-4 .widget-title::before {
  /* Brush-Bild kommt aus brush-styles.php oder Customizer */
  z-index: -1;
}

/* Recent posts & categories innerhalb des weissen Widgets */
.sidebar .widget .recent-post-item {
  padding: 0;
  border-bottom: 1px solid #f0f0f0;
}
.sidebar .widget .recent-post-item:last-child { border-bottom: none; }

.sidebar .widget .cat-list li,
.sidebar .widget-categories ul li {
  padding: 8px 0;
  border-bottom: 1px solid #f0f0f0;
  margin: 0;
}
.sidebar .widget .cat-list li:last-child,
.sidebar .widget-categories ul li:last-child { border-bottom: none; }

/* Widget-Gruppen-Abstand */
.widget-area .widget:last-child { margin-bottom: 0; }

/* ╔══════════════════════════════════════════════════════════════════╗
   ║  v2.0 NEW FEATURES CSS                                           ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* ── BREAKING NEWS BAR ── */
.breaking-news-bar {
  background: var(--black);
  display: flex; align-items: stretch;
  height: 36px; overflow: hidden;
  position: relative; z-index: 1001;
}
.breaking-badge {
  background: var(--green);
  color: #fff;
  font-family: var(--font-h); font-size: 11px; font-weight: 800;
  letter-spacing: 1.5px; text-transform: uppercase;
  padding: 0 16px;
  display: flex; align-items: center;
  white-space: nowrap; flex-shrink: 0;
}
.breaking-track-wrap { flex: 1; overflow: hidden; position: relative; }
.breaking-track {
  display: flex; align-items: center; height: 36px;
  white-space: nowrap;
  animation: breaking-scroll 30s linear infinite;
}
.breaking-item {
  font-size: 13px; color: rgba(255,255,255,.85);
  padding: 0 4px; text-decoration: none;
  transition: color .2s;
}
a.breaking-item:hover { color: var(--green); }
.breaking-dot { color: var(--green); margin: 0 12px; }
@keyframes breaking-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ── POST CARD CATEGORY COLOR BAR ── */
.post-card { position: relative; overflow: visible; }
.post-card-color-bar {
  height: 4px;
  background: var(--cat-color, var(--green));
  transition: height .2s;
}
.post-card:hover .post-card-color-bar { height: 6px; }

/* Category badge uses cat color */
.card-cat-badge { background: var(--cat-color, var(--green)); }
.post-label { background: var(--cat-color, var(--green)); color: #fff; padding: 3px 10px; border-radius: 2px; }

/* ── STATS COUNTER SECTION ── */
.stats-counter-section {
  background: var(--dark-gray);
  padding: 48px 0;
  position: relative;
  overflow: hidden;
}
.stats-counter-section::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(106,180,43,.15) 0%, transparent 60%);
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 32px;
  position: relative; z-index: 1;
}
.stat-item {
  text-align: center;
  padding: 24px 16px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 4px;
  background: rgba(255,255,255,.04);
  transition: border-color .3s, background .3s, transform .3s;
}
.stat-item:hover {
  border-color: rgba(106,180,43,.4);
  background: rgba(106,180,43,.08);
  transform: translateY(-4px);
}
.stat-number {
  font-family: var(--font-h);
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 900; color: var(--green);
  line-height: 1; margin-bottom: 8px;
  display: flex; align-items: baseline;
  justify-content: center; gap: 4px;
}
.stat-prefix { font-size: .4em; color: rgba(255,255,255,.5); align-self: center; }
.stat-suffix { font-size: .5em; color: var(--green); }
.stat-label {
  font-family: var(--font-h); font-size: 12px;
  font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: rgba(255,255,255,.6);
}

/* ── SCROLL INDICATOR ── */
.scroll-indicator {
  position: absolute; bottom: 24px; left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  animation: bounce 2s infinite;
  cursor: pointer;
}
.scroll-indicator span {
  font-family: var(--font-h); font-size: 10px;
  letter-spacing: 2px; text-transform: uppercase;
  color: rgba(255,255,255,.7);
}
.scroll-mouse {
  width: 22px; height: 36px;
  border: 2px solid rgba(255,255,255,.6);
  border-radius: 11px;
  display: flex; justify-content: center; padding-top: 6px;
}
.scroll-wheel {
  width: 4px; height: 8px;
  background: var(--green);
  border-radius: 2px;
  animation: scroll-wheel 2s infinite;
}
@keyframes scroll-wheel {
  0%, 100% { transform: translateY(0); opacity: 1; }
  80%       { transform: translateY(10px); opacity: 0; }
}
@keyframes bounce {
  0%,100% { transform: translateX(-50%) translateY(0); }
  50%     { transform: translateX(-50%) translateY(-6px); }
}

/* ── LESEZEIT ── */
.reading-time {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 12px; color: var(--mid-gray);
}
.reading-time svg { color: var(--green); flex-shrink: 0; }

/* ── SHARE BUTTONS ── */
.share-buttons {
  display: flex; align-items: center;
  gap: 10px; flex-wrap: wrap;
  margin: 32px 0;
  padding: 20px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.share-label {
  font-family: var(--font-h); font-size: 12px;
  font-weight: 700; letter-spacing: 1px;
  text-transform: uppercase; color: var(--mid-gray);
  margin-right: 4px;
}
.share-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  font-family: var(--font-h); font-size: 11px;
  font-weight: 700; letter-spacing: .8px;
  text-transform: uppercase;
  border: none; cursor: pointer;
  transition: transform .2s, box-shadow .2s;
  text-decoration: none;
  border-radius: 2px;
}
.share-btn:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.15); }
.share-wa   { background: #25D366; color: #fff; }
.share-fb   { background: #1877F2; color: #fff; }
.share-mail { background: var(--dark-gray); color: #fff; }
.share-copy { background: var(--light-gray); color: var(--black); }
.share-copy.copied { background: var(--green); color: #fff; }

/* ── POST NAVIGATION (Prev/Next) ── */
.post-navigation {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 16px; margin-top: 40px;
  padding-top: 32px; border-top: 1px solid var(--border);
}
.nav-prev a, .nav-next a {
  display: block; padding: 16px 20px;
  background: var(--light-gray);
  color: var(--black);
  font-family: var(--font-h); font-size: 13px;
  font-weight: 700; text-transform: uppercase;
  transition: background .2s, color .2s;
  border-left: 3px solid var(--green);
  line-height: 1.4;
}
.nav-next a { text-align: right; border-left: none; border-right: 3px solid var(--green); }
.nav-prev a:hover, .nav-next a:hover { background: var(--green); color: #fff; }

/* ── NEWSLETTER SECTION ── */
.newsletter-section {
  background: var(--dark-gray);
  padding: 52px 0;
  position: relative; overflow: hidden;
}
.newsletter-section::before {
  content: '';
  position: absolute; top: 0; left: 0;
  width: 6px; height: 100%;
  background: var(--green);
}
.newsletter-inner {
  display: flex; align-items: center;
  justify-content: space-between; gap: 40px;
  flex-wrap: wrap;
}
.newsletter-text { flex: 1; min-width: 240px; }
.newsletter-title {
  font-family: var(--font-h); font-size: clamp(20px,3vw,28px);
  font-weight: 800; color: #fff; text-transform: uppercase;
  margin-bottom: 8px;
}
.newsletter-text p { color: rgba(255,255,255,.7); margin: 0; font-size: 15px; }
.newsletter-form {
  display: flex; gap: 8px; flex-wrap: wrap;
  flex: 1; min-width: 280px;
}
.newsletter-form input {
  flex: 1; min-width: 140px;
  padding: 12px 16px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.2);
  color: #fff; font-family: var(--font-b); font-size: 14px;
  outline: none; transition: border-color .2s;
}
.newsletter-form input::placeholder { color: rgba(255,255,255,.4); }
.newsletter-form input:focus { border-color: var(--green); }
.newsletter-form button {
  padding: 12px 24px;
  background: var(--green); color: #fff; border: none;
  font-family: var(--font-h); font-size: 13px;
  font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  cursor: pointer; white-space: nowrap;
  transition: background .2s, transform .15s;
}
.newsletter-form button:hover { background: var(--green-dark); transform: translateY(-1px); }

/* ── SPIELER DES MONATS ── */
.potm-inner {
  padding: 16px;
  display: flex; gap: 16px; align-items: flex-start;
}
.potm-photo {
  position: relative; flex-shrink: 0;
  width: 90px; height: 90px;
  border-radius: 50%; overflow: hidden;
  border: 3px solid var(--green);
}
.potm-photo img { width: 100%; height: 100%; object-fit: cover; }
.potm-number {
  position: absolute; bottom: 2px; right: 2px;
  background: var(--green); color: #fff;
  font-family: var(--font-h); font-size: 11px; font-weight: 800;
  width: 24px; height: 24px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.potm-info { flex: 1; }
.potm-name { font-family: var(--font-h); font-size: 15px; font-weight: 800; text-transform: uppercase; color: var(--black); margin-bottom: 2px; }
.potm-pos  { font-size: 11px; color: var(--green); font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }
.potm-text { font-size: 13px; color: var(--mid-gray); line-height: 1.5; margin: 0; }

/* ── MOBILE STICKY CTA ── */
.mobile-sticky-cta {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0;
  z-index: 8000;
  background: var(--dark-gray);
  border-top: 3px solid var(--green);
  box-shadow: 0 -4px 20px rgba(0,0,0,.2);
}
.mobile-cta-item {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 4px; padding: 10px 8px;
  text-decoration: none; flex: 1;
  font-family: var(--font-h); font-size: 10px;
  font-weight: 700; letter-spacing: .8px;
  text-transform: uppercase;
  transition: background .2s;
}
.mobile-cta-phone { color: rgba(255,255,255,.8); }
.mobile-cta-wa    { color: #25D366; }
.mobile-cta-join  { background: var(--green); color: #fff; flex: 1.4; }
.mobile-cta-item:hover { background: rgba(255,255,255,.08); }
.mobile-cta-join:hover { background: var(--green-dark); }
@media (max-width: 768px) {
  .mobile-sticky-cta { display: flex; }
  /* Extra padding am Body damit Sticky-CTA nichts verdeckt */
  body { padding-bottom: 64px; }
}

/* ── COOKIE BANNER ── */
.cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--dark-gray);
  border-top: 3px solid var(--green);
  padding: 20px;
  z-index: 9000;
  transform: translateY(100%);
  transition: transform .4s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 -8px 32px rgba(0,0,0,.2);
}
.cookie-banner.is-visible { transform: translateY(0); }
@media (max-width: 768px) {
  .cookie-banner { bottom: 64px; } /* Über der mobilen CTA-Leiste */
}
.cookie-inner {
  max-width: 900px; margin: 0 auto;
  display: flex; align-items: center;
  gap: 24px; flex-wrap: wrap;
}
.cookie-text {
  flex: 1; min-width: 220px;
  font-size: 13.5px; color: rgba(255,255,255,.8); margin: 0;
}
.cookie-text a { color: var(--green); }
.cookie-text strong { color: #fff; }
.cookie-actions { display: flex; gap: 10px; flex-shrink: 0; }
.cookie-btn {
  padding: 10px 20px; border: none; cursor: pointer;
  font-family: var(--font-h); font-size: 12px;
  font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  transition: background .2s, transform .15s;
}
.cookie-accept { background: var(--green); color: #fff; }
.cookie-accept:hover { background: var(--green-dark); transform: translateY(-1px); }
.cookie-decline { background: rgba(255,255,255,.1); color: rgba(255,255,255,.7); }
.cookie-decline:hover { background: rgba(255,255,255,.15); }

/* ── BACK TO TOP ── */
.back-to-top {
  position: fixed; bottom: 28px; right: 28px;
  width: 46px; height: 46px;
  background: var(--green); color: #fff;
  border: none; cursor: pointer;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 16px rgba(106,180,43,.4);
  z-index: 7000;
  opacity: 0; visibility: hidden;
  transform: translateY(16px);
  transition: opacity .3s, visibility .3s, transform .3s, background .2s;
}
.back-to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.back-to-top:hover { background: var(--green-dark); transform: translateY(-2px); }
@media (max-width: 768px) {
  .back-to-top { bottom: 80px; right: 16px; } /* Über der CTA-Leiste */
}

/* ── LAZY FADE-IN ANIMATION ── */
.post-card, .stat-item, .slide {
  animation: none; /* wird per JS gesteuert */
}
.fade-in-up {
  opacity: 0; transform: translateY(24px);
  transition: opacity .5s ease, transform .5s ease;
}
.fade-in-up.is-visible { opacity: 1; transform: translateY(0); }
