@charset "UTF-8";
/*
Theme Name: Hahn
Author: a3rtgm, AIW, Bertram Hillmann
Version: 1.1
Description: Personal individualized theme for Prof. Hahn's personal website
*/
.flex-wrapper {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
}
.flex-wrapper.paper {
  background: #e8e8e8;
}
.flex-wrapper.paper2 {
  background: #f1ecec;
}
.flex-wrapper.orange {
  background: #ff8b2d;
}
.flex-wrapper.intro p {
  font-family: "font1", sans-serif;
  font-size: 120%;
  font-weight: 100;
  color: #676767;
}
.flex-wrapper.intro p em {
  display: block;
  margin: 20px 0px;
  font-weight: 500;
  color: #2c2726;
}
.flex-wrapper .flex-13 {
  flex: 0 0 32%;
  padding: 30px;
  box-sizing: border-box;
  margin: 0;
}
.flex-wrapper .flex-23 {
  flex: 0 0 65%;
  padding: 50px;
  box-sizing: border-box;
  margin: 0;
}
.flex-wrapper .wp-block-image {
  margin: 0;
  padding: 0;
}

.n2-section-smartslider #n2-ss-2 .n2-ss-slider-wrapper-inside .n2-ss-slide {
  height: 60vh !important;
  min-height: 600px;
}
.n2-section-smartslider #n2-ss-2 .n2-ss-slider-wrapper-inside .n2-ss-slide .n2-ss-layers-container {
  width: 100%;
  max-width: 100%;
}
.n2-section-smartslider #n2-ss-2 .n2-ss-slider-wrapper-inside .n2-ss-slide .n2-ss-layers-container .n2-ss-layer {
  position: relative;
  width: 100%;
  max-width: 100%;
  padding: 0 10% 10% 0;
}
.n2-section-smartslider #n2-ss-2 .n2-ss-slider-wrapper-inside .n2-ss-slide .n2-ss-layers-container .n2-ss-layer:after {
  content: "";
  position: absolute;
  top: 10%;
  left: 10%;
  width: 90%;
  height: 90%;
  background: #ff8b2d;
}

