:root {
	--bg_gray: #f0f0f0;
	--bg_dark: #555;
	--bg_yellow: #FBBA00;
	--fore-color-inverse:#eee;
}


@font-face {
  font-family:'Catamaran';
  src: url('./fonts/Catamaran-ExtraLight.ttf') format('truetype');
  font-weight: 100;
  font-style: normal;
}


@font-face {
  font-family:'Catamaran';
  src: url('./fonts/Catamaran-Light.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
}

@font-face {
  font-family:'Catamaran';
  src: url('./fonts/Catamaran-Regular.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
}

@font-face {
  font-family:'Catamaran';
  src: url('./fonts/Catamaran-SemiBold.ttf') format('truetype');
  font-weight: 600;
  font-style: normal;
}

@font-face {
  font-family:'Catamaran';
  src: url('./fonts/Catamaran-Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
}

.banner-foerder {
    position: absolute;
    width: 180px;
    height: auto;
    top: 280px;
    left: 50px;
    z-index: 1000;
}

@media (max-width: 800px) {
    
    .banner-foerder {
        position: absolute;
        width: 80px;
        height: auto;
        top: 240px;
        left: 20px;
        z-index: 1000;
    }

} 


.cardnews {
	background: var(--card-back-color);
	color: var(--card-fore-color);
	border: 0.0625rem solid var(--card-border-color);
	border-radius: var(--universal-border-radius);
	margin: var(--universal-margin);
	overflow: hidden;
	}


/* -----------------------------------------
    SPLASH
-------------------------------------------- */
/* -----------------------------------------
     Splash Screen
-------------------------------------------- */

.splash {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height:100vh;

    z-index:100000;
    background-color: rgba(0,0,0,0.85);
    transition: all 0.5s;
    display:none;
    z-index: 10000;
}

.splash .splash-poster {
    position: absolute;
    left: 50%;
    top:50%;
    height: auto;
    width:85vw;
    max-width:100%;
    
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    
    transform: translate(-50%, -50%);

    margin: 0 auto;
    
    -webkit-box-shadow: 0px 0px 18px 0px rgba(0,0,0,0.75);
    -moz-box-shadow: 0px 0px 18px 0px rgba(0,0,0,0.75);
    box-shadow: 0px 0px 18px 0px rgba(0,0,0,0.75); 


}

.splash-close {
    position: absolute;
    right: 70px;
    top: 70px;
    z-index: 10000;
    display: none;
}

.splash-close-left {
    position: absolute;
    right: -25px;
    top: -25px;
    width: 48px;
    height: 48px;
    z-index:1000000;
    border-radius: 50%;
    /* -webkit-box-shadow: 0px 0px 18px 0px rgba(0,0,0,0.75);
    -moz-box-shadow: 0px 0px 18px 0px rgba(0,0,0,0.75);
    box-shadow: 0px 0px 18px 0px rgba(0,0,0,0.75); */
}

.splash-close-left:hover {
    cursor: pointer;
}

.splashbox-wrapper {
  position: absolute;
  top: 0;
  left:0;
  display: table-cell;
  vertical-align: middle;
  text-align: center;
  height: 100vh;
  width: 100vw;
  border: 0;
  overflow: hidden;
  
}

.splashbox-wrapper img.splash_image {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); 
  max-width: 90%;
  max-height: 90%;
}

@media (max-width: 800px) {
  .splash-close-left {
      right: 30px;
      top: 30px;
      width: 36px;
      height: 36px;
  }
}



/* Fonts (warum wird das fÃƒÂ¼r alle Elemente zurÃƒÂ¼ckgesetzt? Hebelt die Vererbung aus? */
html,* {
	font-family: 'Sarabun',sans-serif;
	font-weight:300;
}

body {
	font-family: 'Sarabun',sans-erif;
	font-weight: 300;
}

h1,h2,h3,h4,h5,h6 {
	font-family: 'Catamaran',sans-serif;
	font-weight: 700;
}
h1,h2 {
	font-weight: 100;
	font-size:38px;
}

header.page_header {
    position:relative;
    height: 120px;
    background: white;
    overflow:visible;
    z-index:9000;
    padding-top:0;
    border-bottom: 1px solid darkorange;
    /* overflow: hidden; */
}

@media (max-width: 800px) {

    header.page_header { height: 70px; }
	main { padding-top: 70px; }

}

body.home header.page_header {
	background:transparent;
	position:fixed;
	left:0;
	top:0;
	width:100%;
	box-shadow: 2px 2px 8px rgba(0,0,0,0.5);
}

header.page_header {
	background white;
	position:fixed;
	left:0;
	top:0;
	width:100%;

	box-shadow: 2px 2px 8px rgba(0,0,0,0.5);
}


footer.page_footer {
	border:none;
	padding:0;
	margin: 6em 0 0 0;
	background-color:#ddd;
}

section.bg__gray + section.bg__gray {
	margin:0;
	padding-top:0.5em;
}

.bg__gray.dark {
	background-color:var(--bg_dark);
}
.bg__gray.dark {
	color:var(--fore-color-inverse);
}
.bg__gray.dark figcaption {
	color:var(--fore-color-inverse);
}


.under_construction {
	padding:50px 0;
	margin:auto;
	font-size:24px;
	text-align:center;
}

@media (min-width: 800px) {
 	body.std main {
 		margin-top:120px;
 	}
}


/* -----------------------------------------
     Modul Header // generelle Formatierung fÃƒÂ¼r Module
-------------------------------------------- */
.modul__header h2 { text-align: center; }
.modul__header__byline p { text-align: center; width: 80%;}

.center { text-align: center;}

/* -----------------------------------------
   00 - Cover mit Titel
-------------------------------------------- */

.cover {
   position: relative;
   width: 100%;
   height: 30.48vw;
   background-color: #333;
   background-repeat: no-repeat;
   background-size: cover;
   background-position: center;
   margin-top:0;
}

.cover h2 {
   position: absolute;
   bottom: 2em;
   left: 2em;
   background: rgba(255,255,255,0.85);
   font-size:28px;
   padding: 20px 40px;
   font-weight:300;
   min-width:280px;
   max-width: 100%;
}

.badge__holder {
	position:relative;
	padding:0;
}
.badge__holder img {
	display:block;
	position:absolute;
	right:0;
	top:0;
	max-width:13rem;
	height:auto;
	transform:translateY(-50%);
/*
	max-width:30%;
	height:auto;
*/
}

@media (max-width: 800px) {

   .cover h2 {
      bottom: 0em;
      left: 0em;
      padding: 10px 20px;
      font-size: 16px;
      width:100%;
      margin:0;
   }
	.badge__holder img {
		max-width:7rem;
		right:3rem;
	}
   
}


.akplus-badge {
  position: absolute;
  width: 300px;
  height: auto;
  right: 150px;
  top:50%;
  transform: translateY(-50%); 
}

@media (max-width: 800px) {

  .akplus-badge {
      display: none;
  }


  
}


/* -----------------------------------------
    Videocover
-------------------------------------------- */
.videocover {
   position: relative;
   width: 100vw;
   height: 39.27vw;
   overflow:hidden;
   transform: translateY(-4px);

}
section.videocover {
	margin-top:0;
	/*
	padding-top:120px;
	background-color:#5c5c5c;
	*/
}
body.home main > section.videocover #videoplayer {
/*	top:120px;*/
}

.videocover h2 {
   position: absolute;
   bottom: 2em;
   left: 2em;
   background: rgba(255,255,255,0.85);
   padding: 20px 40px;
   font-weight:300;
   min-width:280px;
   max-width: 100%;
}

.videocover .videoplayer {
	position:absolute;
	top:0;
	left:0;
	width:100%;
}

#videoplayer {
   position: absolute;
   top:0;
   left:0;
   width: 100vw;
   height: 56.25vw;
   max-width:100%;
   overflow:hidden;
}



/* -----------------------------------------
     Headline
-------------------------------------------- */
.headline h2,
.headline h1 {
	text-align: center;
	margin-bottom: 1.2rem;
	font-weight: 100;
	font-size: 48px;
}
.headline__byline { text-align: center; }
.headline__subtitle {
	font-size:30px;
	font-weight:600;
	display:block;
}

.headline__byline h3 {
	font-weight: 300;
}

section.head__byline__yellow .headline__subtitle {
	font-weight:400;
	color: #fbba00;
}

