:root {
  --tp-body-font-family: 'Open Sans', sans-serif, 'Arial', sans-serif;
  --tp-body-font-style: normal;
  --tp-body-font-size: 18px;
  --tp-body-font-weight: 400;
  --tp-body-line-height: 1.5;

  /* basic colors */
  --bs-white: #fff;
  --bs-light-grey-bg: #F8F8F8;
  --bs-grey: #F8F8F8;
  --bs-dark-grey: #262628;
  --bs-darker-grey: #1C1C1C;
  --bs-black: #000;

  --bs-background-color: #161616;

  /* Logo Colors */
  --bs-logo-blau-hell: #189CD9;
  --bs-logo-blau-dunkel: #0385BF;
  --bs-logo-green: #00988A;
  --bs-logo-rosa: #E40A7D;
  --bs-logo-lila: #322D62;
  --bs-logo-gelb: #FEEB17;
  --bs-logo-orange: #EE715B;
  
}
::selection { 
    color: var(--bs-grey);
    background: var(--bs-black);
  }
::-moz-selection { 
    color: var(--bs-grey);
    background: var(--bs-black);
  }

body {
    font-family: var(--tp-body-font-family);
    font-size: var(--tp-body-font-size);
    font-weight: var(--tp-body-font-weight);
    line-height: var(--tp-body-line-height);
}

h1 {
    font-family: var(--tp-body-font-family);
    font-size: 60px;
    font-weight: 700;
    line-height: 1.5;
}

h2 {
    font-family: var(--tp-body-font-family);
    font-size: 45px;
    font-weight: 700;
    line-height: 1.5;
}

h3 {
    font-family: var(--tp-body-font-family);
    font-size: 35px;
    font-weight: 600;
    line-height: 1.5;
}

h4 {
    font-family: var(--tp-body-font-family);
    font-size: 25px;
    font-weight: 700;
    line-height: 1.5;
}

h5 {
    font-family: var(--tp-body-font-family);
    font-size: 22px;
    font-weight: 700;
    line-height: 1.5;
}

h6 {
    font-family: var(--tp-body-font-family);
    font-size: 20px;
    font-weight: 700;
    line-height: 1.5;
}
.font-big {
  font-size: 25px;
}
.font-blue {
  color: var(--bs-logo-blau-hell);
}
.offcanvas-menu .offcanvas-inner ul.menu > li ul.menu-child {
  display: block !important;
}
.menu-toggler {
  display: none !important;
}

p {
  
}

a {
  
}

a:hover {
  
}
a:active {
  
}
a:focus {
  
}

.field1,
.field2,
.field3,
.field4,
.field5 {
  margin: 5px 0 5px 0;
}
#field6 {
  margin: 15px 0 0 0;
}

/* text trennung */
.hyphenate {
  word-wrap: break-word;
  overflow-wrap: break-word;

-webkit-hyphens: auto;
   -moz-hyphens: auto;
        hyphens: auto;
}

/* svg logo (change logo in template to text logo) */
span.logo {
  display:none !important;
}
#sp-logo .sp-module {
  margin-left: 0px !important;
}

/* menu last child same space */
.sp-megamenu-parent>li:last-child>a {
    padding: 0px 15px 0px 15px !important;
}

/* Side Buttons */
.sp-module.fixed-right {
    position: fixed;
    top: 250px;
    right: 0;
    z-index: 9999;
}
.desigbed-by {
  text-align: center;
  font-size: 14px;
}
#sp-bottom, #sp-designed-by {
  color: var(--bs-black);
  background: var(--bs-light-grey-bg);
}
#sp-bottom {
  font-size: 16px;
  line-height: 1.5;
}
#sp-footer {
    font-size: 14px;
    padding: 0;
    background: var(--bs-white) !important;
}
#sp-footer a, 
#sp-bottom a,
#sp-designed-by a {
  color: var(--bs-black);
}
#sp-footer a:hover, 
#sp-footer a:active, 
#sp-footer a:focus, 
#sp-bottom a:hover, 
#sp-bottom a:active, 
#sp-bottom a:focus,
#sp-designed-by a:hover,
#sp-designed-by a:active,
#sp-designed-by a:focus {
  color: var(--bs-logo-blau-hell);
}

.sppb-carousel-inner {
  position: relative;
  overflow: hidden;
  width: 100%;
  border-radius: 30px;
}

/* marqee logos und tags */
.marqee.logos img {
    width: 200px;
    height: 100px;
    padding: 0 25px;
}

