/* work-sans-regular - latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/work-sans-v19-latin-ext-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* work-sans-500 - latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/work-sans-v19-latin-ext-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* work-sans-700 - latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/work-sans-v19-latin-ext-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-condensed-700 - latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto Condensed';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/roboto-condensed-v27-latin-ext-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}


/* roboto-300 - latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/roboto-v30-latin-ext-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-regular - latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/roboto-v30-latin-ext-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-500 - latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/roboto-v30-latin-ext-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-700 - latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/roboto-v30-latin-ext-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-900 - latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 900;
  src: url('../fonts/roboto-v30-latin-ext-900.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}


/* oswald-600 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/oswald-v53-latin-600.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}





/*Allgemein*/
:root {
    --sym-rot: #CC071A;
    --sym-grau: #F2F2F2;
    --sym-hell: #dfdfdf;
    --sym-weiss: #fff;
    --sym-dunkel: #575757;
    --sym-text: #000;

    --sym-corner: .3rem;
    --sym-shadow: 0 6px 5px -5px rgba(0,0,0,0.16);

    --sym-roboto:'Roboto', sans-serif; 
    --sym-work: 'Work Sans', sans-serif; 
    --sym-condensed: 'Roboto Condensed', sans-serif;
}

html, body {
  height: 100%;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  scroll-behavior:smooth;
}
body {
  font-family: var(--sym-work);
  font-weight:400;
  font-style: normal;
  color: var(--sym-text);
  font-size: 1.2rem;
}
#mmenu { visibility: hidden; }
#mmenu.mm-menu--opened { visibility: visible; }

header.h-1, header.h-2 {
  display: flex;
  flex-direction:column;
}
h1, h2 {
    font-family: var(--sym-condensed);
    font-weight: 700;
    padding-bottom: 3.5rem;
    font-size: 2.5rem;
  order:2;
  margin-bottom:0;
}
h1 + p {
    font-size: 1.3rem;
}
h2.subheader, h3.subheader, h4 {
    font-family: var(--sym-work);
    font-size: 1.7rem;
    font-weight: 400;
    padding-bottom: .5rem;
    color: var(--sym-text) !important;
    order:1;
    line-height:2.3rem;
}
header.text-center h3.subheader, header.text-center h4 {
  text-align:center;
}

a {
    color:var(--sym-text);
}
a.active {
    font-weight:900;
}
ul {
  list-style:none; 
  padding-left:1.1rem;
}
li::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius:100%;
  display: inline-block;
  background-color: var(--sym-rot);
  margin-right: 10px;
  margin-bottom: 2px;
  margin-left: -0.9em;
  background-repeat:no-repeat;
}

.navicon {
    position: relative;
    z-index: 100;
    display: block;
    height: 33px;
    width: 34px;
    cursor: pointer;
    float: right;
    margin-top: 5px;
}
.navicon span {
    position: absolute;
    width: 34px;
    height: 3px;
    left: 0px;
    border-radius: 2px;
    background-color: var(--sym-rot);
    transition: all .3s ease-in-out;
}
.navicon span.n1 {
    top: 0px;
}
.navicon span.n2 {
    top: 10px;
}
.navicon span.n3 {
    top: 20px;
}

.lead {
  font-size: 2.1rem;
  font-weight: 600;
  font-family: var(--sym-condensed);
}

