/*
Theme Name: ARGE SBS
Description: Starter-Theme für ARGE SBS
Version: 0.2.0
Text Domain: arge-sbs
*/
:root{
  --arge-green:#37B54A;   /* Primär */
  --arge-yellow:#DEE21D;  /* Sekundär */
  --arge-grey:#CCCCCC;
  --arge-lightgrey:#F4F4F4;
  --arge-lightyellow:#FEFECC;
  --content-max:1240px;
}

/* Nunito Sans lokal eingebunden */
@font-face {
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('assets/fonts/nunito-sans/nunito-sans-v18-latin-regular.woff2') format('woff2'),
       url('assets/fonts/nunito-sans/nunito-sans-v18-latin-regular.woff') format('woff');
}
@font-face {
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('assets/fonts/nunito-sans/nunito-sans-v18-latin-600.woff2') format('woff2'),
       url('assets/fonts/nunito-sans/nunito-sans-v18-latin-600.woff') format('woff');
}
@font-face {
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('assets/fonts/nunito-sans/nunito-sans-v18-latin-800.woff2') format('woff2'),
       url('assets/fonts/nunito-sans/nunito-sans-v18-latin-800.woff') format('woff');
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px; -webkit-text-size-adjust: 100%;}
html.no-smooth {
  scroll-behavior: auto !important;
}
body{
  margin:0;
  font-family:"Nunito Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:16px;
  color:#111; line-height:1.6; background:#fff;
}

button{
  font-family:"Nunito Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:#111; line-height:1.6; background:#fff;font-size:16px;}

.container{width:100%; max-width:var(--content-max); margin:0 auto; padding:0 16px;}
a{color:var(--arge-green); text-decoration:none}
a:hover{color:var(--arge-grey)}

/* ---------- Topbar ---------- */


.desktop-only { display:block; }
.searcha { position:relative; display:flex; align-items:center; }
.search-toggle { border:0; background:none; font-size:20px; cursor:pointer; }
.search-form {
  overflow:hidden; max-width:0; opacity:0;
  transition:max-width .25s ease, opacity .2s ease;
  margin-left:8px;
}
.search-form.open { max-width:360px; opacity:1; }
.search-form input {
  width:100%; padding:8px 12px;
  border:1px solid var(--arge-grey);
  border-radius:999px;
}



/* === Header reset === */
.topbar { display:none; }

/* === Sticky Header === */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: #fff;
  transition: box-shadow .2s ease;
}
.site-header.is-scrolled {
  box-shadow: 0 3px 18px rgba(0,0,0,.08);
}

/* Header Top Row */
.header-top .bar {
  display:flex; align-items:center;
  gap:16px; padding:16px;
  min-height:84px;
}

header .container.bar{padding:16px 16px 16px 8px;}

.site-title { display:none; }

/* Logo Smooth Shrink */
.site-brand { margin-left:auto; display:flex; align-items:center; }
.site-brand img {
  height:100px; width:auto;
  transition:height .22s ease;
}
.site-header.is-scrolled .site-brand img { height:85px; }

/* Desktop Search */

/* Navigation Bar (Desktop) */
.nav-bar { background: var(--arge-lightyellow); }
.nav-bar .container { display:flex; align-items:center; }

/* =========================
   PRIMARY NAV – BEREINIGT
   ========================= */

/* Basisliste (Desktop & Mobile) */
.primary-nav > ul{
  list-style:none; margin:0; padding:0;
  display:flex; gap:24px;
}

/* Obermenüpunkte – Grundstil (Desktop-Typo etwas größer) */
@media (min-width: 960px){
  .primary-nav > ul > li > a{
    padding:12px 16px 12px 0;      /* kein Padding links, rechts Raum für ggf. Pfeil */
    color:var(--arge-green);
    text-transform:uppercase;
    font-weight:700;
    border-radius:10px;
    font-size:1.06rem;             /* Tick größer als zuvor */
    line-height:1.2;
  }
  /* Down-Arrow nur bei Oberpunkten mit Kindern */
  .primary-nav > ul > li.menu-item-has-children > a{
    position:relative; padding-right:26px;
  }
  .primary-nav > ul > li.menu-item-has-children > a:after{
    content:'\f0d7'; /* angle-down */
    font-family:'Font Awesome 6 Free','FontAwesome';
    font-weight:900;
    margin-left:10px;
    color:var(--arge-green);
    line-height:1;
  }
}

/* Dropdowns – 1. Ebene */
.primary-nav li{ position:relative; }

@media (min-width: 960px){
  .primary-nav > ul > li > ul.sub-menu{
    position:absolute; left:0; top:calc(100% + 8px);
    list-style:none; margin:0; padding:8px 0; min-width:230px;
    background:#fff; border:1px solid var(--arge-grey); border-radius:12px;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
    display:none; z-index:60;
  }
  .primary-nav > ul > li:hover > ul.sub-menu{ display:block; }
}

/* Dropdowns – 2. Ebene (rechts andockend, ohne Spalt) + Arrow-Right */
@media (min-width: 960px){
  .primary-nav > ul > li > ul.sub-menu > li{ position:relative; }

  .primary-nav > ul > li > ul.sub-menu > li.menu-item-has-children > a{
    position:relative; padding-right:26px;
  }
  .primary-nav > ul > li > ul.sub-menu > li.menu-item-has-children > a:after{
    content:'\f0da'; /* angle-right */
    font-family:'Font Awesome 6 Free','FontAwesome';
    font-weight:900;
    position:absolute; right:10px; top:50%; transform:translateY(-50%);
    color:#000; line-height:1; pointer-events:none;
  }

  .primary-nav > ul > li > ul.sub-menu > li > ul.sub-menu{
    position:absolute; top:-6px; left:calc(100%); /* -1px verhindert Mauslücke */
    margin-left:0;
    list-style:none; margin:0; padding:8px 0; min-width:230px;
    background:#fff; border:1px solid var(--arge-grey); border-radius:12px;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
    display:none; z-index:61;
  }
  .primary-nav > ul > li > ul.sub-menu > li:hover > ul.sub-menu{ display:block; }
}