.headline__props {
	font-size:25px;
	font-weight:200;
	text-align:center;
	margin:1rem 3rem 2rem 3rem;
}

.headline.bg__gray {
	padding: 3rem 0;
}
.headline h4 {
	font-weight:300;
	font-size:1.5em;
	line-height:1.3;
}


@media (max-width: 800px) {

	.headline h2, .headline h1 { font-size: 2.1rem;	}

}


/* -----------------------------------------
    01 - Textblock
-------------------------------------------- */
.textblock { text-align:center; }
.textblock.text-links { text-align:left !important; max-width: 780px; margin: 0 auto; }

.textblock.bg__gray {
	padding: 3rem 0;
}
.textblock.bg__white {
	padding: 3rem 0;
}

/* -----------------------------------------
    02 - Text mit Bild
-------------------------------------------- */
.textpict {  }
.textpict h2 { margin-bottom: 1.3em; }
.textpict img { display:inline-block; max-width:100%; height:auto }

.textpict__text h3 {
	font-weight:200;
	font-size:32px;
}

.textpict__text a {
	color:inherit;
}
.textpict__text a strong {
	color:inherit;
}
.textpict__text a strong::after {
	content:"\3009\3009";
	display:inline-block;
	margin-left:0.5em;
	letter-spacing:-10px;
	color:var(--bg_yellow);
}


.pict__left .textpict__pict {
	padding-right: 1.5em;
}
.pict__left .textpict__text {
	padding-left: 1.5em;
}

.pict__right .textpict__pict {
	order:2;
	padding-left: 1.5em;
}
.pict__right .textpict__text {
	order:1;
	padding-right: 1.5em;
}

.pict__above .textpict__pict.col-md-6 {
	flex-basis:100%;
	max-width:100%;
	text-align:center;
	order:1;
}
.pict__above .textpict__text.col-md-6 {
	flex-basis:100%;
	max-width:100%;
	order:2;
}

.pict__below .textpict__pict.col-md-6 {
	flex-basis:100%;
	max-width:100%;
	text-align:center;
}
.pict__below .textpict__text.col-md-6 {
	flex-basis:100%;
	max-width:100%;
}

@media (max-width: 800px) {
 	.textpict__pict,
 	.textpict__text { padding:0;}
}


/* -----------------------------------------
    02 - Trennlinie mit Ikon
-------------------------------------------- */

.sepline__line {
   width: 100%;
   text-align: center;
   background-image: url(../img/iko-line.svg);
   background-repeat: repeat-x;
   background-position: center;
}
.sepline__ikon {
   display: inline-block;
   width: 50px;
   height: 50px;
   display: inline-block;
   background-color: white;
   border-radius: 50%;
   border: 5px solid white;
   background-image: url(../img/iko-ic.svg);
   background-repeat: no-repeat;
   background-position: center;
   background-size: 90%;
}
.bg__gray .sepline__ikon {
	border-color:var(--bg_gray);
}
.bg__gray.dark .sepline__ikon {
	border-color:var(--bg_dark);
}

/* -----------------------------------------
    03 - Image Modul
-------------------------------------------- */

.imgbox figure img { 
   width:100%;
   height:auto;
   line-height:1;
   display:inline-block;
}
.imgbox figcaption {
	text-align:center;
	font-weight:300;
	font-size:1.2em;
	margin-top: 2em;
}
.imgbox.imgbox__centered figure {
	padding-top:2em;
	padding-bottom:2em;
	text-align:center;
}
.imgbox.imgbox__centered figure img {
	width:auto;
	max-width:100%;
}
.imgbox.imgbox__scaled figure {
	text-align:center;
}

/* ----------------------------------------
    03 - Produktinfos
-------------------------------------------*/
  
.product {
}
.product .bbox {
	margin-top:2rem;
}
.product .videoframe {
	position:relative;
}
.videoframe .videoplayer {
	display:block;
	max-width:100%;
}

.bbox a {
	color: white !important;
}
.product .videoframe.youtube__box {
	margin: 1rem 0;
}

/* ----------------------------------------
    03 - Parallax
-------------------------------------------*/