.btn {
    text-transform:uppercase;
    font-family:var(--sym-roboto);
    font-weight: 600;
    font-size:1rem;
    border-radius:var(--sym-corner);
    padding:.5rem 2rem;
    letter-spacing: 1px;
    transition:.5s;
    border:1px solid var(--sym-text);
  width:fit-content;
}
.btn:hover {
  color:var(--sym-rot);
  border:1px solid var(--sym-rot);
}
.btn-rot {
    border: 1px solid var(--sym-weiss);
    color:var(--sym-weiss);
    background-color:var(--sym-rot);
    margin-top: 3rem;
}
.btn-rot:hover {
    border:1px solid var(--sym-rot);
    background-color:var(--sym-weiss);
    color:var(--sym-rot);
    transition:.5s;
}
.btn-light {
  color:var(--sym-weiss);
  border:1px solid var(--sym-weiss);
  background-color:transparent;
  transition:.5s;
}
.btn-light:hover {
  color:var(--sym-text);
  border:1px solid var(--sym-weiss);
  background-color:var(--sym-weiss);
  mix-blend-mode: screen;
  transition:.5s;
}
.btn-success {
  background-color: transparent;
color: var(--sym-rot);
border: 1px solid var(--sym-rot);
margin-right: 1rem;
}
.btn-success:hover {
  background-color:var(--sym-rot);
  color:var(--sym-weiss);
  border:1px solid var(--sym-weiss);
}
hr {
  opacity:1;
  border-top:1px solid var(--sym-hell);
}
.mt-6 {
    margin-top:4rem;
}
.pt-6 {
    padding-top:4rem;
}
.mb-6 {
    margin-bottom:4rem;
}
.p-6 {
  padding:4rem;
}
.pb-6 {
    padding-bottom:4rem;
}
.p-8 {
  padding:6rem;
}
.pt-8 {
  padding-top:6rem;
}
.pb-8 {
  padding-bottom:6rem;
}
.mt-8 {
  margin-top:6rem;
}
.mb-8 {
  margin-bottom:8rem;
}
.mt-13 {
    margin-top:13rem;
}
.pt-13 {
    padding-top:13rem;
}
.mb-13 {
    margin-bottom:13rem;
}
.pb-13 {
    padding-bottom:13rem;
}
.radius-top {
  border-top-left-radius: var(--sym-corner);
  border-top-right-radius: var(--sym-corner);
}
p {
	hyphens: auto;
}

#page-content {
/*  position:relative; */
padding-top: 70px;
}
#page-content:before {
  content:"";
  background: linear-gradient(rgb(232,232,232), rgb(255, 255, 255));
  width: 100vw;
  height: 100vh;
  z-index: -1;
  position: absolute;
  top: 0;
  left: 0;
}

/*Header*/
#page-wrapper > header {
    box-shadow: var(--sym-shadow);
    -webkit-box-shadow: var(--sym-shadow);
    -moz-box-shadow: var(--sym-shadow);
    background-color: var(--sym-weiss);
    height:70px;
    width: 100vw;
    z-index:100;
	top:0;
    position: fixed;
}
#logo {
	display: flex;
    max-width: 400px;
    align-items: center;
	background-color: var(--sym-weiss);
    padding: 2.6rem 2rem .6rem 2rem;
    border-radius: var(--sym-corner);
    position: absolute; 
	box-shadow: var(--sym-shadow);
    -webkit-box-shadow: var(--sym-shadow);
    -moz-box-shadow: var(--sym-shadow);
    margin-left:-2rem;
}
#logo img {
	width: 255px;
}
.navi {
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: end;
    font-size: .9rem;
    padding-top: .5rem;
    padding-right: 5rem;
    font-weight: 500;
    font-family: var(--sym-roboto);
}
header ul {
    list-style: none;
    padding: 0;
    display: flex;
    justify-content: end;
    margin: 0;
    height: 100%;
    align-items: center;
}
header li{
    padding: 0 40px;
    text-transform: uppercase;
    text-decoration: none;
    cursor: pointer;
    transition:.5s;
}
header li::before {
  display:none;
}
header li.active, header li:hover {
    color: var(--sym-rot);
    transition:.5s;
}
header li:last-child {
    font-size:inherit;
    border: 1px solid var(--sym-rot);
    padding: .3rem 1.1rem;
    border-radius: .5rem;
    font-weight: inherit;
    margin-left: 4rem;
}
header li:last-child:hover {
  border: 1px solid var(--sym-weiss);
  background-color:var(--sym-rot);
}
header li:last-child:hover a {
  color:var(--sym-weiss);
  transition:.5s;
}
header a {
    text-decoration:none;
  transition:.5s;
}
header a:hover, header li.active a {
    color: var(--sym-rot);
    transition:.5s;
}
.suche {
 /*   max-width: 1rem;
    max-height: 1rem; */
    margin-left: 3rem;
  width: 36px;
  height: 36px;
  padding: 10px 10px;
  cursor: pointer;
}
.navi-full {
    position:fixed;
    z-index:3;
    margin-top: 70px;
    top:-100vh;
    transition:.5s;
}
.navi-full.open {
    top:0;
    transition:.5s;
}
.navi-full h5, .navi-full h5 a {
    font-family: var(--sym-condensed);
    text-align: left;
    padding-bottom: .5rem;
    font-weight: 700;
    font-size: 1.3rem;
}
.navi-full p {
    font-size: .8rem;
    line-height: 1.1rem;
}
.navi-inhalt > div {
  background-color:var(--sym-weiss);
    box-shadow: 0 0px 5px rgba(0, 0, 0, 0.16);
  -webkit-box-shadow: 0 0px 5px rgba(0, 0, 0, 0.16);
  -moz-box-shadow: 0 0px 5px rgba(0, 0, 0, 0.16);
}
.navi-inhalt > div:first-child {
  padding-top: 1.3rem;
}
.navi-inhalt > div:last-child {
    padding-bottom:2rem;
}
.navi-inhalt .d-flex {
  padding:0;
}
.spalte {
    border-right: 1px solid var(--sym-hell);
    width: 333px;
    background-color:var(--sym-weiss);
    padding: 0 1.8rem 0 1.8rem;
}
.spalte > div {
    height: 100%;
}
.spalte:last-child {
    border-right:none;
}
.spalte a {
    font-size: .9rem;
    text-decoration: none;
    font-weight: 600;
    line-height: .9rem;
    font-family: var(--sym-roboto);
    transition:.5s;
}
.spalte a:hover {
    color: var(--sym-rot);
    transition:.5s;
}