/* Gemeinsame Dropdown-Item-Stile */
.primary-nav li ul li a{
  display:block; padding:10px 14px; color:#222; background:#fff; font-weight:600;
}
.primary-nav li ul li a:hover{ background:var(--arge-lightyellow); }

/* =========================
   MOBILE
   ========================= */
.nav-toggle{
  display:none; background:none; border:0; font-size:28px; color:var(--arge-green); font-weight:bold;
}

@media (max-width: 959px){
  .desktop-only{ display:none!important; }

  /* Logo-Größen mobil + sticky */
  .site-brand img{ height:80px; }
  .site-header.is-scrolled .site-brand img{ height:64px; } /* etwas größer als zuvor */

  .nav-toggle{ display:block; }

  /* Drawer für Mobile */
  .nav-bar{
    position:fixed; top:84px; left:0; right:0; bottom:0;
    background:#fff; transform:translateY(-100%); transition:transform .25s ease; z-index:99;
  }
  .nav-bar.open{ transform:translateY(0); }

  html.no-scroll body{ overflow:hidden; }

  .primary-nav > ul{ flex-direction:column; padding:16px; gap:8px; }
  .primary-nav > ul > li > a{
    border:1px solid var(--arge-grey); border-radius:10px;
    text-transform:none; padding:14px 10px; font-size:1rem; /* normalisieren mobil */
  }

  /* Dropdowns inline in Mobile */
  .primary-nav li ul{ position:static; margin:0; border:0; box-shadow:none; }
  .primary-nav li:hover > ul{ display:none; }
  .primary-nav li.open > ul{ display:block; }
}

/* =========================
   NAV-LEISTE (gelb) + WEISSER ABSCHLUSS
   ========================= */

/* Vertikales Padding in der gelben Leiste (nur Desktop) */
@media (min-width: 960px){
  .nav-bar .container{ padding-top:12px; padding-bottom:12px; }
}

/* Standard: Weißer Abschlussrand immer sichtbar, variabel groß */
@media (min-width: 960px){
  .nav-bar{
    --nav-white-gap:12px;                  /* vor Sticky: größer */
    border-bottom:var(--nav-white-gap) solid #fff;
  }
  .site-header.is-scrolled .nav-bar{
    --nav-white-gap:12px;                   /* im Sticky: kleiner */
    border-bottom-width:var(--nav-white-gap);
  }
}

/* Frontpage (front-page.php): Weißer Abschluss NUR im Sticky-Zustand */
@media (min-width: 960px){
  body.front-page .nav-bar{ border-bottom-width:0; } /* vor Sticky: kein Weiß */
  body.front-page .site-header.is-scrolled .nav-bar{
    border-bottom-width:12px;               /* im Sticky: kleiner Weiß-Abschluss */
  }
  /* Falls eure Installation 'home' nutzt, optional ergänzen:
     body.home.front-page .nav-bar{ border-bottom-width:0; }
     body.home.front-page .site-header.is-scrolled .nav-bar{ border-bottom-width:12px; }
  */
}


/* =========================
   LOGO (DESKTOP) – STICKY ETWAS GRÖSSER
   ========================= */
@media (min-width: 960px){
  .site-brand img{ height:110px; }
  .site-header.is-scrolled .site-brand img{ height:88px; } /* vorher 56px → jetzt „ein Tick“ größer */
}

/* =========================
   SUB-SUB NACH LINKS FÜR RECHTE RANDPOSITIONEN (DESKTOP)
   ========================= */
@media (min-width: 960px){
  /* Default: Sub-Sub rechts andockend */
  .primary-nav > ul > li > ul.sub-menu > li > ul.sub-menu{
    left: calc(100% - 1px);
    right: auto;
  }
  .primary-nav > ul > li > ul.sub-menu > li.menu-item-has-children > a{
    padding-right: 26px;
  }
  .primary-nav > ul > li > ul.sub-menu > li.menu-item-has-children > a:after{
    content:'\f0da'; /* angle-right */
    font-family:'Font Awesome 6 Free','FontAwesome';
    font-weight:900;
    position:absolute; right:10px; top:50%; transform:translateY(-50%);
    color:#000; line-height:1; pointer-events:none;
  }

  /* --- Heuristik: bei schmaleren Desktops (960–1199px) nur das letzte Item nach links --- */
  @media (max-width:1199px){
    .primary-nav > ul > li > ul.sub-menu > li:nth-last-child(1) > ul.sub-menu{
      left: auto; right: calc(100% - 1px);
    }
    .primary-nav > ul > li > ul.sub-menu > li:nth-last-child(1).menu-item-has-children > a{
      padding-left: 26px; padding-right: 10px; /* Platz für linken Pfeil */
    }
    .primary-nav > ul > li > ul.sub-menu > li:nth-last-child(1).menu-item-has-children > a:after{
      content:'\f0d9'; /* angle-left */
      left:10px; right:auto;
    }
  }

  /* --- Ab 1200px: die letzten ZWEI Items nach links --- */
  @media (min-width:1200px){
    .primary-nav > ul > li > ul.sub-menu > li:nth-last-child(-n+2) > ul.sub-menu{
      left: auto; right: calc(100% - 1px);
    }
    .primary-nav > ul > li > ul.sub-menu > li:nth-last-child(-n+2).menu-item-has-children > a{
      padding-left: 26px; padding-right: 10px;
    }
    .primary-nav > ul > li > ul.sub-menu > li:nth-last-child(-n+2).menu-item-has-children > a:after{
      content:'\f0d9'; /* angle-left */
      left:10px; right:auto;
    }
  }
}

