/* Schriftsettings weil es sonst nicht funktioniert */

/* Google Font laden – NUR falls du ihn nicht schon im <head> geladen hast */
@import url('https://fonts.googleapis.com/css2?family=Poppins&display=swap');

nav#sp-main-menu a {
  font-family: Arial, sans-serif !important;
}

/* Alle Texte auf der Seite in Arial  */
body { font-family: Arial, "Helvetica Neue", Helvetica, sans-serif !important; }

.sppb-animated-number,
.sppb-addon-content,
.sppb-btn-primary,
.sp-slider,
.sp-slider [id^="sp-slider-inner-item"],
.sppb-addon-header .sppb-addon-title,
.sppb-addon-text,
.sppb-readmore,
.sppb-pricing-price {
    font-family: Arial, "Helvetica Neue", Helvetica, sans-serif !important;
}

nav a {
    font-family: Arial, "Helvetica Neue", Helvetica, sans-serif !important;
}



/* Überschreibt gezielt die Schriftart in der Hauptnavigation */
.sp-megamenu-parent > li > a {
  font-family: Arial, sans-serif !important;
  font-weight: 500 !important;
}


/* "Förderung" bei Seitenaufruf initial rot */

.nestfund-service-tab.sppb-addon-tab .sppb-nav-tabs li a:hover,
.nestfund-service-tab.sppb-addon-tab .sppb-nav-tabs li.active a,
.nestfund-service-tab.sppb-addon-tab .sppb-nav-tabs li a:focus {
    color: #ff0000 !important;
}


/* Größenanpassung der Feature Boxen */

.home-tilebox p:empty,
.home-tilebox br {
    display: none !important;
}

.home-tilebox {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.home-tiles {
    flex: 1 1 auto;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

/* Footer-Menü Abstand */
#sp-footer ul.menu {
  padding: 50px 0px;
}



/* Bilder in der Kundenrezessionen*/

.sppb-addon-content .sppb-img-container img[src*="nummern_klein_"] {
  max-width: 55px !important;
  max-height: 56px !important;
  width: 55px !important;
  height: 55px !important;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}

/* Menu-Stil */


.sp-dropdown.sp-dropdown-main.sp-menu-right[style] {
    width: 540px !important;
}


.sp-menu-item > a {
    white-space: nowrap !important;
    max-width: 100%;
}




.sp-megamenu-parent .sp-menu > li.current-item.active > a {
    position: relative;
}

.sp-megamenu-parent .sp-menu > li.current-item.active > a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -5px;
    width: 100%;
    height: 2px;
    background-color: red;
}

/* Roter Strich - Untermenü - senkrecht */


.sp-megamenu-parent .sp-dropdown li.sp-menu-item > a::before {
  content: "";
  display: inline-block;
  height: 16px;
  width: 2px;
  background-color: red;
  margin-right: 10px; /* Abstand zum Text */
  transform: translateX(-5px); /* Positionierung nach links */
  vertical-align: middle;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.sp-megamenu-parent .sp-dropdown li.sp-menu-item > a:hover::before {
  opacity: 1;
}


/* Sandwich-Menu und Kontaktbutton - rechte Seite */

@media (max-width: 768px) {
  /* Kontaktbutton links oben */
  #btn-fded724c-db91-493a-be3c-1958888219da {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 9999;
    padding: 6px 16px;
    font-size: 15px;
  }

  /* Offcanvas/Hamburger-Button rechts oben */
  #offcanvas-toggler {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 9999;
  }

  /* Optional: damit Container keinen Overflow produziert */
  .sppb-row {
    position: relative;
  }
}



/* Vereinheitlichung Buttons auf den Weiterbildungsseiten */

.btn-weiterbildung {
  width: 215px;
  height: 36px;
}



/* roter strick - hoizontaler Strich im Main-Menu 

.sp-megamenu-parent .sp-menu > li.active > a::after {
    background-color: red !important;
}

.sp-megamenu-parent .sp-menu > li.current-item.active > a {
    position: relative;
}

.sp-megamenu-parent .sp-menu > li.current-item.active > a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -5px;
    width: 100%;
    height: 2px;
    background-color: red;
}


*/

/* Spalten auf "about us" Seite */
.equal-boxes {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  align-items: stretch;
}

/* Beide inneren Spalten gleich breit & Inhalt vertikal mittig */
.equal-boxes > div {
  flex: 1 1 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  box-sizing: border-box;
  padding: 20px;
}

/* Responsive: Untereinander auf Tablet & Mobile */
@media (max-width: 991px) {
  .equal-boxes {
    flex-direction: column;
  }

  .equal-boxes > div {
    flex: 1 1 100%;
  }
}