.spalte a + br {
  margin-bottom: 0.7rem;
}

.drei-spalten .spalte {
  width: 443px;
}



.slider {
  /*  background: rgb(232,232,232);
    background: linear-gradient(rgb(232,232,232), rgb(255, 255, 255));
    padding-top:13vh;
    padding-top: 4vh;*/
    margin-top: 70px;
}
.slider img {
    max-height: 580px;
  width: auto;
}
.slider .btn {
  background-color:var(--sym-rot);
  color:var(--sym-weiss);
  padding: .5rem 2rem;
  margin-top:3.5rem;
  border:none;
  transition:.5s;
  border:1px solid var(--sym-rot);
}
.slider .btn:hover {
  transition:.5s;
  background-color:transparent;
  color:var(--sym-rot);
  border: 1px solid var(--sym-rot);
}

.carousel { max-width: none!important;}

.carousel-caption {
    position: inherit;
  padding-bottom:0!important;
}
.carousel-caption p:last-of-type {
  text-align:left;
}
.carousel-indicators {
    position:inherit;
    margin: 50px 0 70px 0;
}
.carousel-indicators [data-bs-target] {
    width: .5rem;
    height: .5rem;
    margin-right: .5rem;
    margin-left: .5rem;
    background-color: var(--sym-dunkel);
    border-radius: 100%;
    border:0;
    opacity: .2;
}
.carousel-indicators [data-bs-target].active {
    opacity:1;
}
h3 {
    font-family: var(--sym-roboto);
    font-weight: 300;
    color:  var(--sym-text);    
    text-align: left;
    font-size: 2.4rem;
    line-height: 3.3rem;
}
h3 strong {
    font-weight: 500;
}
section.background-image {
  padding-bottom:0!important;
  background-position:top;
}
.background-image header {
  filter: drop-shadow(0 0 3rem black);
}
.background-image .bg-weiss header {
  filter:none;
}
.background-image, .background-image h3.subheader {
    color: var(--sym-weiss)!important;
    text-align:center;
}
.background-image p {
    font-size: 1.3rem;
  filter: drop-shadow(0 0 1rem black);
}
.background-image p:nth-of-type(2) {
  filter:none;
}
.bg-grau {
    background-color: var(--sym-grau);
    padding: 5rem 0;
}
.bg-rot {
    background-color: var(--sym-rot);
    color:var(--sym-weiss);
}
.bg-rot h3.subheader, h4 {
  color:var(--sym-weiss)!important;
}
.bg-weiss {
     background-color: var(--sym-weiss);
    opacity:.9;
  height:100%;
  color:var(--sym-text);
  text-align:left;
}
.bg-weiss h2{
 padding-bottom:2rem; 
}
.bg-weiss h3.subheader {
    color:var(--sym-text)!important;
  text-align:left!important;
}
.bg-weiss p {
  filter:none;
}

