footer {
  position: relative;
}

footer a {
  color: #fff;
  text-decoration: none;
  transition: all 0.5s ease 0s;
}

footer#footer a:hover {
  color: var(--red) !important;
}

footer h4 {
  color: var(--red);
  font-size: 1.4rem;
  font-family: "callgest-regular";
  text-transform: none;
  font-weight: 400;
}

footer p {
  color: #fff;
  font-family: "Poppins";
  font-size: 1rem;
}

.wrap {
  display: flex;
  width: 100%;
  justify-content: center;
  padding: 6.4vw 0px 11.6vw 0;
  background-image: url("/wp-content/uploads/muster-bg.svg");
  background-repeat: repeat;
  position: relative;
}

.wrap:after {
  content: "";
  display: block;
  position: absolute;
  background-image: url("/wp-content/uploads/footer-hashtag.svg");
  width: 180px;
  height: calc(180px / 10.3529);
  background-repeat: no-repeat;
  background-size: contain;
  bottom: 6.8vw;
  right: 5vw;
}

.inner-wrap {
  display: flex;
  justify-content: space-between;
  width: 90%;
  max-width: 1360px;
}

.inner-wrap .textwidget *,
.menu-footer-menue-container * {
  line-height: 2;
}

#footer-links,
#footer-mitte,
#footer-rechts {
  display: flex;
  flex-basis: auto;
  flex-direction: column;
  color: #fff;
  flex: 0 0 auto;
}

div#footer-rechts * {
  list-style: none !important;
}

div#footer-rechts .hidden {
  opacity: 0;
  pointer-events: none !important;
  display: block !important;
}

div#footer-rechts ul#menu-footer-menue {
  margin: 0;
  padding-left: 0;
}

.logo-wrap {
  display: flex;
  justify-content: center;
  background-color: #fff;
}

.logo-wrap * {
  line-height: 2;
}

#footer-logos {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-around;
  padding: 3vw 0;
  max-width: 966px;
}

.ft-logo {
  max-width: 175px;
  width: auto;
  display: inline-block;
  vertical-align: middle;
  margin: 0 2.2vw;
}

#footer-top-btn {
  position: absolute;
  right: 2vw;
  bottom: 6.5vw;
}

/*----------------- MOBILE BAR  -------------*/
div#mobile-bar {
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 1000;
  display: none;
  transition: all .5s ease 0s;
}

div#mobile-bar * {
  display: flex;
  flex: 1 1 auto;
  justify-content: center;
  align-items: center;
}

div#mobile-icons p:first-of-type {
  background-color: var(--light-green);
}

div#mobile-icons p:nth-of-type(2) {
  background-color: var(--green);
}

div#mobile-icons p:last-of-type {
  background-color: var(--red);
}

div#mobile-icons p>* {
  color: #fff;
  font-family: "Poppins";
  font-weight: bold;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  line-height: 1;
  padding: 1.2em 10px;
}

/*----------------- SOCIAL SHARE -------------*/

.heateorSssSharing,
.heateorSssSharingButton {
  margin: 0;
}

.heateor_sss_sharing_container.heateor_sss_horizontal_sharing {
  margin-bottom: 1.3vw;
}

ul.heateor_sss_follow_ul li,
ul.heateor_sss_sharing_ul li {
  float: right !important;
}

/*----------------- END SOCIAL SHARE -------------*/

@media (min-width: 1920px) {
  .ft-logo {
    margin: 0 0px;
  }

  .wrap {
    padding: 160px 0px 280px 0;
  }
}

@media (max-width: 1500px) {
  .home .wrap {
    padding: 6.4vw 0px calc(11.6vw + (var(--minifrom-height) / 2)) 0;
    position: relative;
  }

  .home .wrap:after {
    bottom: calc(6.5vw + (var(--minifrom-height) / 2));
  }
}

