@charset "UTF-8";
@import url("bootstrap.min.css");
@import url("aos.css");
@import url("https://cdn.gruenphase.com/gp-cookie-consent/v2/style.css");
@import url("../webfonts/SourceSansPro/SourceSansPro.css");
@import url("../webfonts/Impact/Impact.css");
/*--------------- Variables ---------------*/
:root {
  --gp-color-primary: #40b2b2;
  --gp-color-primary-dark: #007b80;
  --gp-color-primary-light: #09c0c6;
  --gp-color-secondary: #004494;
  --gp-color-secondary-dark: #12336c;
  --gp-color-secondary-light: #1c55b6;
  --gp-color-tertiary: #353535;
  --gp-color-tertiary-dark: #2d2d2d;
  --gp-color-tertiary-light: #737373;
  --black_1: #555;
  --black_2: #999;
  --black_3: #dde0e2;
  --black_4: #ebeef0;
  --white: #ffffff;
  --bs-link-color: #7C7C7B;
  --bs-link-color-rgb: 124, 124, 123;
  --bs-link-decoration: underline;
  --bs-link-hover-color: #999;
  --bs-link-hover-color-rgb: 146, 146, 146;
  --bs-breakpoint-xs: 375px;
  --bs-bg-opacity:1;
  --bs-primary: var(--gp-color-primary);
  --bs-secondary: var(--gp-color-secondary);
  --bs-primary-rgb: 64, 178, 178;
  --bs-secondary-rgb: 0, 68, 148;
  --bs-dark-primary-rgb: 0, 123, 128;
  --bs-light-primary-rgb: 9, 192, 198;
  --bs-dark-secondary-rgb: 18, 51, 108;
  --bs-light-secondary-rgb: 28, 85, 182;
  --bs-tertiary-rgb: 85, 85, 85;
  --bs-dark-tertiary-rgb: 45, 45, 45;
  --bs-light-tertiary-rgb: 57, 57, 57;
}

/* 
----------  GLOBAL CLASSES ----------
*/
::-moz-selection {
  color: var(--white);
  background: var(--gp-color-primary);
}
::selection {
  color: var(--white);
  background: var(--gp-color-primary);
}

@media (min-width: 1200px) {
  #body {
    font-size: 1.2rem;
  }
}
#body #main {
  min-height: 300px;
  font-family: "Source Sans Pro", sans-serif;
  color: var(--black_1);
}
#body #main :is(h2) {
  text-transform: uppercase;
  font-weight: 600;
  color: var(--gp-color-primary);
}
#body #main :is(h3) {
  font-weight: 600;
  color: var(--gp-color-secondary-light);
}

/* Page Video background  */
.page-bg {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: -1;
  background-image: linear-gradient(45deg, var(--gp-color-primary-dark) 0%, var(--gp-color-primary-light) 100%);
}

.page-bg :is(video, img) {
  width: auto;
  height: 100%;
  opacity: 0.5;
}

@media (min-width: 1720px) {
  .page-bg :is(video, img) {
    width: 100%;
    height: auto;
  }
}

/*** BOOTSTRAP ERGÄNZUNG ***/

.gp-btn-tertiary {
  transition: all 0.5s ease;
  display: inline-block;
  position: relative;
  font-size: 1.1em;
  padding: 10px 20px;
  line-height: initial;
  border-radius: var(--bs-border-radius-xxl);
  color: var(--white);
  background: var(--gp-color-primary);
  text-align: center;
  text-decoration: none !important;
  cursor: pointer;
  background-image: linear-gradient(45deg, var(--gp-color-tertiary-dark), var(--gp-color-tertiary-light), var(--gp-color-tertiary-dark));
  background-size: 500% 400% !important;
  color: var(--white);
}
.gp-btn-tertiary:hover, .gp-btn-tertiary:active, .gp-btn-tertiary:focus {
  background-color: var(--gp-color-primary-dark);
  color: var(--white);
}
.gp-btn-tertiary:hover::after, .gp-btn-tertiary:active::after, .gp-btn-tertiary:focus::after {
  background-color: var(--gp-color-primary-dark);
}
.gp-btn-tertiary::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  transform: scaleX(0);
  transform-origin: 0 50%;
  width: 100%;
  height: inherit;
}
.gp-btn-tertiary:hover {
  background-position: 75% 50%;
}
.gp-btn-tertiary:active, .gp-btn-tertiary:focus {
  transform: scale(0.95);
  transition: 0.1s;
}