.para {
  height: 40vh;
  background-attachment: fixed;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

/* ----------------------------------------
    05 - Button
-------------------------------------------*/

.bbox {
   text-align: center;
}

.bbox__link {
   display: table;
   background: rgb(102,102,102);
   color: white;
   padding:0;
   border-radius: 10px;
   height: auto;
   line-height: 1em;
   margin: 0 auto;
   transition: all 0.5s;
   padding: 10px;
}
.bbox__link:visited {
	color:white;
}
.bbox__link:hover {
   background-color: #FBBA00;
}

.bbox__link span { 
   height: 24px; 
   line-height: auto; 
   vertical-align: middle; 
   display: table-cell;
   
}

.bbox__link span:first-child { 
   padding: 0 2em 0 1em!important;
   font-size: 18px;
   background-image: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHZlcnNpb249IjEuMSIgdmlld0JveD0iMCAwIDI0IDI0IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIj4KICAgIDxnIHRyYW5zZm9ybT0ic2NhbGUoMC41KSI+CiAgICAgICAgPHBhdGggZmlsbD0ibm9uZSIgZD0iTS04MzgsLTIyMzJoMTQwMHYzNjAwaC0xNDAwWiI+PC9wYXRoPgogICAgICAgIDxwYXRoIGZpbGw9IiNGRkYiIGQ9Ik0xNiwxMHYyOGwyMiwtMTRaIj48L3BhdGg+CiAgICAgICAgPHBhdGggZmlsbD0ibm9uZSIgZD0iTTAsMGg0OHY0OGgtNDhaIj48L3BhdGg+CiAgICA8L2c+Cjwvc3ZnPg==');
   background-repeat: no-repeat;
   background-position: right;
}

.bbox__link span:last-child { padding:0 1em }

.bbox__link span img { 
   display: block;
   margin: 0 auto;
}

.bbox__link img { 
   height: 100%; 
   vertical-align: center;
}



/* -----------------------------------------
    06 - Video
-------------------------------------------- */

.youtube { width: 100%; max-width:100%; }
.youtube.bg__gray { padding: 3em 0; }
.youtube__header  { text-align: center; margin-bottom: 3em; }

.youtube__box {  
   display:block;
   margin: 0 auto; 
   margin-bottom: 2em; 
   color: black;
   width: 100%;
   max-width:100%;
   padding-top:56.25%;
   position:relative;
}

.youtube__video {
   position: absolute;
   top: 0;
   left: 0;
   bottom: 0;
   right: 0;
}

.youtube__player {
   max-width:100%;
   max-height:100%;
   width:100%;
   height:100%;
}


@media (max-width: 800px) {
   .youtube.bg__gray { padding: 1.5em 0; margin: 0 auto; }
}



/* -----------------------------------------
   07 - 3er Teaser
-------------------------------------------- */

.teaser3 {}
.teaser3__header  { text-align: center; margin-bottom: 3em; }
.teaser3__header h2 { font-size: 45px;}
.teaser3 .card {
	justify-content:flex-start;
	align-self:stretch;
	font-size:14px;
	margin: 1em;
}

.teaser3 .row .card.with-link {  
   border:0; 
   background-image: url(../img/ico-pfeil.svg);
   background-repeat: no-repeat;
   background-size: 1.25em;
   background-position: center bottom 1em;
}
.teaser3 .section.media {
	margin-bottom:1rem;
}
.teaser3 .row .card p { 
	/*font-size: 14px;*/
	padding: 0 8px 4em;
}

.teaser3 .card h3 {
	font-size: 1.50rem;
	color: rgb(103, 103, 103);
	font-weight:700
}

.teaser3 .card h3.bg_dark {
   background-color: #666;
   margin:0;
   padding: 10px; 
   color:white;
   font-weight:500;
}
.teaser3.bg__gray .card {
	background-color:white;
}


.invtop {font-size: 19px !important;}

/* -----------------------------------------
 08 - Teaserliste
-------------------------------------------- */

.tlist { width: 100%; max-width:100%; }
.tlist p { font-size:16px; font-weight:inherit }
.tlist.bg__gray { padding: 3em 0;  }
.tlist__header  { text-align: center; margin-bottom: 3em; }
.tlist__header  h2 { font-size: 45px; }

.tlist__box {  
   display:block;
   margin: 0 auto; 
   margin-bottom: 2em; 
   max-width: 860px;
}

.tlist__bgndimg {
	width:400px;
	height:400px;
	background-size:cover;
	background-position:center center;
}

.tlist__box .row { background-color: white; box-shadow: 1px 0px 9px rgba(0,0,0,0.25);}

.tlist.tlist__box__wide .tlist__box {  max-width: 1200px; }

.tlist__box__image      { padding: 0 1em 0 0; }
.tlist__box__image img  { width:100%;  display: block;}
.tlist__box__text       { padding-left: 0.8em; padding-right: 0.8em;font-size:14px;}
/*
.tlist__box__text p     { font-size: 14px; }
*/
.tlist__box__text h3     { margin-top: 1em; font-size:24px; margin-bottom: 0; }

.tlist__box a[href] .tlist__box__text {
   color:var(--fore-color);
   background-image: url(../img/ico-pfeil.svg);
   background-repeat: no-repeat;
   background-size: 1.5em;
   background-position: left 1em bottom 12px;
}

/* Variante Headteaser, leicht umarrangiert, weil die 
Teaser-Typ-Klasse in der ÃƒÂ¼bergeordneten section.tlist liegt
(spart auch !important ein) */

.tlist__box__headteaser .tlist__box__text h3 {
   color: #FDBB00;
   font-weight: 500;
}

.tlist__box__headteaser .tlist__box__text  {
   font-size: 28px;
   font-weight: 100;
}

/* Variante Teaserstreifen mit quadratischem Bild */
.tlist__box__strip .tlist__box__image.col-md-6 {
	flex-basis:38.2%;
	max-width:38.2%;
}
.tlist__box__strip .tlist__box__text.col-md-6 {
	flex-basis:61.8%;
	max-width:61.8%;
}
.tlist__box__strip .tlist__bgndimg {
	width:100%;
	height:0;
	padding-bottom:85%;
}



/* Spalten, links/rechts */

.tlist__box__slogan, .tlist__box__slogan__alternating {
	/*margin,padding*/
}

.tlist__box__slogan__alternating .tlist__box__text p {
	font-size: 25px;
}


.tlist__box__slogan__alternating .tlist__box {
	margin-bottom:0;
}

.tlist__box__slogan .row, .tlist__box__slogan__alternating .row {
	box-shadow:none;
	background-color:transparent;
}
.tlist__box__slogan .tlist__box__text, .tlist__box__slogan__alternating .tlist__box__text {
	display:flex;
	flex-direction:column;
	justify-content:center;
	font-size:30px;
	font-weight:100;
	line-height:1.2;
	color:var(--fore-color);
	margin:0;
	padding:0;
}
.tlist__box__slogan .tlist__box__image, .tlist__box__slogan__alternating .tlist__box__image {
	display:flex;
	margin:0;
	padding:0;
}

.tlist__box__slogan .tlist__bgndimg, .tlist__box__slogan__alternating .tlist__bgndimg {
	width:380px;
}
.tlist__box__slogan__alternating .tlist__items .tlist__box:nth-child(even) .tlist__box__image {
	order:3;
	margin:0;
	padding:0;
}
.tlist__box__slogan__alternating .tlist__items .tlist__box:nth-child(even) .tlist__box__text {
	text-align:right;
	padding-right:20px;
}

/* Kachelung */

.tlist__box__grid .tlist__items {
	display:flex;
	flex:1 0;
	justify-content:center;
	flex-wrap:wrap;
}
.tlist__box__grid .tlist__box {
	margin:0.5rem;
	box-shadow: 1px 0px 9px rgba(0,0,0,0.25);
}
.tlist__box__grid .tlist__bgndimg {
	width:295px;
	height:205px;
	position:relative;
}
.tlist__box__grid .tlist__bgndimg h3 {
	font-weight:200;
	color:white;
	margin:0;
	width:100%;
	text-align:center;
	position:absolute;
	left:0;
	top:0.7rem;
	font-size:1.3rem;
}




@media (max-width: 800px) {

   .tlist__box__image   { padding: 0;}
   .tlist__box__text    { padding-left: 0; padding: 1em 1em 3.5em 1em;}
   
}

@media (max-width: 640px) {

	/* Strip, Bilder rechteckig (?) */
	.tlist__box__strip .tlist__box__image.col-md-6 {
		flex-basis:100%;
		max-width:100%;
	}
	.tlist__box__strip .tlist__box__text.col-md-6 {
		flex-basis:100%;
		max-width:100%;
	}
	.tlist__box__strip .tlist__bgndimg {
		padding-bottom:62%;
	}


}

/* -----------------------------------------
   09 - Galerien
-------------------------------------------- */

.flexbox {display: flex;}
.flexcenter {
	justify-content:center;
	align-items:center;
}

.gallerygrid {
	display:flex;
	flex-direction:row;
	flex-wrap:wrap;
	justify-content:flex-start;
	margin-left:-10px;
}
.gallerygrid__image {
	width:340px;
	height:230px;
	margin:10px;
	background-size:cover;
	background-position:center center;
}
.gallerygrid__image:nth-child(-n+2) {
	width:520px;
	height:353px
}

.gallerygrid__image:hover {
	cursor: pointer;
}


@media (max-width:1099px) {
	.gallerygrid {
		justify-content:center;
	}
	.gallerygrid__image:nth-child(-n+2),
	.gallerygrid__image {
		width:340px;
		height:230px;
	}
	
}


.gallerygrid__img__quader {
	width:340px;
	height:340px;
	margin:10px;
	background-size:cover;
	background-position:center center;
}

.gallerygrid__img__quader:nth-child(-n+2) {
	width:520px;
	height:520px
}


.gallerygrid__img__quader:hover {
	cursor: pointer;
}


@media (max-width:1099px) {
	.gallerygrid__img__quader:nth-child(-n+2),
	.gallerygrid__img__quader {
		width:340px;
		height:340px;
	}
	
}





.linkbanner { }
.linkbanner h3 {
	text-align:center;
	font-weight:200;
	font-size:30px;
	margin-bottom:1.5rem;
}
.linkbanner .row {
}
.linkbanner__image {
	margin-top:auto;
	margin-bottom:auto;
}
.linkbanner__image img {
	display:block;
	max-width:100%;
	height:auto;
}
.linkbanner__text {
	margin-top:auto;
	margin-bottom:auto;
	padding-left:2rem;
	box-sizing:border-box;
}
a.massive {
	display:inline-block;
	padding-left:50px;
	font-weight:700;
	color:inherit;
	position:relative;
}
a.massive::before {
	position:absolute;
	left:0;
	top:0;
	line-height:1;
	font-weight:700;
	content:"\3009\3009";
	display:block;
	letter-spacing:-30px;
	color:var(--bg_yellow);
	font-size:45px;
	
}


.thumbsgallery {
}
.thumbsgallery__image {
	width:100%;
	height:500px;
	background-size:cover;
	background-position:center;
	background-repeat:no-repeat;
}
.thumbsgallery__thumbs {
}
.thumbsgallery__thumbs .glide__slides {
	justify-content:center;
}
.thumb__slide {
	height:190px;
	background-size:cover;
	margin:5px;
}

.glide__controls {
	position:relative;
	
}
.thumbsgallery .glide__arrow path {
	fill:white;
}
.thumbsgallery .glide__arrow {
	position:absolute;
	top:-420px;
	box-shadow:none;
	border-radius:50%;
	left:1rem;
}
.thumbsgallery .glide__slide {
	border:1px solid transparent;
}

.thumbsgallery .glide__slide--active {
	border:1px solid var(--bg_yellow);
}
.thumbsgallery .slider__arrow--next {
	left:auto;
	right:0.7rem;
}



/* -----------------------------------------
   09 - Aktion Slider
-------------------------------------------- */

.aktion { width: 100%; max-width:100%; }
.aktion.bg__gray { padding: 3em 0; margin: 0 auto; }
.aktion__header  { text-align: center; margin-bottom: 3em; }

@media (max-width: 800px) {
   .aktion.bg__gray { padding: 1.5em 0; margin: 0 auto; }
}

.glide__slide {
	text-align:center;
}




/* -----------------------------------------
    10 - Referenz :: GRID Container
-------------------------------------------- */

/* --- Basis  */
.ref { width: 100%; max-width:100%; padding-bottom: 4em; }
.ref.bg__gray { padding: 4em 0; margin: 0 auto; }
.ref__header  { text-align: center; margin-bottom: 3em; }

.ref__wrapper {  /* --- Rahmen */
   position: relative;
   width: 100%;
   height: calc(100vw - 40px);;
/*    padding-bottom:100%; */
/*    max-height:1100px; */
}

.ref__wrapper_topgrid {
   position: relative;
   width: 100%;
}

/* --- Grid Setting */
.ref__grid {
   display: grid;
   grid-gap: 20px;
   grid-template-columns: 1fr 1fr 1fr;
   grid-template-rows: 1fr 1fr 1fr;
   grid-template-areas:
   "ref__grid_G1 ref__grid_G1 ref__grid_G2"
   "ref__grid_G3 ref__grid_G4 ref__grid_G2" 
   "ref__grid_G5 ref__grid_G6 ref__grid_G6";
   width: 100%;
   height: 100%;
   
}

.ref__grid_G1 { grid-area: ref__grid_G1; }
.ref__grid_G2 { grid-area: ref__grid_G2; }
.ref__grid_G5 { grid-area: ref__grid_G5; }
.ref__grid_G3 { grid-area: ref__grid_G3; }
.ref__grid_G4 { grid-area: ref__grid_G4; }
.ref__grid_G6 { grid-area: ref__grid_G6; }



.ref__wrapper.grid1 {
	height:auto
}
.ref__wrapper.grid2 {
	height:auto;
}

.ref__grid.grid1 {
   grid-template-columns: 1fr 1fr 1fr;
   grid-template-rows: 1fr 1fr;
   grid-template-areas:
    "rg1 rg1 rg2"
    "rg1 rg1 rg3";
    height:auto;
}
.ref__grid.grid2 {
   grid-template-columns: 1fr 1fr;
   grid-template-rows: 2fr 1fr;
   grid-template-areas:
    "rg1 rg1"
    "rg2 rg3";
    height:100%;
}
.ref__grid1_G1 { grid-area: rg1 }
.ref__grid1_G2 { grid-area: rg2 }
.ref__grid1_G3 { grid-area: rg3 }

.ref__grid2_G1 { grid-area: rg1 }
.ref__grid2_G2 { grid-area: rg2 }
.ref__grid2_G3 { grid-area: rg3 }

/* --- Box Basis */
.ref__grid > div {
   position: relative;
   background-color: #ccc;   
   overflow: hidden;
}

img.ref__image {
   width: 100%;
   height:100%;
   object-fit: cover;
   transition: all 0.5s ease-in-out;
}
.ref__grid > div:hover  img.ref__image {   transform: scale(1.2); }

/* --- Textbox */
.ref__text { 
   position: absolute;
   top: 50%;
   width: 40%;
   left:0;
   font-size: 92%;
   transform: translatey(-50%);
   padding: 1em;
   background: rgba(251,186,0,0.75);
   color: white;
   margin:0;
}

.ref__byline h3 {margin-top: 2em; font-weight:300; }

/*
.ref__grid.grid2 .ref__grid2_G3 .ref__text {
	left:auto;
	right:0;
}
*/





/* ------------------------------------------
  12 Google Maps
--------------------------------------------- */

.googlemap {
	height:400px;
	width:100%;
}
.two-maps .googlemap {
	border-right:5px solid transparent;
	width:50%;
}
.two-maps .googlemap + .googlemap {
	border-left:5px solid transparent;
	border-right:0;
}
@media screen and (max-width:840px) {
	.two-maps .googlemap {
		border-right:0;
		width:100%;
	}
	.two-maps .googlemap + .googlemap {
		border-left:0;
		border-top:10px solid transparent;
	}
}


/* -----------------------------------------
   13 - FAQ-Liste
-------------------------------------------- */

dl.faq { margin-top:2em; }

dl.faq dt:first-child    { border-top: 0px dotted gray; }
dl.faq dd:last-child     { border-bottom: 0; }
dl.faq dl                { border-bottom: 0px dotted gray; }

dl.faq dt {
   cursor: pointer;
   padding: 0;
   padding-top: 1em;
   font-weight: 800;
}

dl.faq dt:hover { color: red;}
dl.faq dt:before { 
   content: '▾'; 
   display: inline-block;  
   font-weight:300; 
   background-color: rgb(230,230,230);
   padding: 2px 7px;
   border-radius: 50%;
   margin-right: 1em;
}
dl.faq dt.aktiv:before { content: '▴'; }

dl.faq dd {
   border-bottom: 1px dotted gray;
   padding: 0;
   padding-bottom: 1em;
   padding-left: 3em;
   margin:0;
}



/* -----------------------------------------
    FOOTER
-------------------------------------------- */

.contactmap {
	background:white;
}
.contactmap h2 {
	margin:1em 0;
	text-align:center;
}
.contactmap iframe {
	display:block;
	width:100%;
	height:400px;
	margin:0;
	padding:0;
}
.contactbar {
	background-color:#EFA92C;
}
.contactbar .container {
	background-color: #666666;
	color:white;
	padding:1rem;
}
.contactbar__tel {
	position: relative;
	padding-left:45px;
}

.contactbar__tel a {
	color: white;
}

.contactbar__tel::before {
	position: absolute;
	top:0;
	left:0;
	height: 25px;
	width:25px;
	content:"";
	background-image: url('../img/ico-telefon.svg');
	background-repeat: no-repeat;
	background-size: 100%;
	background-position: center;
}

.contactbar__mail {
	margin-left:auto;
	position: relative;
	padding-right:45px;
}
.contactbar__mail a {
	color:white;
}
.contactbar__mail::after {
	content:"[icon]";
	position: absolute;
	top:0;
	right:0;
	height: 25px;
	width:25px;
	content:"";
	background-image: url('../img/ico-mail.svg');
	background-repeat: no-repeat;
	background-size: 100%;
	background-position: center;
}

.contactbox {
}
.contactbox img {
	display:block;
	max-width:80%;
}

@media (max-width: 800px) {

.contactbox img {
	display:block;
	max-width:100%;
}

 
}

.contactbox .container {
	padding:2rem 2rem 1.7rem 2rem;
	border-bottom:1px solid #888;
}

.footermenu h5 {
	margin:0;
}
.footermenu .container {
	padding:2rem;
}
.footermenu__links a,
.footermenu__links a:visited {
	color:inherit;
	display:inline-block;
	width:49%;
}

.social_icon img {
	width:40px;
	margin:1em 1em 0 0;
}


/* -----------------------------------------
    NAV :: Bereich
-------------------------------------------- */
 
section.nav-bar {
  margin:0;
  height: 120px;
  background: white;
  /* border-bottom: 1px solid darkorange; */
/*   box-shadow: 2px 2px 8px rgba(0,0,0,0.5); */
  transition:background 0.4s linear;
}

.nav-bar.nav-bar-home {
   border-bottom: 0;
   background-color: transparent;
}

.nav-bar .logo1 { display:none }
.nav-bar .logo2 { display:inline-block }
.nav-bar.nav-bar-home .logo1 { display:inline-block }
.nav-bar.nav-bar-home .logo2 { display:none }



/* -----------------------------------------
     NAV :: Container
-------------------------------------------- */
.nav-container {
  position:relative;
  width: 95%;
  height: 120px;
  max-width: 100%; 
  margin: 0 auto;
/*   border: 1px solid red; */
}

@media (max-width: 1300px) {
   .nav-container {
       width: 100%;
   }
}

/* -----------------------------------------
    Nav Brand & Logo
-------------------------------------------- */

.brand {
  position: absolute;
  bottom:0;
  padding-left: 20px;
  float: left;
  line-height: 70px;
  text-transform: uppercase;
  font-size: 24px;
  color: black;
}
.brand a img {
	max-height: 75px;
}
.brand a,
.brand a:visited {
  color: black;
  text-decoration: none;
}


 
/* -----------------------------------------
     NAV : Setup Basiselemente
-------------------------------------------- */
 
nav {
    float: right;
    margin: 4em 145px 0 0;
    border: 0;
    background: transparent;

}

nav a:focus, nav a:visited:hover, nav a:visited:focus {
  text-decoration: none;
  background: none;
}

nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

nav ul li {
   float: left;
   position: relative;
   padding:0;
}

nav ul li a {
   display: block;
   padding: 10px 12px;
   line-height: 20px;
   background-color: white;
   color: #000 !important;
   font-size:15px;
   text-decoration: none;
   border:0 !important;
   background-image: url('data:image/svg+xml;utf8,<svg width="1px" height="32px" viewBox="0 0 1 32" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" stroke-linecap="square"><path d="M0.5,0.5 L0.5,31.5" id="Line" stroke="#FCB900"></path></g></svg>');
   background-repeat: no-repeat;
   background-size: 1px 24px;
   background-position: right center;

}

nav ul li a:hover,
nav ul li.active a:hover {
   background-color:var(--bg_yellow) !important;
   color:black !important;
}


nav ul li:last-child a {
   background-image: none;
}

/* Navigation-Homepage */
section.nav-bar-home nav ul li a { 
   background-color: transparent; 
   color: white !important;
}

@media (max-width: 1080px) {
 
   nav ul li a {
      padding: 10px;
      font-size: 14px;
   }
}


/* -----------------------------------------
     NAV : Hover & Focus Funktionen
-------------------------------------------- */

/* Hover & Fcus Hauptmenu */
nav ul li a:hover,
nav ul li a:focus,
nav ul li:hover a {
   position: relative;
   box-shadow: 0 3px 12px rgba(0, 0, 0, 0.15);
   color: #000;
   z-index:10;
   background-color: white;
   border-radius:0;
}

/* Hover SubmenÃƒÂ¼ */
nav ul li:hover > ul {
   display: block !important;
}

/* Navigation-Homepage */
section.nav-bar-home nav ul li a:hover,
section.nav-bar-home nav ul li a:focus,
section.nav-bar-home nav ul li:hover a { 
   background-color: rgba(0,0,0,0.5);
   color: white !important;
}





/* -----------------------------------------
     NAV : Aktive Navigationspunkte
-------------------------------------------- */

nav ul li.active > a {
   color: orange !important;
}


/* -----------------------------------------
    NAV :: Dropdown Element
-------------------------------------------- */

.nav-dropdown {
  position: absolute;
  display: none;
  z-index: 1;
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.15);
   z-index:11;
}