@media (max-width: 1200px) {
  div#footer-img {
    max-width: 190px;
    width: 15vw;
  }

  .wrap {
    padding: 6.4vw 0px 16.6vw 0;
  }

  .wrap:after {
    bottom: 8.8vw;
  }
}

@media (max-width: 990px) {
  div#mobile-bar {
    display: flex;
  }

  .wrap {
    padding: 6.4vw 0px 16.6vw 0;
  }

  .wrap:after {
    bottom: 10.8vw;
  }

  .inner-wrap {
    flex-wrap: wrap;
  }

  div#footer-img {
    flex-basis: 50%;
    max-width: unset;
    order: +1;
    justify-content: flex-end;
    display: flex;
    padding-right: 10vw;
    margin-bottom: 3vw;
  }

  div#footer-img>* {
    max-width: 220px !important;
  }

  #footer-links,
  #footer-mitte {
    margin-bottom: 5vw;
  }

  #footer-links,
  #footer-mitte,
  #footer-rechts {
    flex: 0 0 50%;
  }
}

@media (max-width: 767px) {
  div#footer-logos {
    flex-wrap: wrap;
    justify-content: center;
  }

  .ft-logo {
    flex: 33%;
    margin: 2vw 0;
    padding: 0 2.2vw;
    display: flex;
    justify-content: center;
  }

  .ft-logo img {
    max-height: 100px !important;
    width: auto;
  }

  .wrap {
    padding: 11.6vw 0px calc(11.6vw + 90px) 0;
  }

  .wrap:after {
    bottom: calc(6vw + 60px);
  }
}

@media (max-width: 576px) {
  footer#footer {
    flex-direction: column-reverse;
    display: flex;
  }

  div#footer-mitte {
    display: none;
  }

  .home .wrap {
    padding: 11.5vw 0px 25vw 0;
    position: relative;
  }

  .inner-wrap {
    flex-wrap: wrap;
    flex-direction: revert;
    justify-content: center;
    align-items: center;
    text-align: center;
  }

  div#footer-img {
    flex-basis: auto !important;
    width: 50%;
    padding: 0;
  }

  #footer-links,
  #footer-rechts {
    margin-bottom: 10vw;
    flex-basis: 100%;
  }

  div#footer-img {
    flex-basis: auto !important;
    width: 50%;
    padding: 0;
    margin: 0 0 5vw;
    display: flex;
    justify-content: center;
  }

  .wrap:after {
    right: 50%;
    transform: translateX(50%);
    bottom: 12.5vw;
    background-position: center;
  }

  footer h4 {
    margin: 0.6em;
  }

  #footer-logos {
    padding: 8vw 0;
  }

  .ft-logo img {
    max-height: 150px !important;
    width: auto;
  }

  .logo-wrap {
    display: flex;
    justify-content: center;
    background-color: #fff;
    padding-bottom: 55px;
  }
}

@media (max-width: 420px) {
  div#mobile-bar {
    padding-bottom: 23px;
    background-color: var(--grey);
  }

  .shiftnav-open div#mobile-bar {
    transform: translateY(100%);
  }

  .ft-logo {
    flex: 0 0 auto !important;
  }

  #footer-links,
  #footer-rechts {
    margin-bottom: 90px;
    flex-basis: 100%;
  }

  div#footer-logos {
    justify-content: space-around;
    width: 90%;
  }

  .ft-logo img {
    max-height: 100px !important;
    width: auto;
  }

  .ft-logo:nth-of-type(1) img {
    max-height: 90px !important;
  }

  .ft-logo:nth-of-type(2) img {
    max-height: 90px !important;
  }

  .ft-logo:nth-of-type(3) img {
    max-height: 70px !important;
  }

  footer#footer .wrap {
    padding: 93px 0px 161px 0;
  }

  footer#footer .wrap:after {
    bottom: 83px;
  }


}

@media (max-width: 320px) {
  /*----------------- ELEMENT -------------*/

  /*----------------- END ELEMENT ---------*/
}