.gp-btn-tertiary-invert {
  transition: all 0.5s ease;
  display: inline-block;
  position: relative;
  font-size: 1.1em;
  padding: 10px 20px;
  line-height: initial;
  border-radius: var(--bs-border-radius-xxl);
  color: var(--gp-color-tertiary-dark);
  background: var(--white);
  text-align: center;
  text-decoration: none !important;
  cursor: pointer;
  box-shadow: rgba(0, 0, 0, 0.05) 0 0 8px;
}
.gp-btn-tertiary-invert:hover, .gp-btn-tertiary-invert:active, .gp-btn-tertiary-invert:focus {
  background-color: var(--gp-color-tertiary-light);
  color: var(--white);
}
.gp-btn-tertiary-invert:hover::after, .gp-btn-tertiary-invert:active::after, .gp-btn-tertiary-invert:focus::after {
  background-color: var(--gp-color-tertiary-light);
}


.mw-300 {
  max-width: 300px !important;
}

.mw-400 {
  max-width: 400px !important;
}

.mw-500 {
  max-width: 500px !important;
}

.mw-600 {
  max-width: 600px !important;
}

.min-h-200 {
  min-height: 300px !important;
}

.place-content-center {
  place-content: center !important;
}

.font-impact {
  font-family: "Impact LT Std" !important;
}

.font-primary {
  font-family: "Source Sans Pro", sans-serif !important;
}

.outline-0 {
  outline: 0 !important;
}

.text-tertiary {
  --bs-text-opacity:1;
  color: rgba(var(--bs-tertiary-rgb), var(--bs-text-opacity)) !important;
}

.text-tertiary-dark {
  --bs-text-opacity:1;
  color: rgba(var(--bs-dark-tertiary-rgb), var(--bs-text-opacity)) !important;
}

.text-shadow-dark {
  text-shadow: 0 0 20px black !important;
}

.fs-0 {
  font-size: calc(1.5rem + 1.5vw) !important;
}

.bg-primary-light {
  --bs-bg-opacity:1;
  background-color: rgba(var(--bs-light-primary-rgb), var(--bs-bg-opacity)) !important;
}

.bg-primary-dark {
  --bs-bg-opacity:1;
  background-color: rgba(var(--bs-dark-primary-rgb), var(--bs-bg-opacity)) !important;
}

.bg-secondary-light {
  --bs-bg-opacity:1;
  background-color: rgba(var(--bs-light-secondary-rgb), var(--bs-bg-opacity)) !important;
}

.bg-secondary-dark {
  --bs-bg-opacity:1;
  background-color: rgba(var(--bs-dark-secondary-rgb), var(--bs-bg-opacity)) !important;
}

.bg-tertiary {
  --bs-bg-opacity:1;
  background-color: rgba(var(--bs-tertiary-rgb), var(--bs-bg-opacity)) !important;
}

.bg-tertiary-light {
  --bs-bg-opacity:1;
  background-color: rgba(var(--bs-light-tertiary-rgb), var(--bs-bg-opacity)) !important;
}

.bg-tertiary-dark {
  --bs-bg-opacity:1;
  background-color: rgba(var(--bs-dark-tertiary-rgb), var(--bs-bg-opacity)) !important;
}

.bg-opacity-10 {
  --bs-bg-opacity: 0.1 ;
}

.bg-opacity-25 {
  --bs-bg-opacity: 0.25 ;
}