nav ul li ul li {
   min-width: 260px;
}

nav ul li ul li a {
   padding: 10px 20px;
   line-height: 20px;
   background-image: none;
}

nav ul li a:not(:only-child):after,
nav ul li a:visited:not(:only-child):after {
  padding-left: 4px;
  content: ' ▾';
}

/* -----------------------------------------
    Mobile Touch Element
-------------------------------------------- */

.touchnav { display:none;}
 
@media (hover: none) {
   .touchnav { display:block;}
}

/* -----------------------------------------
    Mobile
-------------------------------------------- */

.nav-mobile {
  display: none;
  position: absolute;
  top: 0;
  right: 0;
  background: #262626;
  height: 70px;
  width: 70px;
  box-sizing: border-box;
  overflow: hidden;
}

@media only screen and (max-width: 900px) {
  .nav-mobile {
     display: block;
     overflow: hidden;

  }
 



   .nav-container {
      width: 100%;
      height: 70px;
      max-width: 100%; 
      margin: 0 auto;
   }

   nav {
   float: right;
   margin: 0;
   border:0;
   background: transparent;
   }



.brand {
   position: absolute;
   top:0;
   left: 20px;
   height: 70px;
   padding-left: 0px;
   float: left;
   line-height: 70px;
   text-transform: uppercase;
   font-size: 24px;
   color: black;
}

.brand a img {
	height: 85%;
   max-height:100%;
}
.brand a,
.brand a:visited {
  color: black;
  text-decoration: none;
}   

section.nav-bar {
  margin:0;
  height: 70px;
  width: 100% !important;
  background: white;
  border-bottom: 1px solid darkorange;
}   
   
   nav {
    width: 100%;
    padding: 71px 0 15px;
    box-sizing: border-box;
  }
   
  nav * { padding:0;} 
  nav ul {
    display: none;
  }
  nav ul li {
    float: none;
  }
  nav ul li a {
    padding: 10px 15px;
    line-height: 20px;
	 padding-left: 15%;
	 border-bottom: 1px solid #eee !important;
  }
  nav ul li ul li a {
    padding-left: 20%;
     background-color: pink;
  }
 
  .nav-dropdown {
    position: static;
     background-color: pink;
  }
	.brand a img {
		max-height: 60px;
		margin-top: 5px;
	}
}
@media screen and (min-width: 799px) {
  .nav-list {
    display: block !important;
  }
}
#nav-toggle {
  position: absolute;
  left: 18px;
  top: 22px;
  cursor: pointer;
  padding: 10px 0 0 2px;
}
#nav-toggle:hover {
 background-color: transparent !important;
} 