/* =========================
   FRONT-PAGE / HOME: WEISSER ABSCHLUSS NUR IM STICKY
   ========================= */
@media (min-width: 960px){
  /* Standard (alle Seiten): weißer Abschluss vorhanden, sticky kleiner */
  .nav-bar{
    --nav-white-gap:12px;
    border-bottom: var(--nav-white-gap) solid #fff;
  }
  .site-header.is-scrolled .nav-bar{
    --nav-white-gap:12px;
    border-bottom-width: var(--nav-white-gap);
  }

  /* Front-Page mit body.home: vor Sticky KEIN weißer Abschluss */
  body.home .nav-bar{
    border-bottom-width: 0;
  }
  body.home .site-header.is-scrolled .nav-bar{
    border-bottom-width: 12px;
  }

  /* Falls ihr zusätzlich body.front-page habt, die gleiche Logik: */
  body.front-page .nav-bar{ border-bottom-width: 0; }
  body.front-page .site-header.is-scrolled .nav-bar{ border-bottom-width: 12px; }
}

@media (min-width: 960px){
  .primary-nav > ul > li > ul.sub-menu > li.open-left > ul.sub-menu{
    left: auto; right: calc(100% - 1px);
  }
  .primary-nav > ul > li > ul.sub-menu > li.open-left.menu-item-has-children > a{
    padding-left: 26px; padding-right: 10px;
  }
  .primary-nav > ul > li > ul.sub-menu > li.open-left.menu-item-has-children > a:after{
    content:'\f0d9'; /* angle-left */
    left:10px; right:auto;
  }
}


/* Desktop: dritte Ebene (Sub-Sub-Menü) 400px breit */
@media (min-width: 960px) {
.primary-nav .sub-menu .menu-item-225 .sub-menu, .sub-menu .menu-item-226 .sub-menu {
    width: 460px !important;
    white-space: normal;        /* Titel umbrechen */
    box-sizing: border-box;
  }
}