.bg-opacity-50 {
  --bs-bg-opacity: 0.5 ;
}

.bg-opacity-75 {
  --bs-bg-opacity: 0.75 ;
}

.bg-opacity-100 {
  --bs-bg-opacity: 1 ;
}

.bg-gradient-primary-1 {
  background-image: linear-gradient(45deg, var(--gp-color-primary-dark) 0%, var(--gp-color-primary-light) 100%) !important;
}

.bg-gradient-primary-2 {
  background-image: linear-gradient(45deg, var(--gp-color-primary-dark) 0%, var(--gp-color-primary-light) 50%, var(--gp-color-primary-dark) 100%) !important;
}

.bg-gradient-primary-3 {
  background-image: linear-gradient(45deg, var(--gp-color-primary-light) 0%, var(--gp-color-primary-dark) 50%, var(--gp-color-primary-light) 100%) !important;
}

.bg-gradient-secondary {
  background-image: linear-gradient(60deg, var(--gp-color-secondary-dark) 0%, var(--gp-color-secondary-light) 100%) !important;
}

.bg-gradient-dark-1 {
  background-image: linear-gradient(77deg, var(--black_1), var(--black_2)) !important;
}

.bg-gradient-dark-2 {
  background-image: linear-gradient(180deg, var(--black_3) 0%, rgba(221, 224, 226, 0) 100%) !important;
}

.bg-gradient-light-1 {
  background-image: linear-gradient(77deg, #e7e7e7, #f2f2f2) !important;
}

.bg-gradient-light-2 {
  background-image: linear-gradient(77deg, #e7e7e7, #f2f2f2) !important;
}

.bg-blur-1 {
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
}

.bg-blur-2 {
  -webkit-backdrop-filter: blur(4px);
          backdrop-filter: blur(4px);
}

.bg-blur-3 {
  -webkit-backdrop-filter: blur(6px);
          backdrop-filter: blur(6px);
}

.bg-blur-4 {
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
}

.bg-blur-5 {
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
}

.overflow-x-hidden {
  overflow-x: hidden !important;
}


.hover-shadow-lg {
  box-shadow: 0 0 0 rgba(22, 28, 45, 0);
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}
.hover-shadow-lg:hover {
  box-shadow: 0 2rem 5rem rgba(22, 28, 45, 0.1), 0 0.5rem 1rem -0.75rem rgba(22, 28, 45, 0.05) !important;
  transform: translate3d(0, -5px, 0);
}

.hover-scale {
  transition: transform 0.25s ease;
}
.hover-scale:hover {
  transform: scale(1.05);
}

.transation-300 {
  transition: all 300ms ease-out !important;
}

.overlay {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: rgba(0, 0, 0, 0);
  transition: all 300ms ease;
  opacity: 0;
}
.overlay:hover {
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 1;
}

@media (min-width: 992px) {
  .position-lg-absolute {
    position: absolute !important;
  }
  .rounded-lg-bottom {
    border-bottom-right-radius: var(--bs-border-radius) !important;
    border-bottom-left-radius: var(--bs-border-radius) !important;
  }
  .rounded-lg-top {
    border-top-right-radius: var(--bs-border-radius) !important;
    border-top-left-radius: var(--bs-border-radius) !important;
  }
}
@media (min-width: 768px) {
  .rounded-md-start {
    border-top-left-radius: var(--bs-border-radius) !important;
    border-bottom-left-radius: var(--bs-border-radius) !important;
  }
  .border-md-start {
    border-left: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
  }
}
/* --------------- Header --------------- */
#header {
  position: sticky;
  top: 0;
  z-index: 200;
  background-color: transparent;
  background: var(--white);
  width: 100%;
  border-bottom: 1px solid var(--gp-color-primary);
}
#header * {
  transition: all 250ms ease;
}
#header .logo img {
  max-height: 85px;
  width: auto;
}