#nav-toggle span,
#nav-toggle span:before,
#nav-toggle span:after {
  cursor: pointer;
  border-radius: 1px;
  height: 5px;
  width: 35px;
  background: #ffffff;
  position: absolute;
  display: block;
  content: '';
  transition: all 300ms ease-in-out;
   padding:0;
}
#nav-toggle span:before {
  top: -10px;
}
#nav-toggle span:after {
  bottom: -10px;
}
#nav-toggle.active span {
  background-color: transparent;
}
#nav-toggle.active span:before, #nav-toggle.active span:after {
  top: 0;
}
#nav-toggle.active span:before {
  transform: rotate(45deg);
}
#nav-toggle.active span:after {
  transform: rotate(-45deg);
}
 


/* -----------------------------------------
    Kontaktbar
-------------------------------------------- */

.konta { 
   position: fixed;
   right: 0;
   top: 17%;
   width: 46px;
   height:auto;
   z-index:100;

}

.konta a {
   position: relative;
   top: 0;
   left:0;
   display:block;
   width: 400px;
   background-color:rgb(102,102,102);

   color: white !important;
   line-height:46px;
   height:46px;
   overflow: hidden;
   transition: 1s all ease-in-out;
   text-decoration: none !important;
   box-sizing: border-box;
   border: 0;
   padding:0;
   margin: 0 0  5px 0;
}

div.konta a span {
   margin-left:62px;
}

.konta a:hover {   transform: translatex(-200px); }

.konta  a  i {
   position: absolute;
   display: block;
   width: 46px;
   height: 46px !important;
   background-color: orange;
   vertical-align: middle;
   background-repeat: no-repeat;
   background-position: center;
   background-size: 90%;
   background-color: #fbba00;
}

@media (max-width: 800px) {


    .konta  a  i {
       width: 33px;
       height: 33px !important;
    }

    .konta { 
       top: 90px;
       width: 33px;
       height:33px;
    }

    .konta a {
       width: 33px;
       line-height:33px;
       height:33px;
    }

    .konta a:hover {   transform: translatex(-66px); }

}

.konta > a.konta-mail > i {   
   background-image: url(/img/ico-mail.svg);
}
.konta > a.konta-location > i {
   background-image: url(/img/ico-location.svg);
}
.konta > a.konta-read > i {
   background-image: url(/img/ico-read.svg);
}
.konta > a.konta-tel > i {
   background-image: url(/img/ico-tel.svg);
}

.konta > a.konta-kfw > i {
   background-image: url(/img/iko-kfw-sidebar.svg);
    background-size: 70%;
}

/* -------------------------------------------- */



/* -------------------------------------------- 
	Schallschutz-Elemente
 -------------------------------------------- */
table.schall {
	max-height:none;
	background
}
table.schall thead {
	border-width:1px 0px 1px 0px;
}
table.schall th {
	background:transparent;
	border-width:0;
	font-weight:600;
	padding:6px 2px 4px 2px;
}
table.schall tbody {
	border:0;
}
table.schall td {
	background:transparent;
	border-width:0px;
	border-bottom:1px solid var(--table-border-color);
	padding:6px 2px 4px 2px;
}
table.schall.verg td+td {
	text-align:center;
}


.sk__cards .card {
	max-width:290px;
}
.sk__cards .card p {
	font-size:18px;
}
.sk__cards .card p strong {
	font-size:27px;
}

.sk__sep {
	width: 0;
	height: 0; 
	border-top: 15px solid transparent;
	border-bottom: 15px solid transparent;
	border-left: 20px solid red;
	margin:0 0.3rem;
}
.sk__sep.sep2 {
	border-left-color:#578dc6;
}

/* -------------------------------------------- 
	SprungmenÃ¼
 -------------------------------------------- */
