:root {
  --grun: #9aa88b;
  --hell--grun: #ccd3c5;
  --orange: #ee9038;
  --orange2: #ef9340;
  --dunkel--orange: #e67022;
}
@font-face {
  font-family: 'M PLUS Rounded 1c';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/MPLUSRounded1c-Medium.woff2") format('woff2');
}
@font-face {
  font-family: 'M PLUS Rounded 1c';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/MPLUSRounded1c-Black.woff2") format('woff2');
}
/* ------------------------- © Werbecluster -------------------------- */
/*
 * font-family: 'M PLUS Rounded 1c', sans-serif;
*/
/* -------------------- Keyframes -------------------- */
/* -------------------- CSS Main -------------------- */
html {
  overflow-x: hidden !important;
  width: 100vw;
  scroll-behavior: smooth;
}
body {
  font-size: 1rem;
  font-weight: 500;
  font-family: 'M PLUS Rounded 1c', sans-serif;
  color: black;
}
main {
  padding-bottom: 0 !important;
  padding-top: 0 !important;
}
p {
  margin-top: 1em;
}
p, li {
  line-height: 1.33;
  font-family: 'M PLUS Rounded 1c', sans-serif;
}
ul, ol, li {
  font-family: inherit;
}
ol {
  padding-left: 1em;
}
ul {
  padding-left: 0;
}
li {
  padding-left: 1em;
  list-style: none;
  background-size: 0.4em auto;
  background-repeat: no-repeat;
  background-position: left 0.15em;
}
a, #masthead .custom-logo-link, .custom-logo, .voll a {
  outline: none !important;
}
h2, h3, h4 {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  width: 100%;
}
h2, h3 {
  text-align: center;
  font-size: 1.75rem;
}
h2 {
  text-transform: uppercase;
  font-weight: 900;
}
h3, h4 {
  font-weight: 400;
}
h4 {
  margin-top: 1em;
  font-size: 1.4rem;
}
footer {
  padding-top: 0 !important;
  ;
  padding-bottom: 0 !important;
  background-color: var(--grun);
}
footer > div {
  background-color: white;
  padding: 0.5rem 1rem;
  border-top-right-radius: 0.75rem;
  border-top-left-radius: 0.75rem;
  color: var(--grun);
}
footer p {
  margin: 0 auto;
  width: max-content;
  max-width: 100%;
  font-size: 0.9rem;
}
footer p > span {
  color: var(--orange);
}
footer a {
  color: inherit !important;
  transition: all 0.33s ease-in-out;
  background: unset !important;
  outline: none !important;
  text-decoration: none !important;
}
footer a:hover {
  color: var(--orange) !important;
}
/* ---------- Class ---------- */
.pseudo {
  height: 0px;
  width: 0px;
  overflow: hidden;
  padding: 0;
  margin: 0;
}
.flexbox {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
.flex-start {
  justify-content: flex-start;
}
.voll {
  margin: 0;
  padding: 5.5rem 5vw;
  width: 100%;
}
.voll > div {
  width: 100%;
  max-width: 1150px;
  margin: 0 auto;
}
.o-bg {
  background: unset;
  margin: 0;
  padding: 0;
  height: 100%;
  width: 100%;
  cursor: pointer;
  background-color: rgba(0, 0, 0, 0.75);
}
.o-container {
  margin: auto;
  background-color: white;
  padding: 2rem;
  padding-left: 0;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 90%;
  max-width: 1024px;
  border-radius: 0.75rem;
  max-height: 90%;
  height: max-content;
}
.o-container > img:first-of-type {
  position: absolute;
  width: 1rem;
  height: 1rem;
  cursor: pointer;
  top: 0.5rem;
  right: 0.5rem;
}
.o-container > div {
  padding: 0 0.5rem 1rem 8.5rem;
  margin: 0;
  background-size: auto 5rem;
  background-repeat: no-repeat;
  background-position: 1.5rem top;
  display: none;
  max-height: calc(90vh - 5rem);
  height: max-content;
  overflow: auto;
}
.flex-buttons {
  position: relative;
  padding: 0 0.75rem;
  margin: 0;
  width: 100%;
  height: max-content;
  display: flex;
  justify-content: center;
  align-items: stretch;
  bottom: -1rem;
  left: 0;
  right: 0;
}
.flex-buttons a, #fakten button {
  background: unset !important;
  outline: none !important;
  border: none !important;
  display: block;
  padding: 0.35rem 1rem 0;
  margin: 0;
  border-top-left-radius: 0.75rem;
  border-top-right-radius: 0.75rem;
  background-color: var(--orange) !important;
  font-size: 1rem;
  font-weight: 700;
  transition: all 0.5s ease-in-out;
  font-family: 'M PLUS Rounded 1c', sans-serif;
  line-height: 1;
}
.flex-buttons a {
  color: white !important;
  text-decoration: none !important;
  padding-bottom: 0.5rem;
  border-bottom-left-radius: 0.75rem;
  border-bottom-right-radius: 0.75rem;
  padding-top: 0.45rem;
}
.flex-buttons a:hover, #fakten button:hover {
  background-color: var(--grun) !important;
}
.flex-buttons a:not(:first-of-type) {
  margin-left: 1rem;
}
.foermlich a {
  outline: none !important;
  border: none !important;
  background: unset !important;
  color: inherit !important;
  text-decoration: none !important;
  transition: all 0.5s ease-in-out;
}
.foermlich a:hover {
  color: white !important;
}
/* ---------- IDs ---------- */
#einleitung {
  padding-bottom: 12vw;
  background-image: url("../img/bg_einleitung_2.png"), url("../img/bg_einleitung_1.png");
  background-size: auto calc(100% - 1rem), 100% auto;
  background-repeat: no-repeat, no-repeat;
  background-position: right calc(100% - 1rem), left bottom;
}
#einleitung h2 {
  color: white;
  text-align: left;
  hyphens: auto;
  text-transform: none;
}
#einleitung ul {
  width: 35rem;
  max-width: 100%;
  margin: 3.5rem auto;
  display: block;
  padding: 1.75rem 3rem 2rem;
  border: 3px solid white;
  border-bottom: none;
  border-top: none;
}
#einleitung li {
  background-image: url("../img/list_white.png");
}
#ziele {
  background-color: white;
}
#ziele .flexbox {
  align-items: stretch;
  margin-top: 3.5rem;
}
#ziele .flexbox div:first-of-type {
  /*width: 60%;*/
  width: 54%;
}
#ziele .flexbox div:last-of-type {
  /*width: 35%;*/
  width: 45%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  border-radius: 0.75rem;
}
#ziele .flexbox p:first-of-type {
  margin-top: 0;
}
#ziele .flexbox p:not(:first-of-type) {
  margin-top: 1.75em;
}
#ziele .flexbox ul {
  margin-top: 0.75em;
}
#ziele .flexbox li {
  line-height: 1.5;
  background-image: url("../img/list_orange.png");
}
#uber-uns {
  background-color: var(--grun);
  background-image: url("../img/bg_uber-uns.png");
  background-size: auto 11rem;
  background-repeat: no-repeat;
  background-position: calc(50% - 20.728rem) top;
  color: white;
}
#uber-uns .flexbox {
  margin: 3.5rem 0 3rem;
  align-items: flex-start
}
#uber-uns .flexbox div {
  width: 50%;
}
#uber-uns .flexbox img {
  width: 42.5%;
  height: auto;
  border-radius: 0.75rem;
}
#uber-uns .flexbox div p:first-of-type {
  margin-top: 2em;
}
#team {
  background: unset;
  border: none;
  padding: 0;
  margin: 0;
}
#team.flexslider .slides img {
  width: 100%;
  height: 20vw;
  max-height: 15rem;
  object-fit: cover;
  object-position: center top;
  border-radius: 0.75rem;
}
#fakten, #impressum {
  padding-bottom: 20vw;
  background-image: url("../img/bg_fakten.png");
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: left bottom;
}
#fakten h2 {
  color: white;
}
#fakten .flexbox {
  align-items: stretch;
  margin-top: 3.5rem;
}
#fakten .flexbox > div {
  background-color: white;
  background-size: auto 3.5rem;
  background-repeat: no-repeat;
  background-position: 1rem 1rem;
  padding: 1rem;
  padding-left: 5.5rem;
  border-radius: 0.75rem;
  width: calc(50% - 1rem);
  margin-bottom: 1rem;
  position: relative;
}
#fakten .flexbox > div > p:first-of-type {
  margin-top: 0;
}
#fakten .white-bottom {
  position: relative
}
#fakten .white-bottom::after {
  content: "";
  width: 100%;
  padding: 0;
  margin: 0;
  height: 2.5rem;
  background-image: linear-gradient(to bottom, transparent 0%, white 95% 100%);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: left top;
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
}
#fakten .long-text, #fakten .flex-buttons {
  display: none;
}
#fakten .btn-container {
  display: block;
  position: absolute;
  bottom: -1px;
  left: calc(50% - 3.814rem);
  height: max-content;
  width: max-content;
}
#fakten button {
  color: white;
}
#kontakt, #dsgvo {
  background-color: var(--grun);
}
#kontakt h2, #kontakt h3, #kontakt .quelle {
  color: white;
}
#kontakt h3 {
  margin-top: 1.5em;
}
#kontakt h2, #kontakt h3, #kontakt .quelle {
  text-align: center;
}
#kontakt li {
  background-image: url("../img/list_grun.png");
}
#kontakt .flexbox {
  margin-top: 3.5rem;
  align-items: stretch;
}
#kontakt .flexbox > div {
  width: calc(50% - 1rem);
}
#kontakt .flexbox > div:first-of-type {
  border-radius: 0.75rem;
  background-color: white;
  padding: 1.5rem 1rem 1rem 3rem;
}
#kontakt .flexbox > div:first-of-type p:first-of-type {
  margin-top: 0;
  margin-bottom: 1em;
}
#kontakt .wpforms-container .wpforms-field, #kontakt .wpforms-container .wpforms-submit-container {
  padding: 0;
}
#kontakt .wpforms-container {
  margin: 0;
}
#kontakt .wpforms-container input[type="text"], #kontakt .wpforms-container input[type="email"], #kontakt .wpforms-container textarea, #kontakt button[type="submit"], #kontakt button[type="button"] {
  outline: none !important;
  background: unset !important;
  border: none !important;
  border-radius: 0.75rem;
  background-color: white !important;
  transition: all 0.5s ease-in-out;
  font-family: 'M PLUS Rounded 1c', sans-serif;
}
#kontakt .wpforms-container input[type="text"], #kontakt .wpforms-container input[type="email"], #kontakt .wpforms-container textarea {
  padding: 0.4rem 1rem 0.6rem;
  margin: 0 0 1rem
}
#kontakt .wpforms-container input[type="text"]:focus, #kontakt .wpforms-container input[type="email"]:focus, #kontakt .wpforms-container textarea:focus {
  background-color: var(--hell--grun) !important;
}
#kontakt .wpforms-container label.wpforms-error {
  color: white;
}
#kontakt .wpforms-container textarea {
  resize: none !important;
  background-image: url("../img/bg_kontakt.png") !important;
  background-repeat: no-repeat !important;
  background-position: left bottom !important;
  background-size: auto 90% !important;
}
#kontakt .wpforms-container textarea:focus {
  background-image: unset !important;
}
#kontakt button[type="submit"], #kontakt button[type="button"] {
  padding: 1rem;
  margin: 0;
  font-weight: 700;
  color: var(--grun);
  line-height: 1;
  font-size: 1rem;
}
#kontakt button[type="submit"]:hover, #kontakt button[type="button"]:hover {
  color: var(--orange);
}
#kontakt .wpforms-confirmation-container {
  padding: 0.4rem 1rem 0.6rem;
  border-radius: 0.75rem;
  ;
  background-color: var(--hell--grun);
  color: var(--orange);
}
#kontakt .wpforms-confirmation-container p {
  margin: 0;
}
#overlay {
  width: 100vw;
  height: 100vh;
  padding: 0;
  margin: 0;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 666;
  display: none;
}
#impressum h2, #impressum strong {
  color: white;
}
#dsgvo {
  padding-bottom: 3.5rem;
}
#dsgvo > div > div {
  background-color: white;
  border-radius: 0.75rem;
  margin: 3.5rem 0 0;
  padding: 1rem;
}
#dsgvo a:hover {
  color: var(--grun) !important;
}
#werbecluster {
  font-family: Arial, Helvetica, sans-serif !important;
  color: inherit !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  font-style: normal !important;
  -webkit-user-select: none !important;
  -ms-user-select: none !important;
  user-select: none !important;
  cursor: alias !important;
  outline: none !important;
}
#werbecluster > span {
  text-decoration-color: #fdc400 !important;
  text-decoration-thickness: 3px !important;
}
#werbecluster > span:first-of-type {
  font-weight: 700 !important;
  text-decoration-style: solid !important;
}
#werbecluster > span:last-of-type {
  font-style: italic !important;
  text-decoration-style: dotted !important;
}
#werbecluster, #werbecluster span {
  transition: all 0.5s ease-in-out !important;
}
#werbecluster:hover {
  color: #4c4b4b !important;
}
#werbecluster:hover span {
  text-decoration-line: overline !important;
}
/* -------------------- CSS Responsiv -------------------- */
@media screen and (min-width: 482px) {
  #logo, #masthead {
    max-width: 1150px;
    background-color: white;
  }
  #logo {
    margin: 0 auto 1.5rem;
    padding: 0.75rem 1rem;
    border-bottom-right-radius: 0.75rem;
    border-bottom-left-radius: 0.75rem;
  }
  #logo .site-branding, #logo .site-logo {
    margin: 0;
  }
  #logo .site-logo .custom-logo {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 5.5rem;
  }
  #masthead {
    margin: 0 auto;
    padding: 0 1rem;
    border-radius: 0.75rem;
    position: sticky;
    top: 0;
    z-index: 665;
  }
  #masthead .site-branding {
    display: none;
  }
  #masthead .primary-navigation {
    margin: 0 auto;
  }
  #masthead .primary-navigation .primary-menu-container > ul > .menu-item {
    padding: 0;
  }
  #masthead .primary-navigation .primary-menu-container > ul > .menu-item > a {
    font-size: 1rem;
    background: unset !important;
    outline: none !important;
    color: var(--grun) !important;
    text-decoration: none !important;
    padding: 0.5rem 1.5rem;
    font-weight: 400;
    transition: all 0.33s ease-in-out;
    position: relative;
    font-family: 'M PLUS Rounded 1c', sans-serif;
  }
  #masthead .primary-navigation .primary-menu-container > ul > .menu-item > a:hover {
    color: var(--orange) !important;
  }
  #masthead .primary-navigation .primary-menu-container > ul > .menu-item:not(:last-of-type) > a::after {
    content: "";
    width: 3px;
    height: calc(100% - 1rem);
    background-color: var(--orange);
    display: inline-block;
    position: absolute;
    right: -1px;
    top: 0.5rem;
  }
}
@media all and (max-width: 79rem) {
  /* 1264px */
  #ziele .flexbox {
    flex-direction: column;
  }
  #ziele .flexbox div:first-of-type, #ziele .flexbox div:last-of-type {
    width: 100%;
  }
  #ziele .flexbox div:last-of-type {
    margin-top: 2rem;
  }
  #ziele .flexbox div:last-of-type {
    height: 43vw;
  }
}
@media all and (max-width: 48rem) {
  /* 768px */
  .flex-direction-nav .flex-prev {
    left: -2rem;
  }
  .flex-direction-nav .flex-next {
    right: -2rem;
  }
  .o-container > div {
    overflow-x: hidden;
    overflow-y: auto;
  }
  .flex-buttons {
    width: 90vw;
    left: -8.5rem;
    padding: 0 2rem;
  }
  #einleitung ul {
    padding: 1rem 1.25rem;
  }
  #uber-uns .flexbox {
    flex-direction: column;
  }
  #uber-uns .flexbox div, #uber-uns .flexbox img, #fakten .flexbox > div, #kontakt .flexbox > div {
    width: 100%;
  }
  #uber-uns .flexbox img, #kontakt .flexbox > div:last-of-type {
    margin-top: 2rem;
  }
  #uber-uns {
    background-position: calc(95% - 8.5rem) top;
  }
  #uber-uns h2 {
    text-align: right;
  }
  #uber-uns .flexbox div p:first-of-type {
    margin-top: 0;
  }
  #team.flexslider .slides img {
    height: 30vw;
  }
}
@media all and (max-width: 481px) {
  .flex-direction-nav .flex-prev, .flex-direction-nav .flex-next, #logo {
    display: none;
  }
  .flex-buttons {
    width: calc(100% + 3rem);
    padding: 0 0.75rem;
    left: -3rem;
  }
  #masthead.site-header.has-logo:not(.has-title-and-tagline).has-menu .site-logo {
    margin: 0;
    padding: 0.25rem 0;
  }
  #masthead.site-header.has-logo:not(.has-title-and-tagline).has-menu .site-logo {
    z-index: 666;
    display: block !important;
  }
  #masthead.site-header.has-logo:not(.has-title-and-tagline).has-menu .site-logo img {
    padding: 0.5rem;
    border-radius: 0.75rem;
    background-color: white;
    width: auto;
    height: auto;
    max-width: 60vw;
    max-height: 78px;
    z-index: 666;
  }
  #masthead .menu-button-container #primary-mobile-menu {
    outline: none !important;
    color: white;
  }
  #masthead .menu-button-container {
    padding: 0;
  }
  #masthead .menu-button-container #primary-mobile-menu .dropdown-icon .svg-icon {
    width: 2.5rem;
    height: 2.5rem;
  }
  #masthead .menu-button-container #primary-mobile-menu .dropdown-icon.close .svg-icon {
    background-color: var(--orange);
    border-radius: 0.75rem;
  }
  #masthead .primary-navigation > .primary-menu-container, .primary-navigation-open .menu-button-container {
    background-color: white;
  }
  #masthead .primary-navigation > div > .menu-wrapper {
    padding: 2rem 0;
  }
  #masthead .primary-navigation > div > .menu-wrapper li:not(:last-of-type)::after {
    content: "";
    display: block;
    height: 2px;
    width: 2.5rem;
    background-color: var(--orange);
    margin: 0 auto;
  }
  #masthead .primary-navigation a {
    padding: 0.75rem 0;
    font-size: 1rem;
    background: unset !important;
    outline: none !important;
    color: var(--grun) !important;
    text-decoration: none !important;
    font-weight: 400;
    transition: all 0.33s ease-in-out;
    font-family: 'M PLUS Rounded 1c', sans-serif;
    text-align: center;
  }
  #masthead .primary-navigation a:hover {
    color: var(--orange) !important;
  }
  #einleitung .flexbox p, #einleitung .flexbox ul {
    width: 100%;
    padding: 0;
    border: none;
  }
  #einleitung .flexbox p {
    padding-bottom: 1.5rem;
    margin-bottom: 1.5rem;
    border-bottom: 3px solid white;
  }
  #einleitung .flexbox ul {
    padding-bottom: 1rem;
  }
  #team.flexslider .slides img {
    height: 50vw;
  }
  #fakten .flexbox > div {
    background-size: auto 2rem;
    padding-left: 4rem;
    padding-bottom: 3.5rem;
  }
}