.swiper-wrapper {
  width: 100%;
  position: relative;
}
.swiper-wrapper .swiper-background-bar {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 84%;
  transform: translateY(-50%);
  opacity: 0.4;
}
@media (max-height: 960px) {
  .swiper-wrapper .swiper-background-bar {
    height: 70%;
    min-height: 440px;
  }
}
.swiper-wrapper .swiper-container {
  width: 90%;
  max-width: 1600px;
  position: relative;
  margin: 10px auto;
  height: 70vh;
  min-height: 600px;
  overflow: hidden;
}
@media (max-width: 1460px) {
  .swiper-wrapper .swiper-container {
    width: 80%;
  }
}
@media (max-height: 960px) {
  .swiper-wrapper .swiper-container {
    margin: 0px auto;
    height: 85vh;
    min-height: 540px;
  }
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide {
  z-index: 3;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content {
  position: relative;
  width: 100%;
  height: 100%;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .slide-title {
  position: absolute;
  top: 50%;
  z-index: 5;
  font-size: 400%;
  text-transform: uppercase;
  color: white;
  font-family: "font1", sans-serif;
  z-index: 50;
  text-shadow: 2px 2px black;
}
@media (max-width: 1460px) {
  .swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .slide-title {
    font-size: 320%;
  }
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .slide-excerpt {
  position: relative;
  width: 100%;
  height: 100%;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .slide-excerpt p {
  position: absolute;
  top: 50%;
  padding-top: 80px;
  z-index: 5;
  font-size: 180%;
  color: whitesmoke;
  text-shadow: 1px 1px #444;
  z-index: 50;
}
@media (max-width: 1460px) {
  .swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .slide-excerpt p {
    font-size: 140%;
  }
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .slide-excerpt .wp-block-buttons {
  position: absolute;
  top: 50%;
  left: 12.5%;
  padding-top: 140px;
  z-index: 15;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .slide-excerpt .wp-block-buttons .wp-block-button a {
  font-size: 120%;
  background: rgba(255, 139, 45, 0.8);
  backdrop-filter: blur(5px);
  padding: 10px 40px;
  border-radius: 0px;
  color: whitesmoke;
  -webkit-box-shadow: 0px 10px 25px -15px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 10px 25px -15px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 10px 25px -15px rgba(0, 0, 0, 0.75);
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .slide-bg {
  position: relative;
  display: block;
  padding-bottom: 70px;
  width: calc(100% - 70px);
  height: 100%;
  /*&:after {
      content:"";
      position: absolute;
      top:0;
      left:0;
      width:100%;
      height:calc(100% - 70px);
      opacity:1;
      mix-blend-mode: multiply;
      background:url("/assets/images/pattern.webp");
      z-index:3;
  }*/
}
@media (max-width: 1460px) {
  .swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .slide-bg {
    padding-bottom: 35px;
    width: calc(100% - 35px);
  }
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .slide-bg img {
  position: relative;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  object-position: center;
  z-index: 1;
  -webkit-box-shadow: 0px 20px 45px -25px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 20px 45px -25px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 20px 45px -25px rgba(0, 0, 0, 0.75);
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .overlay-foreground {
  content: "";
  position: absolute;
  width: calc(100% - 70px);
  height: calc(100% - 70px);
  top: 0;
  mix-blend-mode: multiply;
  pointer-events: none;
  opacity: 0.85;
  border: 25px solid #2c2726;
  z-index: 5;
}
@media (max-width: 1460px) {
  .swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .overlay-foreground {
    width: calc(100% - 35px);
    height: calc(100% - 35px);
  }
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .dynamic-slide-background {
  content: "";
  position: absolute;
  width: calc(100% - 70px);
  height: calc(100% - 70px);
  background: #ff8b2d;
  opacity: 0.65;
  z-index: 0;
}
@media (max-width: 1460px) {
  .swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide .slide-content .dynamic-slide-background {
    width: calc(100% - 35px);
    height: calc(100% - 35px);
  }
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.odd-slide .slide-content .slide-title {
  left: 10%;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.odd-slide .slide-content p {
  left: 12.5%;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.odd-slide .slide-content .slide-bg {
  margin: 0 auto 0 0;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.odd-slide .slide-content .overlay-foreground {
  left: 0;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.odd-slide .slide-content .dynamic-slide-background {
  top: 70px;
  left: 70px;
}
@media (max-width: 1460px) {
  .swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.odd-slide .slide-content .dynamic-slide-background {
    top: 35px;
    left: 35px;
  }
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.even-slide .slide-content .slide-title {
  left: auto;
  right: 10%;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.even-slide .slide-content p {
  left: auto;
  right: 12.5%;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.even-slide .slide-content .slide-bg {
  margin: 0 0 0 auto;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.even-slide .slide-content .overlay-foreground {
  left: auto;
  right: 0;
}
.swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.even-slide .slide-content .dynamic-slide-background {
  top: 70px;
  left: auto;
  right: 70px;
}
@media (max-width: 1460px) {
  .swiper-wrapper .swiper-container .swiper-wrapper .swiper-slide.even-slide .slide-content .dynamic-slide-background {
    top: 35px;
    left: auto;
    right: 35px;
  }
}
.swiper-wrapper .swiper-container .swiper-button-next {
  position: absolute;
  bottom: 100px;
  top: auto;
  left: auto;
  right: 100px;
  border: 2px solid #fff;
  width: 60px;
  height: 60px;
  background: rgba(0, 0, 0, 0.25);
}
@media (max-width: 1460px) {
  .swiper-wrapper .swiper-container .swiper-button-next {
    width: 50px;
    height: 50px;
    right: 70px;
    bottom: 70px;
  }
  .swiper-wrapper .swiper-container .swiper-button-next:after {
    font-size: 24px;
  }
}
.swiper-wrapper .swiper-container .swiper-button-next:after {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 30px;
  filter: saturate(0) brightness(3);
}
.swiper-wrapper .swiper-container .swiper-button-next:hover {
  cursor: pointer;
  border: 2px solid #3c3937;
  background: #3c3937;
  transition: 0.3s;
}
.swiper-wrapper .swiper-container .swiper-button-prev {
  position: absolute;
  bottom: 115px;
  top: auto;
  left: auto;
  right: 155px;
  border: 2px solid #fff;
  width: 60px;
  height: 60px;
  background: rgba(0, 0, 0, 0.25);
}
@media (max-width: 1460px) {
  .swiper-wrapper .swiper-container .swiper-button-prev {
    width: 50px;
    height: 50px;
    right: 125px;
    bottom: 85px;
  }
  .swiper-wrapper .swiper-container .swiper-button-prev:after {
    font-size: 24px;
  }
}
.swiper-wrapper .swiper-container .swiper-button-prev:after {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 30px;
  filter: saturate(0) brightness(3);
}
.swiper-wrapper .swiper-container .swiper-button-prev:hover {
  cursor: pointer;
  border: 2px solid #3c3937;
  background: #3c3937;
  transition: 0.3s;
}
.swiper-wrapper .swiper-container .swiper-pagination {
  width: auto !important;
  top: auto !important;
  bottom: 5px !important;
  left: auto !important;
  right: 90px !important;
}
@media (max-width: 1460px) {
  .swiper-wrapper .swiper-container .swiper-pagination span {
    width: 12px;
    height: 12px;
    margin: 0px 4px !important;
  }
}
.swiper-wrapper .swiper-container .swiper-pagination span {
  width: 16px;
  height: 16px;
  border: 1px solid whitesmoke;
  margin: 0px 6px !important;
}
.swiper-wrapper .swiper-container .swiper-pagination span.swiper-pagination-bullet-active {
  background: white;
}

.language-menu {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 70px;
}
.language-menu ul {
  display: flex;
  flex-flow: row nowrap;
  list-style: none;
  margin: 0;
}
.language-menu ul li {
  margin: 0px 5px;
  filter: saturate(0.5);
}
.language-menu ul li:hover {
  filter: saturate(0.75);
}
.language-menu ul li.current_page_item {
  filter: saturate(1);
}
.language-menu ul li a {
  position: relative;
  display: block;
  height: 24px;
  width: 24px;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
}

.mobile-nav #mobile-menu {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  height: 24px;
  width: 42px;
  background: white;
  border: none;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
}
.mobile-nav #mobile-menu span {
  width: 100%;
  height: 2px;
  background: #2c2726;
  transition: 0.3s;
}
.mobile-nav #mobile-menu:hover {
  cursor: pointer;
}
.mobile-nav #mobile-menu:hover span:nth-child(even) {
  transform: translateX(-3px);
  transition: 0.3s;
}
.mobile-nav #mobile-menu:hover span:nth-child(odd) {
  transform: translateX(3px);
  transition: 0.3s;
}
.mobile-nav .sidebar-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
  opacity: 0;
  background: rbga(0, 0, 0, 0.15);
  z-index: 1000;
  backdrop-filter: blur(5px);
}
.mobile-nav .sidebar-wrapper.open {
  opacity: 1;
  pointer-events: all;
}
.mobile-nav .sidebar-wrapper.open .sidebar {
  -webkit-box-shadow: -15px 0px 25px -15px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: -15px 0px 25px -15px rgba(0, 0, 0, 0.75);
  box-shadow: -15px 0px 25px -15px rgba(0, 0, 0, 0.75);
  transform: translateX(-100%);
  transition: 0.3s;
}
.mobile-nav .sidebar-wrapper .sidebar {
  position: fixed;
  left: 100%;
  top: 0;
  width: 440px;
  height: 100vh;
  background: white;
  z-index: 3;
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  overflow-x: hidden;
  transition: 0.3s;
}
.mobile-nav .sidebar-wrapper .sidebar .logo {
  flex: 1 0 100%;
  padding: 20px;
}
.mobile-nav .sidebar-wrapper .sidebar .logo h2 {
  font-size: 130%;
  color: #2c2726;
  font-weight: 400;
}
.mobile-nav .sidebar-wrapper .sidebar .nav-wrapper {
  flex: 1 0 100%;
}
.mobile-nav .sidebar-wrapper .sidebar .nav-wrapper .mobile-navbar {
  display: flex;
  flex-flow: row wrap;
  list-style: none;
  padding: 0;
}
.mobile-nav .sidebar-wrapper .sidebar .nav-wrapper .mobile-navbar li.nav-item {
  flex: 1 0 100%;
  margin: 5px 0px;
}
.mobile-nav .sidebar-wrapper .sidebar .nav-wrapper .mobile-navbar li.nav-item a {
  display: block;
  position: relative;
  font-family: "Raleway", sans-serif;
  color: #2c2726;
  text-transform: uppercase;
  padding: 10px 40px !important;
  font-size: 120%;
  color: #222;
  font-weight: 600;
}
.mobile-nav .sidebar-wrapper .sidebar .nav-wrapper .mobile-navbar li.nav-item a:hover {
  background: whitesmoke;
}
.mobile-nav .sidebar-wrapper .sidebar .nav-wrapper .mobile-navbar li.nav-item a:after {
  display: none;
}
.mobile-nav .sidebar-wrapper .sidebar .nav-wrapper .mobile-navbar li.nav-item a.dropdown-toggle {
  pointer-events: none;
}
.mobile-nav .sidebar-wrapper .sidebar .nav-wrapper .mobile-navbar li.nav-item .dropdown-menu {
  margin: 0;
  padding: 0;
  position: relative;
  margin-left: 60px;
  transform: translate(0);
  opacity: 1;
  box-shadow: none;
}
.mobile-nav .sidebar-wrapper .sidebar .nav-wrapper .mobile-navbar li.nav-item .dropdown-menu li {
  margin: 10px 0px;
}
.mobile-nav .sidebar-wrapper .sidebar .nav-wrapper .mobile-navbar li.nav-item .dropdown-menu li a {
  display: block;
  padding: 5px 10px !important;
  font-family: "font1", sans-serif;
  background: white;
  text-transform: none;
  color: #676767;
  font-weight: 300;
}
.mobile-nav .sidebar-wrapper .sidebar .mobile-footer-wrapper {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}
.mobile-nav .sidebar-wrapper .sidebar .mobile-footer-wrapper ul {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  width: 100%;
  list-style: none;
}
.mobile-nav .sidebar-wrapper .sidebar .mobile-footer-wrapper ul li {
  margin: 0px 10px;
}
.mobile-nav .sidebar-wrapper .sidebar .mobile-footer-wrapper ul li a {
  text-decoration: none;
  color: #2c2726;
}
.mobile-nav .sidebar-wrapper .sidebar-clickzone {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  z-index: 1;
}

.wp-block-group.points-plan-1 {
  position: relative;
  padding: 0 !important;
}
.wp-block-group.points-plan-1 figure {
  position: relative;
}
.wp-block-group.points-plan-1 .point-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.wp-block-group.points-plan-1 .point-wrapper .point {
  position: absolute;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #ff8b2d;
  color: white;
  font-family: "font1", sans-serif;
  font-weight: 700;
  animation: pulse 3s infinite;
  animation-play-state: running;
  overflow: visible;
  z-index: 1;
}
.wp-block-group.points-plan-1 .point-wrapper .point.point-1 {
  top: 30%;
  left: 34%;
}
.wp-block-group.points-plan-1 .point-wrapper .point.point-2 {
  top: 52%;
  left: 54%;
}
.wp-block-group.points-plan-1 .point-wrapper .point.point-3 {
  top: 28%;
  left: 55%;
}
.wp-block-group.points-plan-1 .point-wrapper .point.point-4 {
  top: 42%;
  left: 69%;
}
.wp-block-group.points-plan-1 .point-wrapper .point.point-5 {
  top: 62%;
  left: 64%;
}
.wp-block-group.points-plan-1 .point-wrapper .point.point-6 {
  top: 51%;
  left: 74%;
}
.wp-block-group.points-plan-1 .point-wrapper .point.point-7 {
  top: 78%;
  left: 66%;
}
.wp-block-group.points-plan-1 .point-wrapper .point span {
  position: absolute;
  display: none;
  pointer-events: none;
  font-size: 100%;
  color: #fff;
  background: #2c2726;
  width: auto;
  height: auto;
  padding: 5px 10px;
  border-radius: 3px;
  -webkit-box-shadow: 0px 10px 25px -15px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 10px 25px -15px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 10px 25px -15px rgba(0, 0, 0, 0.75);
  z-index: 10;
}
.wp-block-group.points-plan-1 .point-wrapper .point span.show {
  display: block;
}
.wp-block-group.points-plan-1 .point-wrapper .point::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 139, 45, 0.65);
  border-radius: 50%;
  animation: wave 3s infinite;
  animation-play-state: running;
  opacity: 0;
}
@keyframes pulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.2);
  }
}
@keyframes wave {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  100% {
    transform: scale(1.8);
    opacity: 0;
  }
}
.wp-block-group.points-plan-1 .point-wrapper .point:hover {
  cursor: pointer;
  background: #16b7cc;
  transform: scale(1.2);
  animation-play-state: paused;
  z-index: 10;
  transition: 0.3s;
}
.wp-block-group.points-plan-1 .point-wrapper .point:hover:after {
  animation-play-state: paused;
}

.projekte-grid {
  position: relative;
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  align-items: center;
  margin: 50px 0px;
}
.projekte-grid .projekt-background-bar {
  position: absolute;
  top: 50%;
  left: -100vw;
  transform: translateY(-50%);
  width: 300vw;
  height: 70%;
  z-index: 0;
}
.projekte-grid .projekt-kachel {
  position: relative;
  transition: transform 0.3s ease, background-color 0.3s ease, box-shadow 0.3s ease;
  flex: 0 0 30%;
  height: 580px;
  margin-right: 50px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  border: none;
  position: relative;
  z-index: 10;
}
@media (max-width: 1460px) {
  .projekte-grid .projekt-kachel {
    flex: 0 0 28%;
    margin-right: 50px;
    height: 500px;
  }
  .projekte-grid .projekt-kachel h2, .projekte-grid .projekt-kachel p {
    top: 40%;
  }
}
.projekte-grid .projekt-kachel:hover {
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.4);
  z-index: 2;
  cursor: pointer;
  transform: translateY(10px);
  background-color: #000;
  transition: 0.3s;
}
.projekte-grid .projekt-kachel:hover .overlay-foreground {
  border: 15px solid #2c2726;
  transition: 0.3s;
}
.projekte-grid .projekt-kachel:hover .projekt-bild {
  transform: scale(1.05);
}
.projekte-grid .projekt-kachel:hover .projekt-bild img {
  filter: brightness(0.3);
}
.projekte-grid .projekt-kachel:hover h2 {
  opacity: 1;
  transform: translateY(-50%);
  transition: 0.3s;
}
.projekte-grid .projekt-kachel:hover h3 {
  opacity: 0;
  transform: translateY(50px);
  transition: 0.3s;
}
.projekte-grid .projekt-kachel:hover p {
  opacity: 1;
  transition: 0.5s;
  transition-delay: 0.25s;
}
.projekte-grid .projekt-kachel:hover:after {
  transform: translateY(-50px);
  transition: 0.3s;
  transition-delay: 0.15s;
}
.projekte-grid .projekt-kachel .overlay-foreground {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  mix-blend-mode: multiply;
  pointer-events: none;
  opacity: 0.85;
  border: 25px solid #2c2726;
  z-index: 5;
}
.projekte-grid .projekt-kachel:after {
  content: "";
  position: absolute;
  top: 25px;
  left: 20px;
  width: 100%;
  height: 100%;
  background: #ff8b2d;
  z-index: 1;
  transition: 0.3s;
  transition-delay: 0.15s;
  opacity: 0.65;
}
.projekte-grid .projekt-kachel a {
  display: block;
  width: 100%;
  height: 100%;
}
.projekte-grid .projekt-kachel a .projekt-bild {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
  z-index: 3;
  -webkit-box-shadow: 0px 20px 45px -25px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 20px 45px -25px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 20px 45px -25px rgba(0, 0, 0, 0.75);
  transition: transform 0.3s ease;
}
.projekte-grid .projekt-kachel a .projekt-bild img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.projekte-grid .projekt-kachel a h2 {
  position: absolute;
  top: 50%;
  transform: translateY(50px);
  width: 100%;
  font-size: 160%;
  font-family: "font1", sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  text-shadow: 2px 2px #2c2726;
  color: white;
  padding: 0px 35px;
  opacity: 0;
  z-index: 100000;
  transition: opacity 0.3s ease 0s, transform 0.3s ease 0.1s;
}
.projekte-grid .projekt-kachel a h3 {
  position: absolute;
  bottom: 10px;
  left: 20px;
  font-size: 140%;
  font-family: "font1", sans-serif;
  font-weight: 400;
  text-transform: uppercase;
  text-shadow: 2px 2px #2c2726;
  color: white;
  padding: 15px;
  width: 100%;
  opacity: 1;
  transition: opacity 0.3s ease, color 0.3s ease, background-color 0.3s ease;
  z-index: 100000;
}
.projekte-grid .projekt-kachel a p {
  position: absolute;
  top: 50%;
  left: 0;
  padding: 35px;
  z-index: 100000;
  opacity: 0;
  color: #e8e8e8;
}

footer {
  position: relative;
  justify-content: space-between;
  align-items: center;
  padding: 150px 0 50px;
  background-color: #454545;
  color: #ff8b2d;
}
footer .footer-container {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding-bottom: 120px;
  width: 90%;
  max-width: 1600px;
  position: relative;
  margin: 0 auto;
}
footer .footer-container .footer-info-block {
  width: 30%; /* Infoblock nimmt 30% der Breite ein */
  padding-right: 20px; /* Abstand nach rechts */
}
footer .footer-container .footer-info-block h4 {
  font-size: 18px; /* Schriftgröße für Titel */
  margin-bottom: 10px;
}
footer .footer-container .footer-info-block ul {
  list-style-type: none;
  padding: 0;
}
footer .footer-container .footer-info-block ul li {
  margin-bottom: 5px;
  text-decoration: none;
  color: #fff;
}
footer .footer-container .footer-info-block ul li:nth-child(2) {
  margin-bottom: 40px;
}
footer .footer-container .footer-info-block ul li a {
  text-decoration: none;
  color: #fff;
}
footer .footer-menu {
  display: flex;
  justify-content: space-between;
  gap: 80px;
  margin: 0 auto;
}
footer .footer-menu .footer-block {
  flex: 1 1 auto;
  text-align: left; /* Links ausrichten */
  padding: 10px; /* Innenabstand */
}
footer .footer-menu .footer-block h4 {
  font-size: 18px; /* Schriftgröße der Überschrift */
  margin-bottom: 10px; /* Abstand zur Liste */
  font-weight: bold; /* Fettschrift */
}
footer .footer-menu .footer-block ul {
  list-style: none; /* Entfernt die Punkte in der Liste */
  padding: 0; /* Entfernt Standardabstand */
  margin: 0;
}
footer .footer-menu .footer-block ul li {
  margin-bottom: 5px; /* Abstand zwischen den Links */
}
footer .footer-menu .footer-block ul li a {
  text-decoration: none; /* Unterstreichung entfernen */
  color: #fff; /* Farbe der Links */
}
footer .footer-menu .footer-block ul li a:hover {
  color: #16b7cc; /* Farbe beim Hover (kann angepasst werden) */
}
@media (max-width: 768px) {
  footer .footer-menu .footer-menu {
    flex-direction: column; /* Blöcke untereinander auf kleinen Bildschirmen */
    max-width: 90%; /* Auf mobilen Geräten breiter */
  }
}
footer .my_extra_menu_class {
  text-decoration: none;
  padding: 0;
  margin: 0;
  display: flex;
  justify-content: center;
}
footer .my_extra_menu_class li {
  margin-bottom: 20px;
  margin-right: 60px;
  list-style: none;
}
footer .my_extra_menu_class li:last-child {
  margin-right: 0;
}
footer .my_extra_menu_class a {
  color: #ff8b2d;
  text-decoration: none;
  font-size: 16px;
}
footer .my_extra_menu_class a:hover {
  color: #16b7cc;
}
footer .my_extra_footer_class {
  position: absolute;
  bottom: 0;
  right: 100px;
  text-decoration: none;
  padding: 0;
  display: flex;
}
footer .my_extra_footer_class li {
  margin-right: 60px;
  list-style: none;
}
footer .my_extra_footer_class li:last-child {
  margin-right: 0;
}
footer .my_extra_footer_class a {
  color: #ff8b2d;
  text-decoration: none;
  font-size: 16px;
}
footer .my_extra_footer_class a:hover {
  color: #16b7cc;
}
@media (max-width: 768px) {
  footer .my_extra_footer_class {
    flex-direction: column;
    align-items: flex-end;
  }
  footer .my_extra_footer_class li {
    margin-bottom: 10px;
  }
}
footer .footer-copyright {
  position: absolute;
  bottom: 0;
  left: 0;
}
footer .footer-extra-menu {
  position: absolute;
  bottom: 0;
  right: 0;
}

#popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(5px);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 999999;
}
#popup .popup-content {
  position: relative;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(3px);
  border-radius: 8px;
  overflow: hidden;
  -webkit-box-shadow: 0px 10px 25px -15px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 10px 25px -15px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 10px 25px -15px rgba(0, 0, 0, 0.75);
}
#popup .popup-content .popup-inner-content {
  width: calc(100% + 20px);
  height: 100%;
  padding: 0px;
  margin-right: -20px;
  padding-right: 20px;
  box-sizing: border-box;
  overflow: auto;
  overflow-x: hidden;
}
#popup .popup-content .popup-inner-content h2 {
  font-size: 24px;
  margin-bottom: 20px;
}
#popup .popup-content .popup-inner-content p {
  font-size: 16px;
  line-height: 1.5;
}
#popup .popup-content .popup-inner-content .wp-block-group {
  position: relative;
  padding: 50px;
}
#popup .popup-content .popup-inner-content .wp-block-group.intro-popup .wp-block-media-text {
  grid-template-columns: auto;
}
#popup .popup-content .popup-inner-content .wp-block-group.intro-popup .wp-block-media-text figure {
  width: 100%;
  height: 100%;
  min-height: 400px;
}
#popup .popup-content .popup-inner-content .wp-block-group.intro-popup .wp-block-media-text figure img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
#popup .popup-content .popup-inner-content .wp-block-group.intro-popup .wp-block-media-text__content {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  position: absolute;
}
#popup .popup-content .popup-inner-content .wp-block-group.intro-popup .wp-block-media-text__content p {
  position: absolute;
  font-family: "font1";
  color: #2c2726;
  font-weight: 500;
  font-size: 120%;
  margin: 10px 0px;
  left: 50px;
  bottom: 50px;
}
#popup .popup-content .popup-inner-content .wp-block-group.intro-popup .wp-block-media-text__content p.popup-header {
  text-align: right;
  right: 50px;
  top: 50px;
  left: auto;
  bottom: auto;
}
#popup .popup-content .popup-inner-content .wp-block-group.intro-popup .wp-block-media-text__content p strong {
  font-size: 180%;
  font-weight: 700;
}
#popup .popup-content .popup-inner-content .wp-block-group.brown-block {
  background: #3c3937;
  padding: 70px 50px;
  min-height: 400px;
  position: relative;
}
#popup .popup-content .popup-inner-content .wp-block-group.brown-block .wp-block-group__inner-container {
  width: 100%;
  height: 100%;
}
#popup .popup-content .popup-inner-content .wp-block-group.brown-block .wp-block-group__inner-container h2 {
  position: absolute;
  bottom: 10px;
  left: 50px;
  font-family: "font1", sans-serif;
  font-size: 320%;
  font-weight: 700;
  max-width: 90%;
  color: white;
}
#popup .popup-content .popup-inner-content .wp-block-group.brown-block .wp-block-group__inner-container h2 strong {
  color: #ff8b2d;
}
@media (max-width: 1460px) {
  #popup .popup-content .popup-inner-content .wp-block-group.brown-block .wp-block-group__inner-container h2 {
    font-size: 300%;
  }
}
#popup .popup-content .popup-inner-content .wp-block-group.brown-block .wp-block-group__inner-container p {
  color: #e8e8e8;
  text-align: right;
  margin: 0 0 170px auto;
  max-width: 80%;
}
#popup.projects .popup-content {
  position: absolute;
  top: 0;
  right: 0;
  width: 40vw;
  height: 100vh;
  background: white;
  min-width: 600px;
  max-width: 100%;
  border-radius: 0px;
  overflow-x: hidden;
  -webkit-box-shadow: -15px 0px 25px -15px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: -15px 0px 25px -15px rgba(0, 0, 0, 0.75);
  box-shadow: -15px 0px 25px -15px rgba(0, 0, 0, 0.75);
}
#popup.footer .popup-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 600px;
  height: 800px;
  max-width: 90%;
  max-height: 80%;
}
#popup .popup-close {
  position: absolute;
  top: 10px;
  right: 10px;
  font-size: 24px;
  color: #ff8b2d;
  background: none;
  border: none;
  cursor: pointer;
}
#popup .popup-close:hover {
  color: #16b7cc;
}