.anchormenu {
	margin-top:2rem;
}
.anchormenu__menu nav {
	float:none;
	margin:0;
	border:0;
	text-align:center;
}
.anchormenu__menu nav span {
	font-size:1.2rem;
}
.anchormenu__menu nav a {
	font-size:1.2rem;
	color:inherit;
	display:inline-block;
	position:relative;
}
.anchormenu__menu nav a:before {
	content:"|";
	position:absolute;
	left:0;
}
.anchormenu__menu nav a:nth-of-type(1):before {
	display:none;
}

.anchormenu__menu nav a:visited {
	color:inherit;
}

/* ------------------------------------------ 
   Fenster Aufklapper
-------------------------------------------*/

.collapsed_content {
	overflow:hidden;
	font-size:13px;
	box-sizing:border-box;
}
.collapsed_content__header {
	background-color:var(--bg_dark);
	color:var(--bg_gray);
	text-align:center;
	padding:0.5rem;
	position:relative;
	cursor:pointer;
}
.collapsed_content .indicator {
	position:absolute;
	right:1rem;
	top:50%;
	transform:translateY(-50%) rotate(0deg);
	width:20px;
	height:20px;
	background:transparent url(collapse-icon.svg) no-repeat;
	background-size:100% auto;
	transition:transform 0.7s ease-in-out;
}

.collapsed_content__body {
	background-color:var(--bg_gray);
	text-align:center;
	padding:2rem;
}
.collapsed_content__body img {
	display:inline-block;
	max-width:100%;
	height:auto;
}
.collapsed_content .collapsed_content__body {
	max-height:1200px;
	transition: all 0.7s ease-in-out;
}
.collapsed_content.collapsed .collapsed_content__body {
	max-height:0;
	padding-top:0;
	padding-bottom:0;
}
.collapsed_content.collapsed .indicator {
	transform:translateY(-50%) rotate(-90deg);
}


.team {
	max-width:1020px;
	margin-left:auto;
	margin-right:auto;
}
.team .row {
	margin-top:2rem;
	justify-content:space-between;
}
.team__member {
	width:300px;
	text-align:left;
	margin-bottom:2rem;
}
.team__name {
	font-weight:600;
	padding:0.5rem 0 0.3rem 0;
}
.team__text {
}
.team__photo {
	width:300px;
	height:270px;
	background-size:cover;
}

@media all and (max-width:980px) {
	.team .row {
		justify-content:flex-start;
	}
	.team__member {
		margin:1rem;
	}
}


/* -----------------------------------------
    Toplink
-------------------------------------------- */

#toplink {
   position: fixed;
   bottom: 0;
   right: 1em;
   width: 40px;
   height: 40px;
   text-align: center;
   background-color: rgb(102,102,102);
   padding-top: 0.5em;
}


@media (max-width: 800px) {
   #toplink {display: none;}
}



body.home .videocover h2 {
	position: absolute;
    top: 40%;
    bottom: auto;
    left: 0;
    margin:0;
    text-align: center;
    width: 100%;
    background: transparent;
    padding: 20px 40px;
    font-weight:300;
    max-width: 100%;
    font-size: 50px;
    color: white;
    text-shadow: 1px 3px 8px rgba(0,0,0,1); 
    font-weight:600;
    animation: covertextfade 2s linear;

}

@media (max-width: 800px) {
     body.home .videocover h2 {
     	 font-size: 26px;
     	 padding:0;
     }
}


@keyframes covertextfade {
  0% { opacity: 0 }
  50% { opacity: 0 }
  100% { opacity: 1 }
}



.imgbox .headline__byline {
	width: 80%;
	margin: 2em auto;
}

@media (max-width: 800px) {
 
	.imgbox .headline__byline {
		width: 100%;
		margin: 2em auto;
	}
 
}


/* ----------------------------------------- */

.light { font-weight:300;}

/* -----------------------------------------
    Banner Box Center
-------------------------------------------- */

.banner__box__center {
}

.banner__box__center > div:last-child {
   padding-left: 2em;
   display: flex;
   align-items: center;
   justify-content: left;
 
}

/* -----------------------------------------
    Job Anzeige
-------------------------------------------- */

.job { width: 100%; max-width:100%; }
.job.bg__gray { padding: 3em 0; margin: 0 auto; }

.job__header  { text-align: center; margin-bottom: 2em; }
.job__header h2  { font-size: 56px; font-weight:700; transform: translateY(-10px); }
.job__header h4  { font-size: 28px; font-weight:700; }

.job__box {
   background-color: #eeeeee;
   padding: 40px;
}

.job__box__text {
   background-color: white;
   padding: 20px;
   margin-bottom:20px;
}
.job__box__text h3 { font-weight:700; margin-bottom: -7px; }

.job__box__text ul { list-style: none; }
.job__box__text ul li::before {
   content: "•"; 
   color: #FBBA00;
   font-weight: 900;
   display: inline-block; width: 1em;
   margin-left: -1em
}

/* -----------------------------------------
    JOB Footer
-------------------------------------------- */

.job__footer { padding: 1em 1em 0 1em;}
.job__footer h3 { font-weight: 700; font-size:20px;}
.job__footer__bannertext {font-size:28px; }





/* -----------------------------------------
    Stelelnanzeige Feature-Element
-------------------------------------------- */
/* section * { border: 1px solid red;} */
/* section.feature .row { border: 1px solid red;} */

/* Frame */

section.feature .container {    background: #efefef;  }
section.feature .container.wrapper {
   position: relative;
   padding: 40px;
   border-top: 1px solid #333;
}

/* Ikon */
.feature__ikon {
   position: absolute;
   left:50%;
   top:0;
   background-color: white;
   border: 7px solid #FFF;
   border-radius:50%;
   width: 40px;
   height:40px;
   transform: translate(-50%, -50%);
   
   background-image: url(/template/img/iko-ic.svg);
   background-repeat: no-repeat;
   background-size:100%;
   background-position: center center;

}

/* TOP Images  */
.feature__imagearea {
   display: grid;
   grid-gap: 1.25rem;
   grid-template-columns: repeat(3, 1fr);
   margin-bottom: 1.85rem;
}
.feature__imagearea figure { margin:0 !important; padding:0 !important; }



/* Features GRID  */
.feature__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(45%, 1fr));
  grid-gap: 2rem;
}

@media (max-width: 800px) {

    .feature__grid {
      display: grid;
      grid-template-columns: repeat(1, 1fr);
      grid-gap: 1.25rem;
    }

 
}



.feature__grid > div {
   background-color: white;   
   padding: 1.25em 1.5em 1.5em 5em ;
   background-image: url("https://wp10472167.server-he.de/img/ico-feature-haken.svg");
   background-repeat: no-repeat;
   background-position: left 1.5em top 2em;
   min-height: 80px;
   font-size:15px;
}

.feature__grid > div h4 { margin-bottom: 0; padding-bottom:0;}
.feature__grid > div  p {margin-top: 0;}

/* Footer Image */
.feature__footerimage * { margin:0; padding:0;}

/* About Company */
.feature__about .row { padding-top: 2em; padding-bottom: 4em;}
.feature__about .row > div { padding: 2em; }


/* Footer */
section .container.feature__footerbar { 
   position: relative;
   background-color: #666;
   color: white;
}

/* Footer Banner */
.feature__banner { 
   position: absolute;
   top: 0;
   left:50%;
   width: auto;
   text-align: center;
   padding: 0.5em 3em;
   transform: translate(-50%, -65%) rotate(-5deg);
   box-shadow: 2px 2px 8px rgba(0,0,0,0.5);
   height: auto;
   background-color: orange;
   font-size:22px;
}

.feature__footerbar .row {   padding:3em 0; }
.feature__footerbar .row > div {   padding:10px;   text-align: center; }
.feature__footerbar a { color: white; }
.feature__footerbar .ico-mail { padding-left:45px;   }
.feature__footerbar .ico-mail::before {
   	background-image: url('https://wp10472167.server-he.de/img/ico-mail.svg');
   	height: 35px;
	   width:35px;
}
.feature__footerbar .ico-tel { padding-left:45px;   }
.feature__footerbar .ico-tel::before {
   	background-image: url('https://wp10472167.server-he.de/img/ico-tel.svg');
   	height: 35px;
	   width:35px;
}

/* Basic  */

.ico {
   display: inline-block;
	position: relative;
   padding-left:45px;   
}
.ico-before::before {
	position: absolute;
   transform: translateY(-5px);
	top:0;
	left:0;
	height: 30px;
	width:30px;
	content:"";
	background-repeat: no-repeat;
	background-size: 100%;
	background-position: center;
}


  /* -----------------------------------------
    PIN :: Referenz-Compare-Modul
-------------------------------------------- */
.pin { 
   position: relative;
   padding-right:2em;
}