/* ---------- Hero 6:1 mit Wellenabschluss ---------- */
.hero{position:relative; isolation:isolate;}
.hero picture, .hero img{display:block; width:100%; height:auto;}
.hero .hero-inner{
  position:absolute; inset:0; display:flex; align-items:flex-end; justify-content:flex-start;
  padding:clamp(16px,3vw,36px);
}
.hero-title{
  color:#fff; margin:0; font-weight:800; font-size:clamp(22px,4vw,44px);
  text-shadow:0 2px 8px rgba(0,0,0,.35);
}
/* 6:1 Aspect Helper (falls noch kein Bild vorhanden) */
.hero--ratio{aspect-ratio:6/1; background:#ddd}

/* dynamische Welle unter Hero */
.wave-bottom{
  position:absolute; bottom:0px; left:0px; width:100%;  background:transparent;
}
.wave-bottom-flyin{
  position:absolute; top:0px; left:0px; width:100%;  background:transparent;
}
.wave-bottom svg,.wave-bottom-flyin svg{display:block; width:100%;  }

/* ---------- Main ---------- */
main{padding:32px 0;}
.maincontainer{position:relative;padding-bottom:0px;z-index:1;}
.maincontainer .wave-bottom{position:relative;}
@media(min-width: 960px){
.footerversatz{position:relative;margin-top:-40px;z-index:10;}
}
@media(min-width: 550px) and (max-width:960px){
.footerversatz{position:relative;margin-top:-20px;z-index:10;}
}
@media(max-width: 960px){
div.maincontainer main.container{padding-bottom:16px;}
}

/* ---------- Footer + Wellenabschluss oben ---------- */

.pref-vorueberschrift{display:flex;align-items:center;gap:15px;font-size:24px;font-weight:bold;}
.pref-vorueberschrift-flex{flex:1;}

.pref-kastenzeile{padding:14px 0px;display:flex;align-items:top;}
.pref-kastenicon{width:30px;}
.pref-tellink{text-decoration:none;color:#000000 !important;}
.pref-kastentext{flex:1;}

.pref-kastenlink{display:inline-block;margin:0px auto;}
.pref-kastenlink a{border:1px solid var(--arge-green);border-radius:16px; padding:12px;text-decoration:none;font-weight:bold;display:block;}
.pref-kastenlink a:hover{background-color: var(--arge-green);color:#FFFFFF;}

.prefooter .pref-newsletter-c{display:flex;justify-content:center;padding-top:6px !important;}
.pref-newsletter{display:flex;gap:20px;text-align:center;align-items:center;background-color:#FFFFFF;padding:28px;border-radius:16px;}
.pref-newsletter-acutal{flex:1;}
.pref-newsletter-icon{border:1px solid #000000;padding:12px 15px !important;border-radius:72px;}
.pref-newsletter-link a{border:1px solid var(--arge-green);border-radius:16px; padding:12px;text-decoration:none;font-weight:bold;display:block;}
.pref-newsletter-link a:hover{background-color: var(--arge-green);color:#FFFFFF;}
@media(min-width: 960px){
.pref-newsletter{width:92%;}
}
@media(max-width: 960px){
.pref-newsletter{display:block;}
.pref-newsletter div{display:inline-block;padding:3%;}
}


/* ---- Prefooter Cards ---- */
:root{
  /* ein Wert, der fürs Padding UND für den Grid-Gap genutzt wird */
  --prefooter-space: clamp(24px, 4vw, 56px);
}

/* Fallback-Hintergrund (#6FDC8A) + moderne Mischung als Primär */
.prefooter{
  position: relative;
  padding:4% 0px 10% 0px;
  margin-bottom:-35px;	
  background: var(--arge-lightyellow);
}
@media (max-width: 700px){
.prefooter{margin-bottom:0;}
}
@media (min-width: 700px) and (max-width: 1000px){
.prefooter{margin-bottom:-20px;}
}
.prefooter .wrap{
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--prefooter-space) 16px;
}

.prefooter-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: var(--prefooter-space); /* gleich groß wie das Padding */
}

.prefooter-card{
  background:#fff;
  border-radius:16px;
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  padding: clamp(16px, 2.2vw, 28px);
  min-height: 160px; /* optionaler Startwert */
}

/* Tablet: 2 Spalten */
@media (max-width: 1024px){
  .prefooter-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

/* Mobile: 1 Spalte */
@media (max-width: 640px){
  .prefooter-grid{ grid-template-columns: 1fr; }
}


.site-footer{
  position:relative;background:#fff; color:#333; padding:14px 0 28px 0px; margin-top:10px;z-index:11;
}

.footer-flex,.footer-blog-subline{display:flex;justify-content:space-between;gap:20px;}
.footer-blog-subline{margin-top:24px;}

.footer-mbox-1{width:200px;display:flex;justify-content:start;flex-direction:column;gap:20px;}
.footer-mbox-2{flex:1;display:flex;align-items:top;flex-direction:column;gap:20px;}

.footer-mbox-11,.footer-mbox-21{height:130px;}

.footer-mbox-12 img,.footer-mbox-21 img{height:100%;}
.footer-mbox-12 img{width:100%;height:auto;}


@media (max-width: 960px){
.footer-flex,.footer-blog-subline,.footer-mbox-1,.footer-mbox-2{display:block;}
.footer-mbox-1 div,.footer-mbox-21 img{padding-bottom:16px;}
.footer-mbox-1{width:auto;}
.footer-mbox-11,.footer-mbox-21{height:auto;}
.footer-mbox-11 a,.footer-mbox-21 a{display:block;margin:0px;}
.footer-mbox-11 img,.footer-mbox-12 img,.footer-mbox-21 img{height:auto;width:65%;}
.footer-blog-subline-1{order:2;}
.footer-blog-subline-2{order:1;}
}

main h1{color:var(--arge-green);line-height:30px;display:flex;font-size:24px;}
/* main h1:before{content:'\f110';font-family:FontAwesome;color:var(--arge-green);margin-right:14px;} */
main h1 a:hover{color:var(--arge-green);cursor:default;}
main h2{color:var(--arge-green);font-size:18px;}
main div.buttonorange{margin:24px 0px;}
main div.buttonorange a,main div.buttonorange a:hover{border:1px solid var(--arge-green);background-color:var(--arge-green);color:#FFFFFF;border-radius:16px;padding:12px;text-decoration:none;display:inline-block;}
main div.buttonpdf{margin:24px 0px;}
main div.buttonpdf a,main div.buttonpdf a:hover{border:1px solid var(--arge-green);background-color:var(--arge-green);color:#FFFFFF;border-radius:16px;padding:12px;text-decoration:none;display:inline-block;}
main.container :not(.buttonorange) :not(.buttonpdf) a[href^="http"]:before,main.container :not(.buttonorange) :not(.buttonpdf) a[href^="https"]:before {
  color: var(--arge-green);
  display:inline-block;
  content:'\f08e';
  font-family:FontAwesome;
  width:15px;
  padding-left:4px;padding-right:6px;
}
main.container :not(.buttonorange) :not(.buttonpdf) a[href^="javascript"]:before {
  color: var(--arge-green);
  display:inline-block;
  content:'\f0e0';
  font-family:FontAwesome;
  width:15px;
  padding-left:4px;padding-right:6px;
}
main.container :not(.buttonorange) :not(.buttonpdf) a[href$=".pdf"]:before {
  color: var(--arge-green);
  display:inline-block;
  content:'\f15b';
  font-family:FontAwesome;
  width:15px;
  padding-left:4px;padding-right:4px;
}
main.container :not(.buttonorange) :not(.buttonpdf) a[href$=".pdf"]:hover:before,
main.container :not(.buttonorange) :not(.buttonpdf) a[href^="https"]:hover:before,
main.container :not(.buttonorange) :not(.buttonpdf) a[href^="http"]:hover:before,
main.container :not(.buttonorange) :not(.buttonpdf) a[href^="javascript"]:hover:before{
color:var(--argegreen);
}

/* ARGE SBS – Blockquote Globalstyle innerhalb maincontainer/container */
div.maincontainer main.container blockquote,
div.maincontainer main.container .wp-block-quote {
  position: relative;
  margin: 1rem 0;
  padding: 0.5rem 1rem 0.5rem 1.25rem; /* Platz links für Linie + Quote-Zeichen */
  background: #fff; /* optional konsistent zu Cards; bei Bedarf entfernen */
}


/* Vertikale grüne Linie über die volle Zitat-Höhe */
div.maincontainer main.container blockquote::before,
div.maincontainer main.container .wp-block-quote::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;          /* -> volle Höhe */
  width: 4px;
  background: var(--arge-green, #37B54A);
}

/* Grünes Anführungszeichen am Textbeginn (erste Textzeile) */
div.maincontainer main.container blockquote p:first-child::before,
div.maincontainer main.container .wp-block-quote p:first-child::before {
  content: "“";                       /* öffnendes deutsches/typografisches Anführungszeichen */
  color: var(--arge-green, #37B54A);
  margin-right: 10px;
  line-height: 0;                     /* sauber am Textanfang platzieren */
}

div.maincontainer main.container blockquote p:first-child::before{font-family:Times, sans-serif;font-size:34px !important;font-weight:bold;}
div.maincontainer main.container blockquote, div.maincontainer main.container .wp-block-quote{
padding:0.1rem 1rem 0.1rem 1.25rem;
}
div.maincontainer main.container blockquote p:first-child {margin-block-start:10px;}
div.maincontainer main.container blockquote p:last-child {margin-block-end:0px;}

/* Optional: Zitatquelle/cite optisch abgesetzt (falls genutzt) */
div.maincontainer main.container blockquote cite,
div.maincontainer main.container .wp-block-quote cite {
  display: block;
  margin-top: .4rem;
  color: #555;
  font-style: normal;
}

/* Optional: auf sehr schmalen Displays lieber Flattersatz */
@media (max-width: 380px){
  main.container p,
  main.container li,
  main.container blockquote p {
    text-align: start;
  }
}

/* Überschriften ausnehmen & schöner umbrechen */
main.container h1, main.container h2, main.container h3 {
  text-wrap: balance;              /* moderne Browser: schönere Zeilen */
  hyphens: manual;                 /* keine automatische Trennung in Headlines */
}

main h1 a[href^="https" i]::before, main h1 a[href$=".pdf" i]::before { content: none !important; }
main .breadcrumb a[href^="https" i]::before,
main .breadcrumb .breadcrumb__link[href$=".pdf" i]::before { content: none !important; }
main .breadcrumb a[href^="https" i]::before,
main .breadcrumb .breadcrumb__link[href$=".pdf" i]::before { content: none !important; }
main ol{padding-inline-start:16px; content: counters(list-item, ".") ".\2002"; 
  font-variant-numeric: tabular-nums; }


/* ===== Farben (ARGE) ===== */
:root {
  --arge-green:  #37B54A;
  --arge-grey:   #C4C4C4;
}

/* --- ARGE SBS: Bulletpoints dezenter --- */

/* Weniger Einzug & kompaktere Zeilen */
main ul li {
  padding-left: 6px;      /* vorher 25px */
  margin: .35rem 0;        /* vorher .5rem */
}

/* Grund-Bullet deutlich kleiner & leicht transparent */
main ul li::before {
  width: 0.66rem;          /* vorher 0.9rem */
  height: 0.66rem;
  top: .72em;              /* minimal tiefer für ruhige Linie */
  opacity: .6;             /* dezenter Look */
}

/* Unterebenen noch kleiner */
main ul ul li::before {
  width: 0.58rem;          /* vorher 1.0rem */
  height: 0.58rem;
  opacity: .55;
}

/* Ring-Bullet: dünnerer Strich */
main ul {
  padding-left: 18px;
  --mask-ring: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'>\
<circle cx='12' cy='12' r='10' fill='none' stroke='%23fff' stroke-width='2'/>\
</svg>");
}

/* Unterlisten etwas dichter, aber nicht gequetscht */
main ul li > ul {
  margin-top: .2rem;       /* vorher .25rem */
}

/* Mobile noch einen Tick dezenter */
@media (max-width: 680px) {
  main ul li        { padding-left: 3px; margin: .3rem 0; }
  main ul li::before{ width: .6rem; height: .6rem; opacity: .55; }
  main ul ul li::before { width: .52rem; height: .52rem; opacity: .5; }
}

/* --- Bulletpoints generell in Schwarz --- */
main ul li::before {
  background-color: #111;   /* tiefes Schwarz passend zur Textfarbe */
  opacity: 0.85;            /* leicht abgemildert, wirkt ruhiger */
}

/* Unterebenen ebenfalls schwarz */
main ul ul li::before {
  background-color: #111;
  opacity: 0.75;            /* Unterpunkte etwas dezenter */
}

/* -------- Fallback ohne Masken-Support -------- */
@supports not ((mask-image: url("")) or (-webkit-mask-image: url(""))) {
  main > ul > li::before {
    background-color: var(--arge-green);
  }
  main ul li ul > li::before {
    background: transparent;
    border: 2px solid var(--arge-green);
  }
}

/* ===== Layout ===== */
.breadcrumb { width: 100%; font-size: .95rem; line-height: 1.4; }

.breadcrumb__list {
  list-style: none; padding: .5rem 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: .1rem .5rem;
}

/* Separator (›) zwischen Items */
.breadcrumb__item { display: inline-flex; align-items: center; gap: .5rem; }
.breadcrumb__item + .breadcrumb__item::before {
  content: "›"; color: var(--arge-grey); opacity: .9;
}

/* Links in ORANGE, aktueller Punkt neutral */
.breadcrumb__link { color:#000000;
   text-decoration: none; display: inline-flex; align-items: center; gap: .35rem;
}
.breadcrumb__link:hover, .breadcrumb__link:focus { text-decoration: none; color: var(--arge-green); }
.breadcrumb__current { color: #111; }

/* Haus-Icon in Grün */
.breadcrumb__home { fill: #000000; display: block; }
.breadcrumb__link:hover .breadcrumb__home{fill: var(--arge-green);}
.sr-only { position: absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

main .wp-block-media-text{gap:25px;}
main .wp-block-media-text>.wp-block-media-text__content{padding:0px;}
main .wp-block-media-text>.wp-block-media-text__content p:first-child{margin-block-start:0px;}
main.containersearch a:before{display: none !important;}
main.containersearch div.search-results > p:first-child{padding:14px 0px 0px 0px;}
main.containersearch .search-result__title { display: flex; align-items: baseline; gap: .5rem; color: var(--arge-green);}

main.containersearch .pagination { margin: 2rem 0; }
main.containersearch .pagination ul { display: flex; gap: .5rem; list-style: none; padding: 0; }
main.containersearch .pagination a,main.containersearch .pagination span {
  display: inline-block; padding: .5rem .75rem; border: 1px solid var(--arge-grey); text-decoration: none;
}
main.containersearch .pagination .current { background: var(--arge-lightgrey); font-weight: 700; }

/* Rechtes Top-Item nach innen einklappen (Kontakt) */
@media (min-width: 960px) and (max-width: 1249px){
  /* 1. Ebene: rechts bündig andocken */
  .primary-nav > ul > li:last-child > ul.sub-menu{
    left: auto;
    right: 0;              /* am rechten Rand der Seite ausrichten */
  }

  /* 2. Ebene: nach links aufklappen (nicht über den Viewport hinaus) */
  .primary-nav > ul > li:last-child > ul.sub-menu > li > ul.sub-menu{
    left: auto;
    right: calc(100% - 1px);   /* bündig an die 1. Ebene andocken */
    margin-left: 0;
  }

  /* Pfeil-Richtung im Sub-Sub nach links zeigen lassen */
  .primary-nav > ul > li:last-child > ul.sub-menu > li.menu-item-has-children > a{
    padding-left: 26px;
    padding-right: 10px;
    position: relative;
  }
  .primary-nav > ul > li:last-child > ul.sub-menu > li.menu-item-has-children > a:after{
    content:'\f0d9'; /* angle-left */
    font-family:'Font Awesome 6 Free','FontAwesome';
    font-weight:900;
    position:absolute; left:10px; right:auto; top:50%; transform:translateY(-50%);
    color:#000;
    pointer-events:none;
  }
}

/* Genereller Schutz: Dropdowns nicht breiter als der Viewport */
@media (min-width: 960px){
  .primary-nav > ul > li > ul.sub-menu{
    max-width: min(420px, calc(100vw - 24px));
  }
}

@media (max-width: 768px) {
  html,body,h3,h4,button { font-size: 17px; }
}

/* === ARGE-SBS: Sub-Sub (3. Ebene) Breite + Richtungslogik === */

/* Basisbreite ab 960px – "ein Tick" breiter, aber viewport-sicher */
@media (min-width: 960px){
  .primary-nav > ul > li > ul.sub-menu > li > ul.sub-menu{
    width: 560px;                                  /* etwas breiter */
    max-width: min(600px, 100vw - 40px);           /* nie aus dem Viewport */
    white-space: normal;
    overflow-wrap: break-word;
    z-index: 1000;
  }

  /* Standard: Sub-Sub rechts andockend (für ALLE außer letztes Top-Item) */
  .primary-nav > ul > li:not(:last-child) > ul.sub-menu > li > ul.sub-menu{
    left: calc(100% - 1px) !important;
    right: auto !important;
  }
  .primary-nav > ul > li:not(:last-child) > ul.sub-menu > li.menu-item-has-children > a::after{
    content:'\f0da'; /* angle-right */
    font-family:'Font Awesome 6 Free','FontAwesome';
    font-weight:900;
    position:absolute; right:10px; left:auto;
    top:50%; transform:translateY(-50%); color:#000; pointer-events:none;
  }

  /* Nur das letzte Top-Item (z. B. "Kontakt"): Sub-Sub nach links */
  .primary-nav > ul > li:last-child > ul.sub-menu > li > ul.sub-menu{
    left: auto !important;
    right: calc(100% - 1px) !important;
  }
  .primary-nav > ul > li:last-child > ul.sub-menu > li.menu-item-has-children > a::after{
    content:'\f0d9'; /* angle-left */
    font-family:'Font Awesome 6 Free','FontAwesome';
    font-weight:900;
    position:absolute; left:10px; right:auto;
    top:50%; transform:translateY(-50%); color:#000; pointer-events:none;
  }
}

/* Zwischen 960–1150 px: noch ein Tick breiter, aber weiterhin sicher */
@media (min-width: 960px) and (max-width: 1150px){
  .primary-nav > ul > li > ul.sub-menu > li > ul.sub-menu{
    width: 580px;                                  /* +20px */
    max-width: min(620px, 100vw - 24px);
  }
}

/* HARTER OVERRIDE gegen alte "breite-rechts-nach-links"-Heuristiken
   (z. B. Regeln mit :nth-last-child(-n+2) aus der früheren Version) */
@media (min-width: 960px){
  /* Für ALLE außer letztes Top-Item immer rechts öffnen – überschreibt Altregeln */
  .primary-nav > ul > li:not(:last-child) > ul.sub-menu > li:nth-last-child(-n+2) > ul.sub-menu{
    left: calc(100% - 1px) !important;
    right: auto !important;
  }
  .primary-nav > ul > li:not(:last-child) > ul.sub-menu > li:nth-last-child(-n+2).menu-item-has-children > a::after{
    content:'\f0da' !important; /* angle-right */
    left: auto !important; right:10px !important;
  }
}

/* === ARGE-SBS NAV: Sub (2. Ebene) Padding & Pfeile sauber === */
@media (min-width: 960px){
  /* Grundpadding für alle Sub-Links */
  .primary-nav > ul > li > ul.sub-menu > li > a{
    padding: 10px 14px !important;
  }

  /* Nur Sub-Items MIT Kindern → Platz für Pfeil rechts (nach RECHTS öffnend) */
  .primary-nav > ul > li:not(:last-child) > ul.sub-menu > li.menu-item-has-children > a{
    padding-right: 28px !important;   /* Platz für angle-right */
    padding-left: 14px !important;    /* kein „mysteriöses“ Extra links */
  }
  .primary-nav > ul > li:not(:last-child) > ul.sub-menu > li.menu-item-has-children > a::after{
    content:'\f0da'; /* angle-right */
    font-family:'Font Awesome 6 Free','FontAwesome';
    font-weight:900;
    position:absolute; right:10px; left:auto;
    top:50%; transform:translateY(-50%);
    color:#000; pointer-events:none;
  }

  /* Letztes Top-Item („Kontakt“) → Sub-Sub links öffnend: Pfeil links, kein linker Versatz */
  .primary-nav > ul > li:last-child > ul.sub-menu > li.menu-item-has-children > a{
    padding-left: 28px !important;    /* Platz für angle-left */
    padding-right: 14px !important;
  }
  .primary-nav > ul > li:last-child > ul.sub-menu > li.menu-item-has-children > a::after{
    content:'\f0d9'; /* angle-left */
    font-family:'Font Awesome 6 Free','FontAwesome';
    font-weight:900;
    position:absolute; left:10px; right:auto;
    top:50%; transform:translateY(-50%);
    color:#000; pointer-events:none;
  }

  /* Sub-Items OHNE Kinder: niemals Extra-Padding */
  .primary-nav > ul > li > ul.sub-menu > li:not(.menu-item-has-children) > a{
    padding: 10px 14px !important;
  }
}

/* === ARGE-SBS NAV: Sub-Sub (3. Ebene) Breite viewport-sicher === */
@media (min-width: 960px){
  .primary-nav > ul > li > ul.sub-menu > li > ul.sub-menu{
    /* statt fixer Breite → elastisch & viewport-sicher */
    width: auto !important;
    max-width: min( clamp(360px, 44vw, 520px), 100vw - 32px ) !important;
    box-sizing: border-box;
    white-space: normal;
    overflow-wrap: break-word;
    /* zur Sicherheit gegen horizontales Überlaufen */
    overflow-x: hidden;
  }

  /* Nur rechts außen (letztes Top-Item) nach links andocken */
  .primary-nav > ul > li:last-child > ul.sub-menu > li > ul.sub-menu{
    left: auto !important;
    right: calc(100% - 1px) !important;
  }

  /* Alle anderen Top-Items: Sub-Sub nach rechts andocken */
  .primary-nav > ul > li:not(:last-child) > ul.sub-menu > li > ul.sub-menu{
    left: calc(100% - 1px) !important;
    right: auto !important;
  }
}

/* Zwischen 960–1150 px: einen Tick großzügiger, aber immer sicher */
@media (min-width: 960px) and (max-width: 1150px){
  .primary-nav > ul > li > ul.sub-menu > li > ul.sub-menu{
    max-width: min( clamp(380px, 52vw, 560px), 100vw - 24px ) !important;  }
}

@media (min-width: 960px){
.primary-nav > ul li ul li#menu-item-226 ul,
.primary-nav > ul li ul li#menu-item-225 ul{width:350px !important;max-width:350px !important;}
}

/* Harter Override gegen alte Heuristiken (:nth-last-child ...) */
@media (min-width: 960px){
  .primary-nav > ul > li:not(:last-child) > ul.sub-menu > li:nth-last-child(-n+2) > ul.sub-menu{
    left: calc(100% - 1px) !important; right: auto !important;
  }
  .primary-nav > ul > li:not(:last-child) > ul.sub-menu > li:nth-last-child(-n+2).menu-item-has-children > a::after{
    content:'\f0da' !important; left:auto !important; right:10px !important;
  }
}

@media (min-width: 960px){
  /* Dropdown näher an den Oberpunkt (kein Spalt) */
  .primary-nav > ul > li > ul.sub-menu{
    top: calc(100%+4px);   /* vorher: +8px → jetzt überlappt es nach oben */
    z-index: 999;
  }

  /* Unsichtbare Hover-Brücke oberhalb des Dropdowns, damit der Hover nicht „abbricht“ */
  .primary-nav > ul > li > ul.sub-menu::before{
    content:"";
    position:absolute;
    left:0; right:0;
    top:-14px;                /* überlappt die Leiste */
    height:14px;              /* Brückenhöhe */
    background: transparent;  /* unsichtbar, aber „hoverbar“ */
    display:block;
  
}
}

main.container p,
main.container li,
main.container blockquote p {
  text-align: justify;
  text-justify: inter-word;        /* Edge/IE */
  hyphens: auto;
  -webkit-hyphens: auto;           /* Safari/iOS */
  -ms-hyphens: auto;               /* sehr alt */
  overflow-wrap: anywhere;         /* Notbremse gegen Überläufe */
}

article.sbs-termin p,.fb-endpoint p {
  display: flex;
  align-items: flex-start;
}

article.sbs-termin .tab,.fb-endpoint .tab {
  flex: 0 0 9ch;           /* feste Breite, aber flexbasiert */
}

article.sbs-termin p span + *,.fb-endpoint p span + *  {
  flex: 1;
  word-break: break-word;  /* bei langen Wörtern trennen */
}


@media (max-width: 959px){
  /* Drawer abschalten → statisch unter dem Header */
  .nav-bar{
    position: absolute;
    top: auto; left: auto; right: auto; bottom: auto;
    transform: none;
    background: #fff;
    z-index: 20;
    border-top: 0;
    width:100%;
  }
  html.no-scroll body{ overflow: auto; } /* sicherheitshalber neutralisieren */

  /* Toggle zeigt/verbirgt die Liste */
  .primary-nav{ display: none; }
  .nav-bar.open .primary-nav{ display: block; width:100%;}

  /* Layout der Liste */
  .primary-nav > ul{
    display: flex; flex-direction: column;
    gap: 8px; padding: 16px;
  }

  /* Submenüs als Akkordeon */
  .primary-nav li ul{
    position: static; display: none;
    box-shadow: none; border: 0; margin: 0; padding: 0;
  }
  .primary-nav li.open > ul{ display: block; }

  /* Touch-Ziel + Caret am Parent */
  .primary-nav > ul > li > a{
    display:flex; align-items:center; justify-content:space-between;
    border:2px solid var(--arge-green);
    border-radius:10px; padding:14px 12px; background:#fff;
    text-transform: none; font-size:1rem;
  }
  .primary-nav li.menu-item-has-children > a::after{
    content:'\f0d7'; /* angle-down */
    font-family:'Font Awesome 6 Free','FontAwesome';
    font-weight:900;
    margin-left: 10px;
  }
  .primary-nav li.open.menu-item-has-children > a::after{
    content:'\f0d8'; /* angle-up */
  }

  /* Sub-Item-Links */
  .primary-nav li ul li a{
    border: 0; border-radius:10px;
    padding:12px 12px; background:#fff;
  }
}

/* Sicherheitsnetz: Menü immer oben starten (falls Themes Padding setzen) */
@media (max-width: 959px){
.nav-bar.open{ scroll-padding-top: 0; }
}

/* iOS/Android: kein graues Tap-Highlight */
* { -webkit-tap-highlight-color: rgba(0,0,0,0); }

/* Erste Ebene: aktiv/focus/visited bleiben grün auf weiß */
@media (max-width: 959px){
  .primary-nav > ul > li > a,
  .primary-nav > ul > li > a:visited{
    color: var(--arge-green);
    background: #fff;
  }
  .primary-nav > ul > li > a:active,
  .primary-nav > ul > li > a:focus{
    color: var(--arge-green) !important;
    background: #fff !important;
  }

  /* Unterebenen ebenso neutral halten */
  .primary-nav li ul li a,
  .primary-nav li ul li a:visited{
    color:#111; background:#fff;
  }
  .primary-nav li ul li a:active,
  .primary-nav li ul li a:focus{
    color:#111 !important; background:#fff !important;
  }
}

/* =========================
   MOBILE REFINEMENTS (<959px)
   ========================= */
@media (max-width: 959px){

  /* 1) .nav-bar offen: innen kein Padding, alles 100% Breite */

  .nav-bar.open .primary-nav,
  .nav-bar.open .primary-nav > ul,
  .nav-bar.open .primary-nav > ul > li,
  .nav-bar.open .primary-nav a{
    width:100%;
  }

  /* 2) Oberpunkte: mehr Abstand, fette Schrift, grüne dickere Umrandung */
  .primary-nav > ul{
    flex-direction: column;
    gap: 14px;                 /* mehr Luft zwischen den Oberpunkten */
    padding: 16px 0;           /* oben/unten statt seitlich */
  }
  .primary-nav > ul > li{ margin: 0; } /* saubere Spalte */
  .primary-nav > ul > li > a{
    display:block;
    padding:16px 14px;
    border:2px solid var(--arge-green);
    border-radius:12px;
    font-weight:800;           /* fett */
    color:var(--arge-green);
    background:#fff;
    text-transform:none;
  }

  /* 3) Unterebenen (2./3. Ebene): OHNE Aufzählungspunkte, volle Breite */
  .primary-nav li ul,
  .primary-nav li ul li{
    list-style:none;
  }

  .primary-nav li ul{
    padding:0; margin:8px 0 0 0;   /* kein Bullet-Einzug */
  }
  .primary-nav li ul li a{
    border:0;
    border-radius:10px;
    padding:12px 12px;
    background:#fff;
    color:#111;
    width:100%;
    display:block;
  }

  /* 4) Tap-Highlight neutral & aktiv immer grün/weiß wie gewünscht */
  *{ -webkit-tap-highlight-color: rgba(0,0,0,0); }
  .primary-nav > ul > li > a:active,
  .primary-nav > ul > li > a:focus{
    color:var(--arge-green) !important;
    background:#fff !important;
  }

  .primary-nav li ul li.open > a, .primary-nav li ul li.open a:active,.primary-nav li ul li.open a:focus{background-color:var(--arge-lightyellow) !important;}

  /* 5) Offenes Menü: notfalls scrollbar, aber Seite bleibt oben startend */
  .nav-bar{
    position: absolute;        /* deine Wahl: Seite scrollt, passt */
    left:0; right:0;
    background:#fff;
    z-index:20;
  }
  .nav-bar.open{
    overflow-y: auto;          /* „runter-draggen“ möglich */
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    scroll-padding-top:0;      /* Sicherheitsnetz */
  }
}