#wpadminbar {
  display: none;
}

html, body {
  margin: 0 !important;
  padding: 0 !important;
  overflow-x: hidden;
}

.front-page-content {
  width: 100vw;
  margin-top: 10vh;
}
@media (max-height: 960px) {
  .front-page-content {
    margin-top: 0vh;
  }
}
.front-page-content section {
  display: block;
  width: 100%;
  margin: 0px auto;
}
.front-page-content section .container {
  width: 90%;
  max-width: 1600px;
}
@media (max-width: 1460px) {
  .front-page-content section .container {
    width: 80%;
  }
}
.front-page-content section:nth-child(odd) {
  background: whitesmoke;
}

.custom-bgc {
  background-color: #e8e8e8;
}

.header {
  position: fixed;
  top: 50px;
  width: 100%;
  z-index: 1000;
}

img {
  max-width: 100%;
}

.navbar {
  background-color: white !important;
  top: 0;
  width: 100%;
  height: 60px;
  z-index: 1000;
  transition: box-shadow 0.3s ease;
  top: 10vh;
}
@media (max-height: 960px) {
  .navbar {
    top: 0vh;
  }
}
.navbar.sticky {
  position: fixed;
  top: 0;
}
.navbar .container-fluid {
  position: relative;
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  align-items: center;
  width: 90%;
  max-width: 1600px;
  margin: 0px auto;
}
@media (max-width: 1460px) {
  .navbar .container-fluid {
    width: 80%;
  }
}
.navbar.navbar-scrolled {
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

.navbar-nav {
  margin-left: 100px;
}
.navbar-nav .nav-item {
  position: relative;
  height: 60px;
  line-height: 60px;
}
.navbar-nav .nav-item:last-child:after {
  display: none;
}
.navbar-nav .nav-item:after {
  content: "";
  position: absolute;
  width: 1px;
  height: 30px;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  background: #ccc;
}

.nav-link {
  width: 100%;
  color: #000;
  text-decoration: none;
  transition: color 0.3s ease;
  padding: 0px 30px !important;
  list-style: none;
}
.nav-link.dropdown-toggle {
  padding-right: 40px !important;
}
.nav-link.dropdown-toggle:after {
  position: absolute;
  top: 50%;
  right: 15px;
  transform: translateY(-50%);
}
.nav-link:hover {
  background-color: whitesmoke;
}
.nav-link.active {
  color: #fff;
  background-color: #16b7cc;
}

.dropdown-menu {
  display: block;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  background-color: white;
  transform: translateY(-100px);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  z-index: 1;
  border: none;
  transition: transform 0.3s ease 0s, opacity 0.3s ease 0s;
}
.dropdown-menu .dropdown-item {
  color: #333;
  text-decoration: none;
  display: block;
}
.dropdown-menu .dropdown-item:hover {
  background-color: #e8e8e8;
}
.dropdown-menu .dropdown-toggle::after {
  display: none;
}

.nav-item.dropdown:hover .dropdown-menu {
  opacity: 1;
  pointer-events: all;
  transform: translateY(0);
  transition: transform 0.3s ease 0.15s, opacity 0.3s ease 0.25s;
}

section {
  padding: 120px 0;
}

#backToTop {
  position: fixed;
  height: 40px;
  width: 40px;
  bottom: 20px;
  right: 20px;
  padding: 10px;
  background-color: #ff8b2d;
  color: white;
  border: none;
  border-radius: 0;
  cursor: pointer;
  z-index: 10000;
  display: flex;
  justify-content: center;
  align-items: center;
}
#backToTop img {
  vertical-align: middle;
  position: relative;
  transition: transform 0.3s ease;
}
#backToTop img:hover {
  animation: bounce 0.6s infinite;
}

@keyframes bounce {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-5px);
  }
  100% {
    transform: translateY(0);
  }
}
@media (max-width: 1024px) {
  .navbar-nav {
    display: none;
  }
}/*# sourceMappingURL=style.css.map */