.pin__box,
.pin__box2 {
   position: absolute;
   display: block;
   top: 85%;
   left: 15px;
   background-color: white;
   width: 100%;
   min-width: 360px;
   min-height: 120px;
   transform: rotate(-2deg);
   z-index:3;
}
.pin__box2 {
    z-index:10;
    box-shadow: 0 2px 12px rgba(119,119,119,.8);
/* 	background-image: linear-gradient(130deg, rgba(0,0,0,0.10) 0%, white 50%, rgba(0,0,0,0.08) 100%); */
}



.pin__box:after,
.pin__box:before {
   content: " ";
   display: block;
   position: absolute;
   width: 50%;
   max-width: 320px;
   left: 17px;
   top: 60%;
   bottom: 17px;
   background: rgba(119,119,119,.8);
   box-shadow: 0 18px 12px rgba(119,119,119,.8);
/*    box-shadow: 0 15px 10px rgba(119,119,119,.8); */
   -webkit-transform: rotate(-3deg);
   transform: rotate(-3deg);
   z-index: 1;
}
.pin__box:after {
   left: auto;
   right: 17px;
   -webkit-transform: rotate(3deg);
   transform: rotate(3deg);
   z-index: 2;
	
	
}

.pin__sticker {
   position: absolute;
   top: 0;
   left: 50%;
   width: 50px;
   height: auto;
   transform: translate(-50%, -50%);
    
}

.pin__text {   padding-top: 1.5em; }
.pin__text > h3 { 
   font-size: 23px;  
   line-height: 1.2em;
   text-align: center;  
	padding-bottom: 0.5em;
	margin-bottom: 0;
	background-image: url(/img/yellow-underline.png);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: 80% auto ;
}


.pin__text table,
.pin__text tbody,
.pin__text table tr,
.pin__text table td {
   background: none;
   border: none;
   width: auto;
   padding-bottom:0;
   font-size:15px;
}
.pin__text table td {
   padding-rigt: 0;
}

.pin__text table tr td:first-child {
   max-width: 115px !important;
   font-weight: 700;
   padding-right: 0;
}
.pin__text table tr td:last-child {
   padding-left: 0;

}



@media (max-width: 800px) {

   .pin__text table tr td:first-child,
   .pin__text table tr td {
      display: block;
      width: 100% !important;
      text-align: center;
      max-width: 100% !important;
      padding-top:0;
   }
    .pin { 
      padding-right:0;
   }

   .pin__box2 {
      position: relative;
      display: block;
      top:0;
      left: 0;
      width: 100%;
      transform: rotate(0);
      margin-bottom:10px;
   }
   .pin__box { display: none;}
   
   .pin__box:after,
   .pin__box:before {display: none;}
 
}



/* -----------------------------
    3er-Teaser Susy-Support
   ----------------------------- */
.coli {
}

/* Box */
.coli__box {
    position: relative;
    text-align: left;
    background-color: white;
    border-radius: 0 0 8px 8px;
    border: 0;
    transition: 0.3s ease-in-out;
    padding-bottom: 1.3em;
    box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.3);
}

.coli__box:nth-child(2) {
    margin: 0 2em;
}

@media (max-width: 400px) {
    .coli__box:nth-child(2) {
        margin: 0 0 2em 0;
    }
}

/* Header */
.coli__head {
    background-color: #2198B7;
    color: white;
    padding: 10px 15px;
    font-size: 18px;
    text-align: center;
    font-weight: 600;
}

.colidark .coli__head {
    background-color: #666;
}

/* Image */
.coli__image {
    width: 100%;
    height: auto;
    overflow: hidden;
}

.coli__image img {
    display: block;
    width: 100% !important;
    height: auto;
    overflow: hidden;
    -webkit-transition: all 0.3s linear 0s;
    -moz-transition: all 0.3s linear 0s;
    -ms-transition: all 0.3s linear 0s;
    -o-transition: all 0.3s linear 0s;
    transition: all 0.3s linear 0s;
}

.coli__box:hover .coli__image img {
    -webkit-transform: scale(1.1);
    -moz-transform: scale(1.1);
    transform: scale(1.1);
}

.coli__image a:after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}

/* Aktiv-Status */
.coli__aktiv {
    background-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjRweCIgaGVpZ2h0PSIyNHB4IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+CiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4KICAgICAgICA8ZyBpZD0iaWNvLWxpbmsiPgogICAgICAgICAgICA8Y2lyY2xlIGlkPSJPdmFsIiBmaWxsPSIjMjE5OEI3IiBjeD0iMTIiIGN5PSIxMiIgcj0iMTIiPjwvY2lyY2xlPgogICAgICAgICAgICA8cG9seWdvbiBpZD0iU2hhcGUiIGZpbGw9IiNGRkZGRkYiIGZpbGwtcnVsZT0ibm9uemVybyIgcG9pbnRzPSIxMiA2LjM1Mjk0MTE4IDExLjAwNDcwNTkgNy4zNDgyMzUyOSAxNC45NDM1Mjk0IDExLjI5NDExNzYgNi4zNTI5NDExOCAxMS4yOTQxMTc2IDYuMzUyOTQxMTggMTIuNzA1ODgyNCAxNC45NDM1Mjk0IDEyLjcwNTg4MjQgMTEuMDA0NzA1OSAxNi42NTE3NjQ3IDEyIDE3LjY0NzA1ODggMTcuNjQ3MDU4OCAxMiI+PC9wb2x5Z29uPgogICAgICAgIDwvZz4KICAgIDwvZz4KPC9zdmc+");
    background-position: center bottom 15px;
    background-repeat: no-repeat;
    background-size: 24px;
    padding-bottom: 4em !important;
}

.coli__cover {
    background-size: cover;
    background-position: center center;
}

.coli__cover img {
    opacity: 0;
}

/* Content */
.coli__content {
    padding: 15px 20px 0px 20px;
    font-size: 16px;
    color: #545454;
    letter-spacing: 0;
    line-height: 21px;
}

/* -----------------------------
    SUSY-GRID System
   ----------------------------- */
/* Float or flex */
.susy {
    display: flex;
}

/* Setup */
.susy-item {
    --span: initial; /* avoid inheritance */
    --percentage: calc(var(--span) * 100%); 
    width: var(--percentage, initial);
}


.susy-1 {
    --span: 1/12; }

.susy-2 {
    --span: 2/12; }

.susy-3 {
    --span: 3/12; }

.susy-4 {
    --span: 4/12; }

.susy-5 {
    --span: 5/12; }

.susy-6 {
    --span: 6/12; }

.susy-7 {
    --span: 7/12; }

.susy-8 {
    --span: 8/12; }

.susy-9 {
    --span: 9/12; }

.susy-10 {
    --span: 10/12; }

.susy-11 {
    --span: 11/12; }

.susy-12 {
    --span: 12/12; }

 .susy5 {  --span: 1/5; }

.susycolpad .susy-item             { padding-left: 1em; padding-right: 1em; } 
.susycolpad .susy-item:first-child { padding-left: 0; }
.susycolpad .susy-item:last-child  { padding-right: 0; }