/* --------------- Navigation --------------- */
.desktop-menu {
  margin-bottom: 0;
}
.desktop-menu ul.nav {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  text-transform: uppercase;
}
.desktop-menu ul.nav li {
  position: relative;
  list-style: none;
  display: flex;
  align-items: center;
  height: 100px;
  width: -moz-max-content;
  width: max-content;
}
.desktop-menu ul.nav li a {
  position: relative;
  display: block;
  padding: 38px 20px;
  font-weight: 700;
  text-decoration: none;
  text-transform: uppercase;
  color: var(--gp-color-primary);
}
@media (max-width: 1200px) {
  .desktop-menu ul.nav li a {
    padding: 38px 15px;
  }
}
.desktop-menu ul.nav li:hover {
  background-color: rgba(255, 255, 255, 0.1333333333);
}
.desktop-menu ul.nav li ul {
  background: var(--black_4);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin-inline: auto;
  padding-block: 2rem;
  max-width: 1320px;
  position: fixed;
  top: 100px;
  left: 0;
  right: 0;
  transform: translateY(0px);
  visibility: hidden;
  opacity: 0;
}
.desktop-menu ul.nav li ul * {
  transition: all 0ms ease !important;
}
@media (max-width: 1400px) {
  .desktop-menu ul.nav li ul {
    max-width: 1140px;
  }
}
.desktop-menu ul.nav li ul::before {
  content: "";
  position: fixed;
  top: 0;
  bottom: 0;
  left: -100%;
  right: -100%;
  background: var(--black_4);
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
  border-block: 2px solid #eee;
  border-color: var(--gp-color-primary-light);
}
.desktop-menu ul.nav li ul li {
  display: grid;
  padding: 7px;
  width: 100%;
  height: -moz-fit-content;
  height: fit-content;
}
.desktop-menu ul.nav li ul li a {
  padding: 0px;
  font-weight: 700;
  color: var(--gp-color-primary-dark);
}
.desktop-menu ul.nav li ul li ul {
  width: -moz-max-content;
  width: max-content;
  position: initial;
  display: block;
  padding: 0;
  background: transparent;
  margin-inline: unset;
}
.desktop-menu ul.nav li ul li ul::before {
  display: none;
}
.desktop-menu ul.nav li ul li ul li {
  padding: 0;
  color: var(--gp-color-primary-dark);
  transition: all 200ms ease !important;
}
.desktop-menu ul.nav li ul li ul li:hover {
  background-color: var(--white);
}
.desktop-menu ul.nav li ul li ul li a {
  font-weight: 300;
  background: transparent;
  color: var(--gp-color-primary-dark);
}
.desktop-menu ul.nav li:hover ul {
  visibility: visible;
  opacity: 1;
  transform: translateY(0px);
}
.desktop-menu ul.nav li:hover ul li ul {
  visibility: visible;
  opacity: 1;
  transform: translateY(0px);
}

div.mobile-menu-button a {
  color: var(--gp-color-primary);
}

div.mobile-menu {
  display: none;
  position: absolute;
  top: 93px;
  right: 0;
  left: 0;
  background-color: var(--white);
}
div.mobile-menu ul.nav {
  list-style: none;
  position: relative;
  list-style: none;
  margin: 0;
  padding: 0;
  flex-direction: column;
}
div.mobile-menu ul.nav li {
  border-top: 1px solid var(--black_3);
  background-color: var(--white);
  text-transform: uppercase;
  margin: 0px;
  text-align: center;
}
div.mobile-menu ul.nav li a {
  color: var(--gp-color-primary-dark);
  display: block;
  font-size: initial;
  white-space: inherit;
}
div.mobile-menu ul.nav li > ul {
  display: none;
}

li:hover, li:active, li:focus {
  background-color: rgba(255, 255, 255, 0.2);
  background-color: linear-gradient(45deg, var(--gp-color-primary-dark) 0%, var(--gp-color-primary-light) 50%, var(--gp-color-primary-dark) 100%);
}
li:hover a, li:active a, li:focus a {
  text-decoration: none;
}