/*Elemente*/
.services > div {
    background-color: var(--sym-rot);
    color:var(--sym-weiss);
    border-radius: var(--sym-corner);
    padding: 2rem;
    padding-bottom: 8rem;
    max-width: 410px;
    font-size: 1.1rem;
    line-height: 1.9rem;
    position: relative;
}
.services img {
    max-width: 150px;
    margin: auto;
    display: block;
    padding-bottom: 30px;
}
.services h2 {
    font-family: var(--sym-roboto);
    font-weight:600;
    font-size: 1.9rem;
    padding-bottom: 2rem;
}
.services p:last-of-type {
    font-size: .8rem;
    line-height: 1.5rem;
}
.services p:first-of-type {
    margin-bottom: .5rem;
}
.services > div > div:last-child {
  position: absolute;
  bottom: 3rem;
}
.services .btn {
  padding: .5rem 2rem;
  background-color: var(--sym-weiss);
  color: var(--sym-rot);
  border:1px solid var(--sym-weiss);
  transition:.5s;
}
.services .btn:hover {
  transition:.5s;
  background-color:transparent;
  color:var(--sym-weiss);
  border: 1px solid var(--sym-weiss);
}
.grid {
    display: grid;
    grid-template-columns: auto auto auto;
    grid-gap: 3rem;
    padding-bottom:3rem;
}
.grid-item {
color: var(--sym-text);
  display: flex;
  min-height: 200px;
  box-shadow: var(--sym-shadow);
  -webkit-box-shadow: var(--sym-shadow);
  -moz-box-shadow: var(--sym-shadow);
  margin-left: auto;
  margin-right: auto;
  hyphens: auto;
  text-shadow:none;
}
.grid-item header {
  filter:none;
}
.grid-item div:first-child{
    background-color: var(--sym-weiss);
    opacity:.9;
    padding: 5rem 1rem 3rem 3rem;
    border-top-left-radius: var(--sym-corner);
    border-bottom-left-radius: var(--sym-corner);
}
.grid-item p {
    font-family:var(--sym-roboto);
    font-weight: 400;
    font-size: 1.1rem;
    line-height: 1.9rem;
    text-align: left;
  filter:none;
}
.grid-item p:last-child {
    margin:0;
}
.grid-item div:last-child{
    background-color: var(--sym-weiss);
    mix-blend-mode: screen; /* This makes the cutout text possible */
    opacity:.9;
    padding: 0 2rem 0 1rem;
    border-top-right-radius: var(--sym-corner);
    border-bottom-right-radius: var(--sym-corner);
}
h5 {
    font-family: 'Oswald';
    font-style: normal;
    font-weight: 600;
    font-size:11rem;
    text-align:right;
}
.grid.zahlen {
  padding-bottom:6rem;
}
.grid.zahlen .grid-item {
  display:table;
}
.grid.zahlen .grid-item div:first-child {
  padding: 2.5rem 2.5rem 1rem 2.5rem;
  border-top-left-radius: var(--sym-corner);
  border-top-right-radius: var(--sym-corner);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  mix-blend-mode:screen;
}
.grid.zahlen .grid-item div:last-child {
  mix-blend-mode: normal;
  padding: 0 2.5rem 2.5rem 2.5rem;
  border-bottom-left-radius: var(--sym-corner);
  border-bottom-right-radius: var(--sym-corner);
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.grid.zahlen h5 {
  font-size: 7rem;
  text-align: center;
  margin-bottom:0;
  font-family: var(--sym-work);
}
.grid.standorte {
  justify-content: center;
}
.grid.standorte .grid-item {
  min-height:auto;
}
.grid.standorte .grid-item div:last-child {
  opacity:1!important;
  padding: 2.5rem 2.5rem 2.5rem 1.5rem;
  mix-blend-mode: normal;
}
.grid.standorte .grid-item div:first-child {
  mix-blend-mode:normal;
  padding:0;
  opacity:1;
}
.grid.standorte .grid-item .gallery {
  padding: 2.5rem 0 2rem 2.5rem !important;
}
.grid.standorte .grid-item p {
  margin-bottom: 0;
}


footer {
    background-color: var(--sym-hell);
    padding:4rem 0 7rem 0;
    font-family: var(--sym-roboto);
}
footer strong {
    padding-bottom:2rem;
    display:block;
}
footer a { text-decoration: none; }
footer a:hover, footer a:focus { text-decoration: none; color: var(--sym-rot) }


h2.accordion-header {
	padding-bottom: 0;
	font-family: var(--sym-work);
}
h2.accordion-header span {
	color: var(--sym-rot);
	font-weight: 700;
}

button.accordion-button {
	font-size: 1.2rem;
	display: block;
}

button.accordion-button::after {
position: absolute;
right: 20px;
bottom: 17px;
}

.accordion-button:focus {
	border-color:transparent;
	box-shadow: none;
}

.accordion-button:not(.collapsed) {
	background-color: var(--sym-hell);
	color: #000000;
}

.swiper {
  overflow:clip!important;
  overflow-clip-margin:1rem;
}
.swiper .card {
  border:none;
  background-color:var(--sym-rot);
}
.swiper .card-body {
  position: absolute;
bottom: 0;
}
.swiper .card-title {
  text-decoration:none;
  color:var(--sym-weiss);
  font-weight:700;
  font-family: var(--sym-work);
  text-transform:uppercase;
  font-size:1.7rem;
  padding-bottom:0;
  text-shadow:none;
}
.swiper-button-next, .swiper-button-prev {
  color: var(--sym-rot)!important;
  text-shadow: none!important;
  background-color: var(--sym-weiss);
  padding: 1.5rem;
  border-radius: 100%;
  border: 1px solid var(--sym-rot);
}
.swiper-button-next::after, .swiper-button-prev::after {
  font-size:2rem!important;
}
.swiper-button-prev {
  left:var(--swiper-navigation-sides-offset,-1rem)!important;
}
.swiper-button-next {
  right: var(--swiper-navigation-sides-offset,-1rem)!important;
}
.swiper-slide img {
  transition:.5s;
}
.swiper-slide img:hover {
  opacity:.3;
  transform: scale(1.1);
  transition:.5s;
}
/* Safari 11+ */
@supports (hanging-punctuation: first) and (-webkit-appearance: none) {
    .swiper-button-prev { 
      left:var(--swiper-navigation-sides-offset,10px)!important;
    }
    .swiper-button-next {
      right: var(--swiper-navigation-sides-offset,10px)!important;
    }
}

.form-control {
padding: .5rem .75rem;
border-radius: .5rem;
margin-top: 2rem;
  border: 1px solid var(--sym-hell);
}
.bg-rot .form-control {
  border:none;
}
.form-control::placeholder {
color: var(--sym-dunkel);
text-transform: uppercase;
font-size: .8rem;
}
input.btn, input.btn:hover {
padding: .5rem 2rem;
background-color: var(--sym-rot);
color: var(--sym-weiss);
border: none;
  margin-top: 2rem;
}
.bg-rot input.btn {
  background-color: var(--sym-weiss);
color: var(--sym-rot);
  border:1px solid var(--sym-weiss);
}
.bg-rot input.btn:hover {
  background-color:transparent;
  color:var(--sym-weiss);
}
.checkbox {
  margin-top:4rem;
}
.checkbox label {
  padding-left: 2.5rem;
  cursor: pointer;
}
[type="checkbox"] {
  -webkit-appearance: none;
  display: inline;
}
label [type="checkbox"]::before {
    content: "";
  width: 1.5rem;
  height: 1.5rem;
  border-radius: .2rem;
  border: 1px solid var(--sym-rot);
  margin-left: -2.5rem;
  display: block;
  position: absolute;
  cursor: pointer;
}
label [type="checkbox"]:checked::before {
  box-shadow: inset 0px 0px 0px 3px var(--sym-weiss);
  background-color: var(--sym-rot);
}
.bg-rot label [type="checkbox"]::before {
  border: 1px solid var(--sym-weiss);
}
.bg-rot label [type="checkbox"]:checked::before {
  box-shadow: inset 0px 0px 0px 3px var(--sym-rot);
  background-color: var(--sym-weiss);
}
.tx-powermail .powermail_fieldset .powermail-errors-list > li {
color: var(--sym-weiss);
padding: 0;
}
.tx-powermail .powermail_fieldset .powermail-errors-list > li::before {
  display:none;
}
.tx-powermail .powermail_fieldset .powermail-errors-list, .tx-powermail .powermail_fieldset .powermail_field_error_container .powermail-errors-list {
background-color: transparent;
border: none;
}
.tx-powermail .powermail_fieldset .powermail_field_error, .tx-powermail .powermail_fieldset div.error {
background-color: var(--sym-weiss);
border: none;
}
.tx-powermail .powermail_fieldset .powermail_field_error.form-control::placeholder {
  color: var(--sym-rot);
}
.tx-powermail .powermail_fieldset .checkbox.powermail_field_error {
color: var(--sym-rot);
background-color: transparent;
border: none;
  padding:0;
}
.checkbox.powermail_field_error label [type="checkbox"]::before {
  border: 1px solid var(--sym-rot);
}
.tx-powermail .powermail_fieldset .powermail_field_error_container .powermail-errors-list > li {
padding-left: 0;
  color: var(--sym-rot);
margin-left: 2.5rem;
font-weight: 600;
}
.bg-rot .tx-powermail .powermail_fieldset .checkbox.powermail_field_error, .bg-rot .tx-powermail .powermail_fieldset .powermail_field_error_container .powermail-errors-list > li {
  color:var(--sym-weiss);
}
.bg-rot .checkbox.powermail_field_error label [type="checkbox"]::before {
  border: 1px solid var(--sym-weiss);
}
.dp--cookie-check [type="checkbox"] {
  -webkit-appearance: auto;
}
.dp--cookie-check label [type="checkbox"]::before {
  display:none;
}
.karriere.swiper, .zitate.swiper {
  overflow:hidden!important;
}
.karriere.swiper .card,  .zitate.swiper .card {
  background-color: var(--sym-weiss);
  opacity:.9;
  height:100%;
  color:var(--sym-text);
  text-align:left;
  border-radius: var(--sym-corner)!important;
  height:auto;
}
.karriere.swiper .card-body, .zitate.swiper .card-body {
  position:inherit;
  padding:3rem;
}
.karriere.swiper h2 {
  font-size:2rem;
  font-family:var(--sym-roboto);
  padding-bottom:0;
  color: var(--sym-text);
  text-transform: none;
  padding-bottom:1.5rem;
  line-height:2rem;
}
.zitate.swiper h2 {
  font-size: 2.5rem;
  color: var(--sym-rot);
  font-family: var(--sym-condensed);
  text-transform: none;
  padding-bottom: 1rem;
}
.karriere.swiper span:last-child {
  font-weight:400;
  font-size:1.6rem;
}
.karriere.swiper span:first-child {
  font-weight:400;
  font-size:1.3rem;
}
.karriere.swiper p:first-of-type {
  font-weight: 500;
  line-height: 1.8rem;
  align-items: center;
  display: grid;
  grid-template-columns: 50px auto;
}
.karriere.swiper p:first-of-type::before {
  content:"";
  width:50px;
  height:50px;
  background-image: url(../images/standort.svg);
  background-repeat:no-repeat;
  display:block;
}
.swiper p {
  filter:none;
}
.zitate strong {
  font-size:1.1rem;
}
.swiper-pagination-bullet {
  background-color:var(--sym-weiss)!important;
}
.swiper-pagination-bullet.swiper-pagination-bullet-active {
  background:var(--sym-dunkel)!important;
}

.benefits .even {
  margin-top:-50px;
}
.benefits .even p:first-of-type {
  padding-top:2rem;
}

.fakten .odd {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
.fakten figure {
  display:flex;
}
.fakten img {
  width: 30px;
  height:30px;
}
.fakten .image-caption {
  padding-left:1rem;
  font-size: 1.2rem;
}

.mm-blocker {
  position: fixed;
}


/*-------------- SUCHE OVERLAY ------------- */

.tx-kesearch-pi1 {
  font-family: var(--sym-roboto)!important;
  color: var(--bs-black);
}

.search_overlay {
	width: 100%;
	height: 100vh;
  	background: linear-gradient(rgb(212,212,212), rgb(255, 255, 255));
  	position: absolute;
	top:0;
	display:none;
	align-items: center;
	animation-duration: 1s;
  	animation-name: slidein;
  z-index: 150;
}
.search_overlay.visible {
	display:flex;
}

.search_overlay form input.suchwort {
	width: 100%!important;
	font-size: 3rem;
	border: none;
	padding: 15px 40px;
	color: #000000;
  border: 2px solid var(--sym-rot);
  border-radius: 0.5rem;
}
.search_overlay form input.suchwort:focus, .search_overlay form input.suchwort:hover {
	border: none;
outline: none !important;
  border: 2px solid var(--sym-rot);
}
.search_overlay button svg {
width: 120px;
height: 70px;
padding: 0 10px;
}


.search_overlay form input.submit {
letter-spacing: 2px;
margin-top: 3.5rem;
color: #fff;
background-color: var(--sym-rot);
font-size: 1.4rem;
 } 


.tx-kesearch-pi1 .submitbutt input {
letter-spacing: 2px;
margin-top: 1.5rem;
color: #fff;
background-color: var(--sym-rot);
font-size: 1.4rem;
text-transform: uppercase;
  padding: 0.5rem 1.5rem;
  border-radius: 1.0rem;
  font-family: var(--sym-roboto);
 }

.tx-kesearch-pi1 .submitbutt { display: table;}

.search_overlay form input.submit:hover, .search_overlay form input.submit:focus, .tx-kesearch-pi1 .submitbutt input:hover, .tx-kesearch-pi1 .submitbutt input:focus {
  color: var(--sym-rot);
  background-color: #FFFFFF;
  border-color: var(--sym-rot);
    box-shadow: none;
}



#ke_search_sword {
	padding: 15px 40px;
	color: #000000;
  border: 2px solid var(--sym-rot);
  font-size: 2.5rem;
  border-radius: 5px;
}

#ke_search_sword:hover, #ke_search_sword:focus {
  box-shadow: none;
}