.susy-vline .susy-item { border-right: 1px solid #2198B7; }
.susy-vline .susy-item:last-child { border-right: 0; }


/* NEWSFIX */



.newsindex { 
    width:860px;
    margin: 0 auto;
}

@media (max-width: 800px) {
     width: 100%;
}

.newsposter {
    margin-bottom: 2em;
    padding:  0 0 2em;
    border-bottom: 1px dotted gray;
}

.newsposter h2 {
    text-align: center;
    margin-bottom: 1em;
    font-size: 44px;
}

.newsposter h2 a {
    color: gray;
    line-height: 1em;

}

.newsposter .row p { 
    margin-left: 0;  
    margin-right: 0;
}

.newsposter__image img {
    margin-bottom: 2em;
}

.news__grid {
  position: :relative;
    width: calc(100% + 15px);
  transform: translateX(-10px);
}

.news__grid .cardnews figure {
    position: relative;
    display: block;
    margin: 0 0 1em 0; 
    height: 280px !important;
    width:100%;
    overflow:hidden;
    box-sizing: border-box;
}

.news__grid .cardnews figure img {
    width:100%;
    height:100%;
    object-fit: cover;
    transition: transform .75s;
}

.news__grid .cardnews:hover figure img {
	transform: scale(1.2);
}

.news__grid .cardnews .news-entry {
    padding: 0 1.5em 1.5em 1.5em;
}

.news-entry-teaser {
    font-size: 16px;
    text-align: center;
}

.news-entry-teaser p {font-size: 16px !important;}

.news-entry-teaser .more-link {
	display: block;
}

.news-entry h3,
.news-entry h3 a {
    text-align: center;
    font-size: 24px;
    line-height: 1.2em;
    margin-top: 0;
    padding-top: 0;
    font-weight: 900 !important;
    color: rgb(103, 103, 103);
}


/* -----------------------------------------
    NEWSPAGE
-------------------------------------------- */

.newspage {
   max-width: 860px;
   margin: 0 auto;
}

.newspage h2,
.newspage p {
   margin: auto 0;
}

.newspage h2 {
   font-size: 48px;
   font-weight: 500;
   margin-bottom: 1.3rem;
}

.newspage .news-byline { 
   margin-bottom: 1.5em;
   font-size: 22px;
}

.newspage .newscover { 
   margin-bottom: 1.2em;
}

.newsartikel img { margin: 1.20em 0;}
.newsartikel p {margin-bottom: 1em;}


/* -----------------------------------------
    NEWS GRID
-------------------------------------------- */


.news__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(45%, 1fr));
  grid-gap: 1rem;
}



@media (max-width: 800px) {


    .news__grid {
      display: block !important;
    }



     .newsindex {
 	    width:100% !important;
     }

    .newsposter h2 {
        font-size: 22px !important;
    }



}




@media (max-width: 800px) {
    
    .susy-vline .susy-item { border: 0; }
    
    .susy {
        display: block;
    }

    .susy-item {
        width: 100%;
        margin-bottom: 2em;
    }

    .susycolpad .susy-item { 
        padding-left: 10px !important; 
        padding-right: 10px  !important;
     } 
}




/* -----------------------------------------
    Page-Header
-------------------------------------------- */
.pageheader {
	background-color: #333; 
	margin-bottom: 3em;
}

.pageheader h1 { 
	color: white; 
	font-size: 28px !important;
    padding: 30px 40px 30px 65px;
    max-width: 100% !important;
    margin: 0 auto;
    box-sizing: border-box;
}
@media (max-width: 800px) {
	section.pageheader {
		margin-top:0; 
		margin-bottom: 2em;
	}
	
	
    .pageheader h1 { 
    	color: white; 
		font-size: 20px !important;
		padding: 30px 15px !important;
		margin-top: 0;
    }
 
}

/* -----------------------------------------
    yform-Formulare
-------------------------------------------- */
.yform form { 
	background-color:transparent;
	border:none;
	padding:0;
}
.yform .alert {
	max-width:550px;
	padding:1rem;
	background-color:#ddd;
	margin:1rem auto;
}

#yform-formular-katalog_sicherheit {
	border-top:1px dotted #888 !important;
	margin-top: 2em;
}


.formbuilder-form .formcheckbox label {
	display:flex;
	border-bottom:1px dotted #888;
	padding:1rem 0;
}
.formbuilder-form .formcheckbox label input[type="checkbox"] {
	flex-shrink:0;
}
.formbuilder-form .inline-row {
	display:flex;
	margin-left:2rem;
	width:100%;
}

.formbuilder-form .inline-row .option_img {
	width:20%;
	text-align:center;
	
}
.formbuilder-form .inline-row .option_text {
	padding-left:1rem;
}
.formbuilder-form .inline-row .option_title {
	display:block;
}
.formbuilder-form .inline-row .option_subline {
}


.formbuilder-form fieldset {
	margin-bottom: 1.5em;
}

.formbuilder-form fieldset legend {
	font-size: 22px;
}


.formbuilder-form fieldset.field-group {
	border:none;
	display:flex;
	width:100%;
}
.formbuilder-form fieldset.field-single {
	border:none;
	display:block;
}

.formbuilder-form fieldset.field-group .form-group {
	width:50%;
	padding:0 1rem 0 0;
}

.formbuilder-form fieldset.field-group .control-label,
.formbuilder-form fieldset.field-single .control-label {
	display:block;
}

.formbuilder-form fieldset input.form-control[type="text"],
.formbuilder-form fieldset textarea.form-control {
	width:100%;
}

.formbuilder-form fieldset.field-single .option_label {
	margin-left:1rem;
	display:inline-block;
	flex-shrink:1;
}


/* Slick Slider Basic Settings   */
.slick-slider {
    position: relative;
    display: block;
    box-sizing: border-box;
    width: 100%;
    max-width: 1600px;
    margin: 0 auto;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list {
    position: relative;
    overflow: hidden;
    display: block;
    margin: 0;
    padding: 0;
    &:focus {
        outline: none;
    }

    &.dragging {
        cursor: pointer;
        cursor: hand;
    }
}

.slick-slider .slick-track, .slick-slider .slick-list {
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.slick-track {
    position: relative;
    left: 0;
    top: 0;
    display: block;
    margin-left: auto;
    margin-right: auto;
    &:before, &:after {
        content: "";
        display: table;
    }

    &:after {
        clear: both;
    }

    .slick-loading & {
        visibility: hidden;
    }
}
 
.slick-slide {
    float: left;
    height: 100%;
    min-height: 1px;
    [dir="rtl"] & {
        float: right;
    }

    img {
        display: block;
    }

    &.slick-loading img {
        display: none;
    }

    display: none;
    &.dragging img {
        pointer-events: none;
    }

    .slick-initialized & {
        display: block;
    }

    .slick-loading & {
        visibility: hidden;
    }

    .slick-vertical & {
        display: block;
        height: auto;
        border: 1px solid transparent;
    }
}

.slick-arrow.slick-hidden {
    display: none;
}



/* -----------------------------------------
Class Sparaktion
-------------------------------------------- */

.spa-sidebox,
.spa-head {

color: white;
padding: 2em !important;
}

.spa-sidebox {
font-size: 19px;
background: rgb(103,103,103);
}

.spa-head {
background-image: linear-gradient(27deg, rgb(227, 6, 19) 0%, rgb(174, 15, 10) 100%);
font-size: 19px;
}

.spa-head h2 { font-size: 2.7em; }
.spa-head ul  { margin-left: 21px; }
/* .spa-head ul li { font-size: 1.3em; } */
.spa-sidebox h3 { font-size:1.8em;}
/* .spa-sidebox p { font-size:19px;} */

@media (max-width: 800px) {
.spa-head h2 { font-size: 28px; }
.spa-sidebox h3 { font-size: 26px; }
}

.spa-head-money {
background-image: url('/img/GAYKOSparaktion2020-fs.jpg');
background-size: 100% auto;
background-position: center bottom;
background-repeat: no-repeat; 
}

.spa-promo sup {
font-size: 14px;
}

.spa-promo-box {
text-align: center;
padding: 1.5em !important;
line-height: 1.3em;
}

.spa-promo-box h3 {
font-size: 2em;
font-weight: bold;
margin: 0 0 8px;
line-height: 1.2em;

}
.spa-promo-box h3 > span {
font-size: 26px;
font-weight: 300;
}

.spa-promo-box p {
font-size: 21px;
font-weight: 600;
}

.spa-promo-box p.f18 {
font-size: 17px;
font-weight: 600;
}

.bgred { 
background-color: rgb(174, 15, 10);
padding: 5px 12px; 
color: white; 
font-weight: 900 !important; 
font-size: 20px !important;
}

.spa-promo-box {
  background-color: #e6f5fa; 
  /* height: 100%; */
}

.spa-head-text { 
padding: 2em; 
font-size: 17px;
}
.spa-head-text h3 { 
margin:0 0 8px 0;
padding: 0;
font-size: 1.7em;
}

.mini-info { font-size: 15px; text-align: left;}
.mini-info sup { font-size: 12px; }


.spa-sign {
color: #01afd2;
margin-top: 0px;
margin-bottom: 0px;
font-size: 120px;
line-height: 1;
text-align: center;
}

.mobile-divider {
margin: 3em 0;
display: none;
}

@media (max-width: 800px) {
.mobile-divider {
  display: block;
}

}

.uk-button-primary { color:white !important; background-color: #FBBA00 !important; }