li.nav-selected > a {
  font-weight: bold !important;
  color: var(--bs-secondary) !important;
}

#header.sticky .container .row .logo img {
  max-height: 69px;
}
#header.sticky .container .row .desktop-menu ul.nav li {
  height: 85px;
}
#header.sticky .container .row .desktop-menu ul.nav li a {
  padding: 30px 20px;
  color: var(--gp-color-primary);
}
#header.sticky .container .row .desktop-menu ul.nav li ul {
  display: none;
}

/* --------------- Back to top ---------------- */
#back_to_top {
  position: fixed;
  height: auto;
  top: 85%;
  right: 25px;
  margin: 0;
  z-index: 1000;
  transition: opacity 0.3s ease-in-out;
  pointer-events: auto;
  filter: alpha(opacity=100);
  width: 51px;
  height: 51px;
  line-height: 47px;
  color: var(--black_1);
  background-color: var(--gp-color-secondary);
  text-align: center;
  transition: color 0.3s ease-in-out, background-color 0.3s ease-in-out, border-color 0.3s ease-in-out;
  box-sizing: border-box;
  border-radius: 25px;
  opacity: 0;
  transform: translateY(50px);
  transition: all 0.3s ease;
}
#back_to_top:hover {
  background-color: var(--gp-color-secondary-dark);
  color: var(--white);
}

.showBTP {
  opacity: 0.5 !important;
  transform: translateY(0) !important;
}

#back_to_top:hover {
  opacity: 0.9;
}

/* --------------- Footer --------------- */
.footer-area {
  font-family: "Source Sans Pro", sans-serif;
}
.footer-area :is(h1, h2, h3, h4, h5) {
  color: var(--white);
  text-transform: uppercase;
}
.footer-area :is(a) {
  text-decoration: none;
}
.footer-area *:not(.ccm-edit-mode-inline-command-move *, .ccm-area-footer-handle *, input.form-control, .ccm-style-customizer-toolbar *) {
  color: var(--white);
}

/* --------------- system ui fixes --------------- */
.ccm-toolbar-visible .desktop-menu ul.nav li ul {
  top: 149px;
}
.ccm-toolbar-visible .scrolled .desktop-menu ul.nav li ul {
  top: 100px;
}

/* --------------- 
Grid Container
--------------- */

.grid_container {
  display: grid;
  grid-template-rows: auto;
  grid-column-gap: 30px;
}

.grid_container_spalte {
  position: relative;
}

.grid_container_2_spalten {
  grid-template-columns: repeat(2, 1fr);
}

.grid_container_3_spalten {
  grid-template-columns: repeat(3, 1fr);
}

.grid_container_4_spalten {
  grid-template-columns: repeat(4, 1fr);
}

.grid_container_5_spalten {
  grid-template-columns: repeat(5, 1fr);
}

.grid_container_2_spalten_vertikal {
  grid-template-columns: repeat(1, 1fr);
  grid-template-rows: repeat(2, 1fr);
}
.grid_container_2_spalten_vertikal .grid_container_spalte_vertikal_1 {
  grid-row: 1/2;
}
.grid_container_2_spalten_vertikal .grid_container_spalte_vertikal_2 {
  grid-row: 2/3;
}
@media (min-width: 992px) {
  .grid_container_2_spalten_vertikal .grid_container_spalte_vertikal_2 {
    margin-top: -60px;
  }
}

@media (max-width: 1200px) {
  .grid_container_5_spalten {
    grid-template-columns: repeat(4, 1fr);
  }
  .grid_container_4_spalten {
    grid-template-columns: repeat(2, 1fr);
  }
  .grid_container_3_spalten {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 992px) {
  .grid_container_5_spalten {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .grid_container {
    display: grid !important;
    grid-template-columns: auto;
    gap: 2rem;
  }
}