.tags div {
    font-size: 16px;
    color: #fff;
}

.marqee {
    padding: 0;
    margin: 0;
    display: flex;
    white-space: nowrap;

    height: auto;
    align-items: center;
    overflow: hidden;
    position: relative;
    width: 100%;
  -webkit-mask-image: linear-gradient( var(--mask-direction, to right), hsl(0 0% 0% / 0), hsl(0 0% 0% / 1) 20%, hsl(0 0% 0% / 1) 80%, hsl(0 0% 0% / 0) );
  mask-image: linear-gradient( var(--mask-direction, to right), hsl(0 0% 0% / 0), hsl(0 0% 0% / 1) 20%, hsl(0 0% 0% / 1) 80%, hsl(0 0% 0% / 0) );
}

.marqee {
    /*   padding-left: 0.5rem; */
    font-family: sans-serif;
    font-weight: 400;
    color: #010101;
}

.marqy-inner {
    -ms-overflow-style: none;
    display: flex;
    scrollbar-width: none;
}

.marqee[data-direction=left] .marqee-content {
    animation-name: loop_left;
}

.marqee[data-direction=right] .marqee-content {
    animation-name: loop_right;
}

.marqee-content {
    animation-iteration-count: infinite;
    animation-play-state: running;
    animation-timing-function: linear;
    animation-duration: 28s;
    display: flex;
    flex: 1 0 auto;
    will-change: transform;
}

/*
        .marqee:hover .marqee-content {
            animation-play-state: paused;
        }
*/
.marqee-content div {
    padding: 0 2rem
}

@keyframes loop_left {
    0% {
        transform: translate3d(0, 0, 0)
    }

    100% {
        transform: translate3d(-100%, 0, 0)
    }
}

@keyframes loop_right {
    0% {
        transform: translate3d(-100%, 0, 0)
    }

    100% {
        transform: translate3d(0%, 0, 0)
    }
}

/* ---------------------------------------- LARGE DESKTOPS ---------------------------------------- */
@media (min-width: 1399.98px) {
  
}

/* ---------------------------------------- DESKTOPS ---------------------------------------- */
@media only screen and (max-width: 1199.98px) {
  h1 {
        font-size: 50px;
    }

    h2 {
        font-size: 40px;
    }

    h3 {
        font-size: 35px;
    }

    h4 {
        font-size: 25px;
    }

    h5 {
        font-size: 22px;
    }

    h6 {
        font-size: 20px;
    }
}

/* ---------------------------------------- TABLETS ---------------------------------------- */
@media only screen and (max-width: 991.98px) {
  body {
        font-size: 16px;
    }
  h1 {
        font-size: 55px;
    }

    h2 {
        font-size: 35px;
    }

    h3 {
        font-size: 30px;
    }

    h4 {
        font-size: 25px;
    }

    h5 {
        font-size: 22px;
    }

    h6 {
        font-size: 20px;
    }
  p {
    
  }
  .font-big {
  font-size: 20px;
}
      .logo-svg,
    .logo-image-phone {
        height: 40px !important;
    }
  #sp-header {
        height: 50px !important;
    }
 #sp-footer, #sp-footer1, #sp-footer2 {
    justify-content: center;
    text-align: center !important;
  }
}

/* ---------------------------------------- LANDSCAPE PHONE ---------------------------------------- */
@media only screen and (max-width: 767.98px) {
  body {
        font-size: 16px;
    }

    h1 {
        font-size: 45px;
    }

    h2 {
        font-size: 28px;
    }

    h3 {
        font-size: 25px;
    }

    h4 {
        font-size: 22px;
    }

    h5 {
        font-size: 20px;
    }

    h6 {
        font-size: 18px;
    }
  
}

/* ---------------------------------------- PORTRAIT PHONE ---------------------------------------- */
@media only screen and (max-width: 575.98px) {
  body {
        font-size: 16px;
    }

    h1 {
        font-size: 35px;
    }

    h2 {
        font-size: 28px;
    }

    h3 {
        font-size: 25px;
    }

    h4 {
        font-size: 22px;
    }

    h5 {
        font-size: 20px;
    }

    h6 {
        font-size: 18px;
    }
  #sp-header {
    height: 50px;
  }
}
/* safari browser fix for background images (set class safari-only to background section) */
@supports (hanging-punctuation: first) and (font: -apple-system-body) and (-webkit-appearance: none) {
    .safari-only {
        background-attachment: scroll !important;
    }
}