@keyframes slidein {
  from {
    top: -100vh;
  }

  to {
    top: 0vh;
  }
}
#kesearch_results .result-list-item .result-teaser {
  color: #000000!important;
}
button.searchClose {
	width: auto;
background-color: transparent;
  border:none;
color: var(--sym-rot);
	  position: absolute;
  top: 90px;
}
button.searchClose svg {
	width: 80px;
height: 80px;
}
#ke_search_sword {
  width: 75%!important;
}
#ke_search_sword:focus {
  outline: none !important;
}
div.kesearchbox {
  height: 55px!important;
  margin-bottom: 1.5rem;
}
.resetbutt {
  display:none;
}



@media (max-width: 1399px) {
  .navi-full.open {
  display:none!important;
}
    .services div {
      max-width: 550px;
      margin-bottom: 2rem;
    }
  .services > div {
    padding-bottom: 6rem;
  }
  .services > div > div:last-child {
    bottom: 0;
  }
    .grid {
        grid-gap:2rem;
    }
  section.background-image {
    background-position:center;
  }
  }

  @media (max-width: 1199px){

    
    h1, h2 {
        padding-bottom: 3rem;
    }
    .lead {
      font-size:1.6rem;
    }
    .services div {
        max-width: 460px;
    }
      .grid {
          grid-template-columns: 1fr 1fr;
      }
    .p-8 {
      padding:4rem;
    }
    .pt-8 {
      padding-top:4rem;
    }
    .pb-8 {
      padding-bottom:4rem;
    }
    .karriere.swiper .card-body {
      padding: 2rem;
    }
    .karriere.swiper h2 {
      font-size:1.6rem;
      line-height:1.5rem;
    }
    .karriere.swiper span:last-child {
      font-size:1.2rem;
    }
    .karriere.swiper span:first-child {
      font-size:1rem;
    }
    .kariere.swiper p {
      font-size:1.1rem;
    }
    .karriere.swiper p:first-of-type {
      line-height:1.3rem;
      grid-template-columns: 45px auto;
    }
    .karriere.swiper p:first-of-type::before {
      width:30px;
      height:40px;
    }
  }

  @media (max-width: 991px){
    .navi {padding-right:1.5rem;}
    .suche {margin-left:2rem;}
    #logo {
  max-width: 300px;
padding: 2.6rem 1.2rem .6rem 1.2rem;
margin-left: 0;
}
#logo img {
  width: 215px;
}
    .services div {
        max-width: 100%;
      }
    .benefits .even {
      margin-top:0;
    }
  }

@media (max-width: 767px){
    h3 {
        font-size: 2rem;
        line-height: 2.5rem;
    }
    .grid {
          grid-template-columns: 1fr;
      }
}

  @media (max-width: 575px) {
    .services div {
        border-radius: 0;
    }
    .swiper-slide {
      width:100%!important;
    }
    .karriere.swiper, .zitate.swiper {
      width:90vw!important;
    }
  }

.mitarbeiter p {
  margin-bottom:0;
}
.mitarbeiter .lead {
  font-size:1.8rem;
  line-height:1.8rem;
}

@media (max-width: 767px){
   .mitarbeiter .bodytext {
        width: 300px;
margin: auto;
padding-bottom: 3rem;
    }
  .mitarbeiter .lead{
    font-size:1.5rem;
    line-height:1.5rem;
  }
}