body,form,figure{margin:0;padding:0}img{border:0}header,footer,nav,section,aside,article,figure,figcaption{display:block}body{font-size:100.01%}select,input,textarea{font-size:99%}#container,.inside{position:relative}#main,#left,#right{float:left;position:relative}#main{width:100%}#left{margin-left:-100%}#right{margin-right:-100%}#footer{clear:both}#main .inside{min-height:1px}.ce_gallery>ul,.content-gallery>ul{margin:0;padding:0;overflow:hidden;list-style:none}.ce_gallery>ul li,.content-gallery>ul li{float:left}.ce_gallery>ul li.col_first,.content-gallery>ul li.col_first{clear:left}.float_left,.media--left>figure{float:left}.float_right,.media--right>figure{float:right}.block{overflow:hidden}.media{display:flow-root}.clear,#clear{height:.1px;font-size:.1px;line-height:.1px;clear:both}.invisible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.custom{display:block}#container:after,.custom:after{content:"";display:table;clear:both}
@media (max-width:767px){#wrapper{margin:0;width:auto}#container{padding-left:0;padding-right:0}#main,#left,#right{float:none;width:auto}#left{right:0;margin-left:0}#right{margin-right:0}}img{max-width:100%;height:auto}.audio_container audio{max-width:100%}.video_container video{max-width:100%;height:auto}.aspect,.responsive{position:relative;height:0}.aspect iframe,.responsive iframe{position:absolute;top:0;left:0;width:100%;height:100%}.aspect--16\:9,.responsive.ratio-169{padding-bottom:56.25%}.aspect--16\:10,.responsive.ratio-1610{padding-bottom:62.5%}.aspect--21\:9,.responsive.ratio-219{padding-bottom:42.8571%}.aspect--4\:3,.responsive.ratio-43{padding-bottom:75%}.aspect--3\:2,.responsive.ratio-32{padding-bottom:66.6666%}
.content-slider{overflow:hidden;visibility:hidden;position:relative}.slider-wrapper{overflow:hidden;position:relative}.slider-wrapper>*{float:left;width:100%;position:relative}.slider-control{height:30px;position:relative}.slider-control a,.slider-control .slider-menu{position:absolute;top:9px;display:inline-block}.slider-control .slider-prev{left:0}.slider-control .slider-next{right:0}.slider-control .slider-menu{top:0;width:50%;left:50%;margin-left:-25%;font-size:27px;text-align:center}.slider-control .slider-menu b{color:#bbb;cursor:pointer}.slider-control .slider-menu b.active{color:#666}
* {
    padding:0;
    margin:0;
    text-size-adjust: none;
        -webkit-text-size-adjust: none;
        -moz-text-size-adjust: none;
        -ms-text-size-adjust: none;
}
*:focus {
outline: none;
}
img {
	display:block;
}
html,
body {
    margin:0;
    padding:0;
}
body {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  color:#000000;
}
.content-text h1 {
	font-size:1.5em;
  text-transform: uppercase;
}
h2 {
	text-transform:uppercase;
}
.bereiche h2 {
	font-weight: 700;
	font-size: 30px;
	line-height: 1.4em;
	text-transform:unset;
}
.headline-large h1,
h1.headline-large,
.headline-large h2,
h2.headline-large{
	font-weight: 700;
	font-size: 35px;
	text-transform:unset;
	margin-bottom:15px;
}
p.strong {
	font-weight:bold;
}
.bg-grau h2.headline-large {
	margin-bottom:30px;
}
.text-medium p,
.text-medium ul li{
font-size: 20px;
line-height: 28px;
	font-weight: 400;
}
.content .text-medium {
	padding-right:50px;
	box-sizing:border-box;
}
p.small {
	font-size: 14px;
	line-height: unset;
}
.mod_article.content:nth-child(odd) .text-medium {
	padding-right:0;
	padding-left:50px;
}
header,
.bg-grau,
.slider-images.slider-grau{
	background-color:#c4c5c5;
}
header {
	position:relative;
	width:100%;
	padding-top:40px;
	z-index:50;
	display:inline-block;
}
.max-width,
.header,
.footer{
	max-width: 1220px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
	box-sizing: border-box;
}
.logo {
	max-width:200px;
	display:inline-block;
}
header .icons,
.cta icons{
  padding-top: 12px;
  padding-bottom: 12px;
  float:right;
  padding-top:38px;
}
header .icons a,
.cta .icons a {
  text-decoration: none;
  color: #fff;
  height: 30px;
  width: 30px;
  border: 1px solid #000000;
  padding: 5px;
  box-sizing: border-box;
  position: relative;
  display: inline-block;
  float: left;
	margin-left: 10px;
}
header .icons img,
.cta .icons img {
	height:20px;
	width:auto;
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
/*.slider-images {
float: left;
width: 100%;
display:inline-block;
}*/
.slider-menu b {
	width: 50px;
	height: 4px;
	background-color: #000000;
	position:relative;
	display:inline-block;
	margin-left:8px;
	margin-right:8px;
}
.slider-menu b.active {
	background-color:#bc1732;
}
.slider-control .slider-menu {
	font-size:0;
}
.image-overlay {
position: absolute;
top: 50px;
right: 0;
color: #000000;
font-weight: bold;
font-size:30px;
line-height:1.4em;
/*text-shadow:0 0 60px #ffffff, 0 0 60px #ffffff, 0 0 60px #ffffff;*/
max-width: 300px;
float: right;
width: 100%;
padding-right: 50px;
box-sizing: border-box;
}
.image-overlay mark {
background-color: rgba(255,255,255,0.7);
border-top: 3px solid transparent;
padding: 0 8px;
-webkit-box-decoration-break: clone;
box-decoration-break: clone;
display:inline;
}
/*.image-overlay p{
	display: block;
    padding: .25em 0;
    background: rgba(255,255,255,0.5);
    color: #ffffff;
}*/
.slider-prev,
.slider-next {
	display:none !important;
}
.slider-menu {
	margin-top:15px;
}
.slider-control {
  height: 62px;
}
#footer {
	background-color:#c4c5c5;
	padding-top:50px;
	padding-bottom:50px;
}
.footer {
  width: 100%;
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  color: #000000;
  font-weight:500;
}
.footer a {
	color:#000000;
	text-decoration:none;
}
.footer .social a{
	width:30px;
	height:30px;
	float:left;
	padding-right:5px;
	position:relative;
	text-align:center;
	display:flex;
	align-items:flex-end;
}
.footer .social a:last-of-type {
	margin-right:0;
}
.footer .social img{
	max-width:30px;
	max-height:30px;
	width:auto;
	height:auto;
	/*position:absolute;
	bottom:0;*/
	margin-left: auto;
	margin-right: auto;
}
.footer img.marken{
	max-width:50px;
	height:auto;
}
.footer .logo {
	max-width:130px;
}
.footer nav a {
	text-decoration:underline;
}
/* content */
.cta .text-large{
	width:calc(100% - 130px);
	font-weight: 700;
	font-size: 30px;
	line-height: 1.4em;
}
.cta .text-large h1,
.cta .text-large h2 {
	font-weight: 700;
	font-size: 30px;
	line-height: 1.4em;
	text-transform:unset;
}
.cta .icons {
	position:absolute;
	right:20px;
	top: 50%;
	transform: translateY(-50%);
}
.cta .icons a{
	display:block;
	float:none;
}
/*.cta .icons a:nth-child(1),
.cta .icons a:nth-child(2){
	margin-bottom:10px;
}*/
.cta .icons a:not(last-of-type){
	margin-bottom:10px;
}
.cta,
.referenzen,
.slider-element{
	padding-top:100px;
	padding-bottom:100px;
	position:relative;
}
.bereiche .ce_text {
	padding:0 50px 50px 50px;
}
.bereiche .ce_text:nth-child(1) {
	background-color:rgba(196,197,197,0.3);
}
.bereiche .ce_text:nth-child(2) {
	background-color:rgba(196,197,197,0.6);
}
.bereiche .ce_text:nth-child(3) {
	background-color:rgba(196,197,197,1);
}
.col-3 {
	display: grid;
grid-template-columns: repeat(3, 1fr);
grid-gap: 0;
}
.col-2 {
	display: grid;
grid-template-columns: repeat(2, 1fr);
grid-gap: 0;
}
.bereiche h2 {
	padding-top:30px;
	padding-bottom:30px;
}
/* referenzen */
.referenzen-text {
width:calc(100% / 3);
float:left;
padding-right:80px;
box-sizing:border-box;
	position:absolute;
	left:20px;
	top: 50%;
	transform: translateY(-50%);
	padding-bottom:45px;
}
.elemente-slider,
.referenzen-slider {
width:calc(100% / 1.5);
float:right;
margin:unset;
}
.referenzen-slider .container,
.referenzen-slider .wrap,
.elemente-slider .container,
.elemente-slider .wrap{
	margin:unset;
}
.referenzen-slider .frame,
.elemente-slider .frame{
  height: 300px;
  line-height: 300px;
}
.referenzen-slider .frame ul li,
.elemente-slider .frame ul li{
	cursor:unset;
	width: 200px;
	height: 100%;
	margin: 0px 12px 0 0;
}
.referenzen-slider .scrollbar,
.elemente-slider .scrollbar{
	background:#c4c5c5;
}
.referenzen-slider.auto-size .frame ul li,
.elemente-slider.auto-size .frame ul li{
cursor: unset;
width: auto;
height: 100%;
margin: 0px 12px 0 0;
max-width: 300px;
}
.news .referenzen-slider.auto-size .frame ul li,
.news .elemente-slider.auto-size .frame ul li{
cursor: unset;
width: auto;
height: 100%;
margin: 0px 12px 0 0;
max-width: 600px;
}
.referenzen-slider.auto-size .frame ul li img,
.elemente-slider.auto-size .frame ul li img{
width:auto;
height:300px;
}
.kataloge.elemente-slider.auto-size .frame ul li img{
width:auto;
height:298px;
}
.kataloge.elemente-slider figure {
	border:1px solid #c4c5c5;
}
/* service */
.bg-grau.service {
	padding-top:75px;
	padding-bottom:75px;
}
.bg-grau .col-3 {
	grid-gap:20px
}
.bg-grau .col-3 .ce_text:nth-child(3) {
	position:relative;
}
.bg-grau .col-3 .ce_text:nth-child(3) p{
	position:absolute;
	top: 50%;
	transform: translateY(-50%);
	padding-left:20px;
}
.bg-grau .col-3 .ce_text:nth-child(3).langer-text p{
	position:relative;
	top: 0;
	transform: unset;
	padding-left:20px;
}
.langer-text ul {
	margin-left:20px;
}
.bg-grau .ce_text {
	overflow:visible;
	padding-left:20px;
}
.bg-grau .col-2 .ce_text.relative:nth-child(2) p {
	position:relative;
}
/* unternehmen */
.bg-grau .col-2 .ce_text:nth-child(2) {
	position:relative;
}
.bg-grau.text-center .col-2 .ce_text:nth-child(2) p{
	position:absolute;
	top: 50%;
	transform: translateY(-50%);
	padding-left:20px;
}
.bg-grau.above-fold {
	/*padding-top:50px;*/
	padding-bottom:50px;
	margin-bottom:100px;
}
/*
.above-fold .text-medium {
	margin-top:20px;
}
*/
.above-fold .text-medium p {
	line-height:32px;
}
/* standorte */
.content {
	margin-top:100px;
	margin-bottom:50px;
}
.content.standorte p {
	margin-top:1em;
}
/*.content.standorte img {
	max-width: 265px;
	margin-left: auto;
	margin-right: auto;
	padding: 10px;
	box-sizing: border-box;
}*/
.content a {
	color:#000000;
	text-decoration:none;
}
/*.standorte .image_container{
	border:1px solid #c4c5c5;
}*/
.content.standorte:nth-child(odd) .ce_text {
	padding-left:30px;
	box-sizing:border-box;
}
.content.standorte:last-of-type {
	margin-bottom:100px;
}
/* grid 3 3 */
.grid-3-3 {
		display: grid;
		grid-template-columns: 1fr 1fr 1fr;
		grid-template-rows: 1fr 1fr 1fr;
		grid-gap:20px;
}
.grid-3-3 div:nth-child(1) {
grid-column-start: 1;
grid-column-end: 1;
grid-row-start: 1;
grid-row-end: 3;
}
.grid-3-3 div:nth-child(2) {
grid-column-start: 1;
grid-column-end: 1;
grid-row-start: 3;
grid-row-end: 4;
}
.grid-3-3 div:nth-child(3) {
grid-column-start: 2;
grid-column-end: 2;
grid-row-start: 1;
grid-row-end: 2;
}
.grid-3-3 div:nth-child(4) {
grid-column-start: 2;
grid-column-end: 2;
grid-row-start: 2;
grid-row-end: 4;
}
.grid-3-3 div:nth-child(5) {
grid-column-start: 3;
grid-column-end: 3;
grid-row-start: 1;
grid-row-end: 2;
}
.grid-3-3 div:nth-child(6) {
grid-column-start: 3;
grid-column-end: 3;
grid-row-start: 2;
grid-row-end: 4;
}

/*.grid-3-3 div:nth-child(1) {
grid-column-start: 1;
grid-column-end: 1;
grid-row-start: 1;
grid-row-end: 4;
}
.grid-3-3 div:nth-child(2) {
grid-column-start: 2;
grid-column-end: 2;
grid-row-start: 1;
grid-row-end: 3;
}
.grid-3-3 div:nth-child(3) {
grid-column-start: 2;
grid-column-end: 2;
grid-row-start: 3;
grid-row-end: 4;
}
.grid-3-3 div:nth-child(4) {
grid-column-start: 3;
grid-column-end: 3;
grid-row-start: 1;
grid-row-end: 2;
}
.grid-3-3 div:nth-child(5) {
grid-column-start: 3;
grid-column-end: 3;
grid-row-start: 2;
grid-row-end: 4;
}
*/
.grid-3-3 figure {
	width:100%;
	height:100%;
}
.grid-3-3 img {
object-fit: cover;
height: 100%;
width: 100%;
}
.grid-3-3 figcaption {
	text-align:center;
	display:none;
}
.grid-3-3 .ce_image:hover figcaption {
	display:block;
}
.absolute-center {
  position:relative;
}
.absolute-center .inside-wrapper{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  padding-left: 20px;
}
.padding-standard {
	padding-top:50px;
	padding-bottom:100px;
}
.bereiche .ce_text {
	position:relative;
}
a.bereiche-mehr {
	position: absolute;
	display: block;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	text-indent: -9999px;
	z-index: 1000;
}
.ce_text a {
	color:#000000;
}
/*a.cta-btn {
color: #000000;
border: 3px solid #bc1732;
padding: 10px 20px;
text-decoration: none;
font-weight: 700;
font-size: 18px;
display: inline-block;
float: left;
margin-right: 10px;
margin-bottom: 10px;
width: auto;
text-align: center;
box-sizing: border-box;
background-color:#ffffff;
}*/
/*a.cta-btn:hover {
	background-color:#c4c5c5;
}*/
a.cta-btn{
color: #ffffff;
padding: 10px 20px;
text-decoration: none;
font-weight: normal;
font-size: 18px;
display: inline-block;
float: left;
margin-right: 10px;
margin-bottom: 10px;
width: auto;
text-align: center;
box-sizing: border-box;
background-color:#000000;
line-height:22px;
}
a.cta-btn:hover{
	background-color:#bc1732;
}
.details-slider td a.cta-btn {
  margin-top: 8px;
}
.produkte a.cta-btn {
min-width: calc(50% - 30px);
}
.text-medium h1 {
	font-size:1.5em;
}
.sale .text-medium h2,
.sale .col-2.details-slider .text-medium h2{
	font-size:1.5em;
	font-weight:bold;
}
.text-medium h1,
.text-medium h2 {
	text-transform:unset;
}
.col-2.details-slider .text-medium h2,
.text-medium h3 {
	font-size:14px;
	font-weight:normal;
}
.text-medium table {
	border:0;
	margin-top:30px;
	font-size: 16px;
	line-height: 28px;
	font-weight:400;
}
.text-medium table p {
  font-size: 16px;
  line-height: 28px;
  margin-bottom:0;
}
.text-medium table td {
	border:0;
	vertical-align:top;
}
.text-medium table td:first-of-type {
	padding-right:20px;
	font-weight:700;
}
.text-medium.relative {
	margin-top:5px;
}
/* innen aussen */
mark {
	  background-color: rgba(255,255,255,0.7);
  border-top: 3px solid transparent;
  padding: 0 8px;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  display: inline;
}
figure {
	position:relative;
}
figcaption {
position: absolute;
top: 30px;
right: 0;
color: #000000;
font-weight: bold;
font-size: 30px;
line-height: 1.4em;
/*text-shadow: 0 0 60px #ffffff, 0 0 60px #ffffff, 0 0 60px #ffffff;*/
max-width: 100%;
float: left;
width: 100%;
padding-left: 20px;
box-sizing: border-box;
padding-right: 20px;
text-align:left;
}
.grau-filter img,
.filter-grau img{
	filter: grayscale(60%) brightness(100%);
}
.grau-filter-hell img,
.filter-grau-hell img{
	filter: grayscale(20%) brightness(100%);
}
.dark-slider .grau-filter img,
.dark-slider  .filter-grau img{
	filter: grayscale(50%) brightness(70%);
}
.hover-text figcaption {
	display:none;
}
.hover-text:hover figcaption{
	display:block;
}
.content-text {
	margin-top:50px;
	margin-bottom:50px;
}
.content.left-right .ce_text {
  padding-left: 30px;
  box-sizing: border-box;
}
.content-bg .ce_image img{
	max-width:590px;
	float:right;
}
.content-bg:nth-child(odd) {
	background-color:rgba(196,197,197,0.6);
	padding-top:50px;
	padding-bottom:50px;
	margin-top:100px;
}
.content-text {
	font-size:18px;
  line-height:25px;
  margin-top:50px;
  margin-bottom:100px;
}
.ce_text.fliesstext{
  column-count: 3;
  column-gap: 20px;
  font-size:18px;
  line-height:25px;
  margin-top:36px;
}
.ce_text.fliesstext-2{
  column-count: 2;
  column-gap: 40px;
  font-size:18px;
  line-height:25px;
  margin-top:36px;
}
.ce_text strong {
	font-weight:bold;
}
.spacer {
	margin-top:100px;
	margin-bottom:100px;
}
.no-spacer {
	margin-bottom:0;
}
.no-spacer.bg-grau.above-fold {
	margin-bottom:0;
}
.sale figcaption {
	right: 0;
	left: unset;
	float: right;
	max-width: 230px;
	font-size: 20px;
}
.small-text figcaption mark,
.sale figcaption mark {
	border-top:0;
}
.sale .ce_text {
	max-width:600px;
}
mark.red {
  background-color: rgba(160,25,51,0.85);
}
mark.red-text {
	color:#bc1732;
}
mark.large {
color: #bc1732;
font-size: 55px;
margin-bottom: 32px;
display: inline-block;
line-height: 55px;
}
.small-text figcaption {
	font-size:20px;
}
.gh-login label,
.gh-login input{
	float:left;
	clear:both;
}
.gh-login input{
	line-height: 28px;
border-radius: 0;
border: 1px solid #000;
padding-left:5px;
padding-right:5px;
box-sizing:border-box;
}
/*.gh-login button.submit {
	float: left;
	clear: both;
	margin-top: 15px;
	border: 2px solid #bc1732;
	padding: 8px 20px;
	background-color: #ffffff;
	font-weight:bold;
	cursor:pointer;
}
.gh-login button.submit:hover {
	background-color: #c4c5c5;
}*/
.gh-login button.submit {
	float: left;
	clear: both;
	margin-top: 15px;
padding: 10px 20px;
background-color:#000000;
text-decoration: none;
font-weight: normal;
font-size: 18px;
	font-weight:bold;
	cursor:pointer;
color: #ffffff;
border:0;
}
.gh-login button.submit{
color: #ffffff;
padding: 10px 20px;
text-decoration: none;
font-weight: normal;
font-size: 18px;
display: inline-block;
float: left;
width: auto;
text-align: center;
box-sizing: border-box;
background-color:#000000;
}
.gh-login button.submit:hover{
	background-color:#bc1732;
}
p.small,
.above-fold .text-medium p.small,
p.login_info,
.above-fold .text-medium p.login_info{
	font-size: 16px;
	line-height: 22px;
}
.mod_login {
	margin-top:10px;
	margin-bottom:10px;
}
.ul-liste ul li {
	list-style-type: none;
	font-size:18px;
	position:relative;
	margin-left:20px;
}
.ce_text ul li:before {
content: "︎";
background-image: url('/files/img/bernit_icon.png');
color: #e78f1a;
position: absolute;
top: 9px;
left: -20px;
font-size: 0.9em;
width: 12px;
height: 12px;
background-position: center center;
background-size: contain;
background-repeat: no-repeat;
}
mark.rot{
	color:rgba(188,23,50,1)
}
/*.scrollbar .handle {
	max-width:200px !important;
}*/
.text-medium p, .text-medium ul li {
	line-height:unset;
}
.ce_text.ul-liste.langer-text ul {
	margin-top:10px;
}
.ce_text ul li::before {
  content: "︎";
  background-image: url('/files/img/bernit_icon.png');
  color: #e78f1a;
  position: absolute;
  top: 4px;
  left: -20px;
  font-size: 0.9em;
  width: 16px;
  height: 16px;
  background-position: center center;
  background-size: contain;
  background-repeat: no-repeat;
}
.details-slider a.cta-btn {
	min-width:48%;
}
.position-relative {
	position:relative;
}
.no-padding-top {
	padding-top:0;
}
/* media */
a.mobile {
	display:none;
}
.phone-number span {
width: 100%;
min-width: 117px;
right: 60px;
display: inline;
color: #000000;
border: 1px solid #000000;
box-sizing: border-box;
height: 30px;
line-height: 30px;
padding-left: 10px;
padding-right: 10px;
top: 0;
}
.tel-anzeige {
	float: right;
	position: absolute;
	right: 29px;
	height: 30px;
	line-height: 30px;
	border: 1px solid;
	  border-right-color: currentcolor;
	  border-right-style: solid;
	  border-right-width: 1px;
	box-sizing: border-box;
	background-color: #fff;
	z-index: 10;
	display: block;
	border-right: 1px solid #fff;
	width:0;
	font-size:0;
}
div.icons .tel-anzeige a {
	color:#000000;
	text-decoration:none;
	font-weight:bold;
	height:auto;
	width:auto;
	border:none;
	padding:0;
	float:none;
	margin:0;
}
div.icons.show .tel-anzeige{
	width:auto;
	font-size:16px;
	transition:all ease 1s;
	padding-left: 7px;
	padding-right: 7px;
}
div.icons .tel-icon {
	cursor:pointer;
}
.tel-anzeige,
div.icons a.tel-icon {
	display:block;
}
div.icons a.tel-icon.mobile {
	display:none;
}
.header-kontakt .icons {
	position:relative;
}
.header-kontakt .tel-anzeige {
	background-color:#c4c5c5;
	border-right:1px solid #c4c5c5;
	right:109px;
}
/* popup */
body.hide-popup #popup {
	display:none;
}
#popup {
position: fixed;
top: 0;
right: 0;
bottom: 0;
left: 0;
background: rgba(255,255,255,0.8);
z-index: 100;
height: 100vh;
overflow-y: scroll;
}
.popup {
	margin-top:30px;
	margin-bottom:30px;
	border:1px solid #bc1732;
	padding:20px;
	background-color:#ffffff;
	max-width:650px;
	margin-left:auto;
	margin-right:auto;
	position:relative;
	overflow:visible;
}
.popup figure {
	width:41%;
	padding-left:50px;
	padding-bottom:50px;
}
.popup-logo figure {
	max-width:200px;
	width:100%;
	padding-left:0;
	padding-bottom:0;
}
.popup-logo {
	max-width:200px;
	margin-bottom:50px;
}
.popup-footer {
	font-size:12px;
	margin-top:50px;
}
#popup .inside {
	padding-left:30px;
	padding-right:30px;
	position: absolute;
	left: 20px;
	top: 50%;
	transform: translateY(-50%);
	width: 100%;
}
#popup.fit-window .inside {
	position:relative;
	top:initial;
	transform:none;
	left:initial;
	margin-left: auto;
	margin-right: auto;
}
.hinweis {
	margin-top:3em;
	font-size:13px;
	line-height:auto;
}
.logo img.dark {
	display:none;
}
#footer {
	line-height:1.5em;
}
.headline-block h1{
	margin-top:50px;
	margin-bottom:50px;
}
.headline-block.headline-margin {
	margin-bottom:-100px;
}
.juicer-feed-wrapper {
	margin-top:50px;
	margin-bottom:50px;
}
.juicer-feed .j-paginate {
  color: #ffffff !important;
  padding: 10px 20px !important;
  text-decoration: none !important;
  font-weight: normal !important;
  font-size: 18px !important;
  display: inline-block !important;
  margin-right: 10px !important;
  margin-bottom: 10px !important;
  width: auto !important;
  text-align: center !important;
  background-color: #000000 !important;
  box-sizing: border-box;
  line-height: 22px;
  border-radius: unset !important;
  text-transform: unset !important;
  letter-spacing: unset !important;
  border:0 !important;
  transition:none !important;
}
.juicer-feed .j-paginate:hover {
	background-color: #bc1732 !important;
}
.spacer-bottom {
	margin-bottom:50px;
}
mark.rabatt {
	background-color: #bc1732;
  color: #ffffff;
  padding: 80px 10px 10px 10px;
  line-height: 30px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 60px;
  text-align: center;
  float: right;
}
mark.rabatt span.small {
	font-size: 18px;
  letter-spacing: normal;
}
mark.gutschein {
	background-color: #bc1732;
  color: #ffffff;
  padding: 80px 15px 5px 15px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 60px;
  text-align: center;
  float: right;
  line-height: 20px;
  position: relative;
}
mark.gutschein span.small {
	font-size: 20px;
  display: block;
  font-weight: normal;
  letter-spacing: 0.1em;
  line-height: 25px;
}
mark.gutschein span.small.extra {
  letter-spacing: -0.008em;
}
mark.gutschein span.large {
	line-height: 75px;
  display: inline-block;
  font-size: 55px;
  letter-spacing: 0.02em;
  font-weight: normal;
}
/* roboto-100 - 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: 'Roboto';
  font-style: normal;
  font-weight: 100;
  src: url('../../files/fonts/roboto-v30-latin-100.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-100italic - 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: 'Roboto';
  font-style: italic;
  font-weight: 100;
  src: url('../../files/fonts/roboto-v30-latin-100italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-300 - 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: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: url('../../files/fonts/roboto-v30-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-300italic - 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: 'Roboto';
  font-style: italic;
  font-weight: 300;
  src: url('../../files/fonts/roboto-v30-latin-300italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-regular - 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: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: url('../../files/fonts/roboto-v30-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-italic - 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: 'Roboto';
  font-style: italic;
  font-weight: 400;
  src: url('../../files/fonts/roboto-v30-latin-italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-500 - 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: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: url('../../files/fonts/roboto-v30-latin-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-500italic - 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: 'Roboto';
  font-style: italic;
  font-weight: 500;
  src: url('../../files/fonts/roboto-v30-latin-500italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-700 - 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: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: url('../../files/fonts/roboto-v30-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-700italic - 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: 'Roboto';
  font-style: italic;
  font-weight: 700;
  src: url('../../files/fonts/roboto-v30-latin-700italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-900 - 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: 'Roboto';
  font-style: normal;
  font-weight: 900;
  src: url('../../files/fonts/roboto-v30-latin-900.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* roboto-900italic - 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: 'Roboto';
  font-style: italic;
  font-weight: 900;
  src: url('../../files/fonts/roboto-v30-latin-900italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}



/* test */

/*body { background: #e8e8e8; }*/
.container { margin: 0 auto; }

/* Example wrapper */
.wrap {
	position: relative;
	margin: 3em 0;
}

/* Frame */
.frame {
	height: 250px;
	line-height: 250px;
	overflow: hidden;
}
.frame ul {
	list-style: none;
	margin: 0;
	padding: 0;
	height: 100%;
	font-size: 50px;
}
.frame ul li {
	float: left;
	width: 227px;
	height: 100%;
	margin: 0 1px 0 0;
	padding: 0;
	background: #333;
	color: #ddd;
	text-align: center;
	cursor: pointer;
}
.frame ul li.active {
	color: #fff;
	background: #bc1732;
}

/* Scrollbar */
.scrollbar {
	margin: 0 0 1em 0;
	height: 2px;
	background: #ccc;
	line-height: 0;
}
.scrollbar .handle {
	width: 100px;
	height: 100%;
	background: #292a33;
	cursor: pointer;
	position:relative;
}
.scrollbar .handle .mousearea {
	position: absolute;
	top: -9px;
	left: 0;
	width: 100%;
	height: 20px;
}

/* Pages */
.pages {
	list-style: none;
	margin: 20px 0;
	padding: 0;
	text-align: center;
}
.pages li {
	display: inline-block;
	width: 14px;
	height: 14px;
	margin: 0 4px;
	text-indent: -999px;
	border-radius: 10px;
	cursor: pointer;
	overflow: hidden;
	background: #fff;
	box-shadow: inset 0 0 0 1px rgba(0,0,0,.2);
}
.pages li:hover {
	background: #aaa;
}
.pages li.active {
	background: #666;
}

/* Controls */
.controls { margin: 25px 0; text-align: center; }

/* One Item Per Frame example*/
.oneperframe { height: 300px; line-height: 300px; }
.oneperframe ul li { width: 1140px; }
.oneperframe ul li.active { background: #333; }

/* Crazy example */
.crazy ul li:nth-child(2n) { width: 100px; margin: 0 4px 0 20px; }
.crazy ul li:nth-child(3n) { width: 300px; margin: 0 10px 0 5px; }
.crazy ul li:nth-child(4n) { width: 400px; margin: 0 30px 0 2px; }

/* sh 2023-12-09 */

.scrollbar {
	margin-top:30px;
}
.scrollbar .handle .mousearea {
	position: absolute;
	top: -15px;
	left: 50%;
	transform: translateX(-50%);
	width: 35px;
	height: 35px;
	background-image: url('/files/img/bernit_icon.png');
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center center;
	transition: all .3s ease;
	/*background-color: #e8e8e8;
	border: 10px solid #e8e8e8;*/
	box-sizing: border-box;
}

/* details slider */
.details-slider .referenzen-slider {
  width: 100%;
  float: right;
  margin: unset;
  max-width: 590px;
}
/* MENU */
.menu {
	text-align:center;
	margin-top:20px;
	margin-bottom:20px;
}
.menu li {
    display: inline-block;
}
.menu li.nonavlink,
.menu li span.nonavlink {
	cursor:pointer;
}
.menu li a, .menu li strong, .menu li::after, .menu li span.active, .menu li span.nonavlink {
    font-size: 16px;
    text-decoration: none;
    color:#000000;
    font-family:'Roboto';
    font-weight:500;
    text-transform:uppercase;
}
.menu .level_2 li a, .menu .level_2 li strong, .menu .level_2 li::after, .menu .level_2 li span.active, .menu .level_2 li span.nonavlink {
    text-transform:initial;
}
.menu li a, .menu li strong, .menu li span.active, .menu li span.nonavlink {
    padding-left:20px;
    padding-right:20px;
}

/* lines */
.menu li {
	position:relative;
	padding-bottom: 20px;
}
.lines-wrapper {
width: 11px;
height: 20px;
margin: 0;
cursor: pointer;
position: absolute;
right: 0;
z-index: 200;
top: -1px;
}
span.lines {
	    height: 1px;
	    display: block;
	    position: absolute;
	    top: 10px;
	    left: 0;
	    right: 0;
	    background-color: #000000;
	    -webkit-transition: background 0.15s linear 0.15s;
	    -o-transition: background 0.15s linear 0.15s;
	    transition: background 0.15s linear 0.15s;
	}
span.lines:before {
	    top: -4px;
	    -webkit-transition: top 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    transition: top 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    -o-transition: top 0.15s linear 0.15s, transform 0.15s linear;
	    transition: top 0.15s linear 0.15s, transform 0.15s linear;
	    transition: top 0.15s linear 0.15s, transform 0.15s linear, -webkit-transform 0.15s linear;
	}
span.lines:after {
	    bottom: -4px;
	    -webkit-transition: bottom 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    transition: bottom 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    -o-transition: bottom 0.15s linear 0.15s, transform 0.15s linear;
	    transition: bottom 0.15s linear 0.15s, transform 0.15s linear;
	    transition: bottom 0.15s linear 0.15s, transform 0.15s linear, -webkit-transform 0.15s linear;
	}
span.lines:before, span.lines:after {
	    content: "";
	    width: 100%;
	    height: 1px;
	    display: block;
	    position: absolute;
	    left: 0;
	    background-color: #000000;
	}

.level_1 li.submenu .lines-wrapper {
	display:block;
}
.level_1 .lines-wrapper,
.level_1 li.submenu .level_2 .lines-wrapper {
	display:none;
}
/* lines hover */
	/*li:hover span,*/
	li.trail span{
	    -webkit-transition: background 0.15s linear;
	    -o-transition: background 0.15s linear;
	    transition: background 0.15s linear;
	    background: none;
	    cursor:pointer;
	}
	/*li:hover span:before,*/
	li.trail span:before{
	    top: 0px;
	    -webkit-transform: rotate(45deg);
	    -ms-transform: rotate(45deg);
	    transform: rotate(45deg);
	    -webkit-transition: top 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    -o-transition: top 0.15s linear, transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, transform 0.15s linear 0.15s, -webkit-transform 0.15s linear 0.15s;
	    background-color: #000000;
	}
	/*li:hover span:after,*/
	li.trail span:after{
	    bottom: 0px;
	    -webkit-transform: rotate(-45deg);
	    -ms-transform: rotate(-45deg);
	    transform: rotate(-45deg);
	    -webkit-transition: bottom 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    -o-transition: bottom 0.15s linear, transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, transform 0.15s linear 0.15s, -webkit-transform 0.15s linear 0.15s;
	    background-color: #000000;
	}

/* submenu */
.menu nav {
	overflow:visible;
}
ul.level_2 {
position: absolute;
background-color: rgb(255, 255, 255);
padding-left: 0;
padding-right: 0;
padding-top: 20px;
padding-bottom: 20px;
z-index: 10;
display: none;
min-width: 300px;
margin-top:10px;
}
.menu li .level_2 li {
  padding: 0;
  display: block;
  clear: both;
  text-align: left;
  line-height: 30px;
}

@media only screen and (max-width: 980px) {
	/* btn */
.btn {
	width: 45px;
	height: 45px;
	margin: 0 15px 0 15px;
    cursor: pointer;
    position: absolute;
    right:0;
    z-index: 200;
    /*top: -12px;*/
    top:38px;
}
	.btn span {
	    height: 2px;
	    display: block;
	    position: absolute;
	    top: 22.5px;
	    left: 0;
	    right: 10%;
	    background-color: #000000;
	    -webkit-transition: background 0.15s linear 0.15s;
	    -o-transition: background 0.15s linear 0.15s;
	    transition: background 0.15s linear 0.15s;
	}
	.btn span::before {
	    top: -10px;
	    -webkit-transition: top 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    transition: top 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    -o-transition: top 0.15s linear 0.15s, transform 0.15s linear;
	    transition: top 0.15s linear 0.15s, transform 0.15s linear;
	    transition: top 0.15s linear 0.15s, transform 0.15s linear, -webkit-transform 0.15s linear;
	}
	.btn span::after {
	    bottom: -10px;
	    -webkit-transition: bottom 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    transition: bottom 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    -o-transition: bottom 0.15s linear 0.15s, transform 0.15s linear;
	    transition: bottom 0.15s linear 0.15s, transform 0.15s linear;
	    transition: bottom 0.15s linear 0.15s, transform 0.15s linear, -webkit-transform 0.15s linear;
	}
	.btn span::before, .btn span::after {
	    content: "";
	    width: 100%;
	    height: 2px;
	    display: block;
	    position: absolute;
	    left: 0;
	    background-color: #000000;
	}
	body.nav-open .btn span {
	    -webkit-transition: background 0.15s linear;
	    -o-transition: background 0.15s linear;
	    transition: background 0.15s linear;
	    background: none;
	}
	body.nav-open .btn span::before {
	    top: 0px;
	    -webkit-transform: rotate(45deg);
	    -ms-transform: rotate(45deg);
	    transform: rotate(45deg);
	    -webkit-transition: top 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    -o-transition: top 0.15s linear, transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, transform 0.15s linear 0.15s, -webkit-transform 0.15s linear 0.15s;
	    background-color: #000000;
	}
	body.nav-open .btn span::after {
	    bottom: 0px;
	    -webkit-transform: rotate(-45deg);
	    -ms-transform: rotate(-45deg);
	    transform: rotate(-45deg);
	    -webkit-transition: bottom 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    -o-transition: bottom 0.15s linear, transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, transform 0.15s linear 0.15s, -webkit-transform 0.15s linear 0.15s;
	    background-color: #000000;
	}
/* btn ENDE */

/* nav */
	.header nav{
		display:none;
	}
/* nav ENDE */
.show-submenu ul.level_2 {
	display: block !important;
}
/* lines */
	.show-submenu span{
	    -webkit-transition: background 0.15s linear;
	    -o-transition: background 0.15s linear;
	    transition: background 0.15s linear;
	    background: none;
	    cursor:pointer;
	}
	.show-submenu span:before{
	    top: 0px;
	    -webkit-transform: rotate(45deg);
	    -ms-transform: rotate(45deg);
	    transform: rotate(45deg);
	    -webkit-transition: top 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    -o-transition: top 0.15s linear, transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, transform 0.15s linear 0.15s, -webkit-transform 0.15s linear 0.15s;
	    background-color: #000000;
	}
	.show-submenu span:after{
	    bottom: 0px;
	    -webkit-transform: rotate(-45deg);
	    -ms-transform: rotate(-45deg);
	    transform: rotate(-45deg);
	    -webkit-transition: bottom 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    -o-transition: bottom 0.15s linear, transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, transform 0.15s linear 0.15s, -webkit-transform 0.15s linear 0.15s;
	    background-color: #000000;
	}
}
@media only screen and (min-width: 980px) {
.menu li:hover > ul.level_2,
.menu ul.level_2:hover {
	display: block !important;
}
/* lines */
	.menu li:hover span,
	.menu li.trail span{
	    -webkit-transition: background 0.15s linear;
	    -o-transition: background 0.15s linear;
	    transition: background 0.15s linear;
	    background: none;
	    cursor:pointer;
	}
	.menu li:hover span:before,
	.menu li.trail span:before{
	    top: 0px;
	    -webkit-transform: rotate(45deg);
	    -ms-transform: rotate(45deg);
	    transform: rotate(45deg);
	    -webkit-transition: top 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    -o-transition: top 0.15s linear, transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, transform 0.15s linear 0.15s, -webkit-transform 0.15s linear 0.15s;
	    background-color: #000000;
	}
	.menu li:hover span:after,
	.menu li.trail span:after{
	    bottom: 0px;
	    -webkit-transform: rotate(-45deg);
	    -ms-transform: rotate(-45deg);
	    transform: rotate(-45deg);
	    -webkit-transition: bottom 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    -o-transition: bottom 0.15s linear, transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, transform 0.15s linear 0.15s, -webkit-transform 0.15s linear 0.15s;
	    background-color: #000000;
	}
}
.grid-3-3 .small {
	display:none;
}
/*	.text-medium table td{
  width:unset !important;
     overflow-wrap: break-word;
}*/
	.text-medium table {
   width:100% !important;
   overflow-wrap: break-word;
	}
	
@media only screen and (max-width: 1440px) {
.headline-large h1, h1.headline-large,
.headline-large h2, h2.headline-large {
	font-size:30px;
}
}
@media only screen and (max-width: 1200px) {
.col-2.details-slider {
	margin-top:0;
}
.details-slider.col-2 {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  grid-gap: 0;
}
.sale .details-slider.col-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 0;
}
.details-slider a.cta-btn {
  min-width: auto;
}
.col-2.details-slider .referenzen-slider {
  width: 100%;
  float: left;
  max-width: calc(100vw - 40px);
  margin-top: 50px;
}
.sale .headline-block.headline-margin {
    margin-bottom: 0;
}
}
@media only screen and (max-width: 1024px) {
.above-fold .col-2 {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  grid-gap: 0;
}
.above-fold .text-medium.relative {
  margin-top: 30px;
}
.above-fold.bg-grau .ce_text {
  padding-left: 0;
}
.footer {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 10px;
  row-gap:20px;
}
a.mobile {
	display:block;
}
a.desktop {
	display:none;
}
header {
	padding-bottom:20px;
}
.cta, .referenzen, .slider-element {
  padding-top: 75px;
  padding-bottom: 75px;
}
.bg-grau.above-fold {
  margin-bottom: 25px;
}
/*.content-text {
	margin-top:0;
}*/
.content {
  margin-top: 50px;
}
.content-text,
.content.standorte:last-of-type {
  margin-bottom: 50px;
}
.sale .text-medium,
.mod_article.content:nth-child(2n+1) .text-medium,
.content.left-right .ce_text{
	padding-left:50px;
	padding-right:50px;
	box-sizing:border-box;
}
.sale figure {
  padding-left: 50px;
  padding-right: 50px;
  float: left;
  width: 100%;
  box-sizing: border-box;
  position:relative;
}
.content-bg .ce_image img {
  max-width: 100%;
  float: left;
  box-sizing:border-box;
}
.sale figcaption {
  right: 20px;
}
.content-bg:nth-child(2n) {
	margin-top:0;
}
.content .text-medium {
	padding-top:50px;
}
.sale .ce_text a.cta-btn {
	margin-bottom:0;
}
.padding-standard {
  padding-top: 0;
  padding-bottom: 50px;
}
.grid-3-3 .ce_image figcaption {
  display: block;
}
.sale .details-slider.col-2 {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  grid-gap: 0;
}
}
@media only screen and (max-width: 900px) {
	.headline-large h1, h1.headline-large,
	.headline-large h2, h2.headline-large,
	.image-overlay,
	.cta .text-large,
	.bereiche h2,
	figcaption{
	  font-size: 25px;
/*	  line-height: 1.25em;*/
	}
	.bereiche .ce_text {
	  padding: 0 30px 30px 30px;
	}	
	.image-overlay {
  top: 25px;
  max-width: 300px;
  width: 100%;
	}
		.ce_text.fliesstext {
  column-count: 2;
	}
.referenzen-text {
width: 100%;
float: left;
position: relative;
top: 0;
transform: none;
left: 0;
padding-right: 0;
}
.elemente-slider, .referenzen-slider {
  width: 100%;
}
.service .col-3 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr;
  grid-gap: 20px;
}
.service .col-3 div:nth-child(3) {
  grid-column-start: 1;
  grid-column-end: 3;
  grid-row-start: 2;
  grid-row-end: 2;
}
.bg-grau .col-3 .ce_text.text-medium {
	position:relative;
}
.bg-grau .col-3 .ce_text.text-medium p {
  position: relative;
  padding-left: 0;
}
.bg-grau .col-3 .ce_text:nth-child(3).langer-text p {
	padding-left:0;
}
.langer-text ul {
  margin-left: 0;
}
.service.bg-grau .ce_text {
	padding-left:0;
	padding-top:20px;
}
.bg-grau.service {
  padding-top: 50px;
  padding-bottom: 50px;
}
.content.col-2 {
	display: grid;
grid-template-columns: repeat(1, 1fr);
grid-gap: 0;
}
.standorte.content.col-2:nth-child(even) .ce_text { 
	order: 2;
}
.standorte.content.col-2:nth-child(even) .ce_image { 
	order: 1;
}
.content .ce_image img{
	width:100%;
}
.content .text-medium {
	padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
  padding-top: 50px;
}
/*.mod_article.content:nth-child(2n+1) .text-medium {
	padding-left:0;
}*/
.cta, .referenzen, .slider-element {
  padding-top: 50px;
  padding-bottom: 50px;
}
.tel-anzeige,
div.icons a.tel-icon {
	display:none;
}
div.icons a.tel-icon.mobile {
	display:block;
}
.basic-headline.headline-block.headline-margin {
    margin-bottom: 0;
    float: left;
    width: 100%;
}
}
@media only screen and (max-width: 850px) {
.footer {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 10px;
  row-gap:20px;
}
.slider-control {
  height: 45px;
}
.sale .text-medium,
.mod_article.content:nth-child(2n+1) .text-medium,
.content.left-right .ce_text{
	padding-left:20px;
	padding-right:20px;
	box-sizing:border-box;
}
.sale figure {
  padding-left: 20px;
  padding-right: 20px;
  float: left;
  width: 100%;
  box-sizing: border-box;
  position:relative;
}
.content-bg .ce_image img {
  max-width: 100%;
  float: left;
  box-sizing:border-box;
}
.sale figcaption {
  right: 0;
}
.grid-3-3 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 5fr;
  grid-gap: 20px;
}
.grid-3-3 div:nth-child(1) {
  grid-column-start: 1;
  grid-column-end: 1;
  grid-row-start: 1;
  grid-row-end: 3;
}
.grid-3-3 div:nth-child(2) {
  grid-column-start: 1;
  grid-column-end: 1;
  grid-row-start: 3;
  grid-row-end: 4;
}
.grid-3-3 div:nth-child(3) {
  grid-column-start: 2;
  grid-column-end: 2;
  grid-row-start: 2;
  grid-row-end: 3;
}
.grid-3-3 div:nth-child(4) {
  grid-column-start: 2;
  grid-column-end: 2;
  grid-row-start: 3;
  grid-row-end: 5;
}
.grid-3-3 div:nth-child(5) {
  grid-column-start: 2;
  grid-column-end: 2;
  grid-row-start: 1;
  grid-row-end: 2;
}
.grid-3-3 div:nth-child(6) {
  grid-column-start: 1;
  grid-column-end: 1;
  grid-row-start: 4;
  grid-row-end: 5;
}
.grid-3-3 .small {
	display:block;
}
.grid-3-3 .large {
	display:none;
}
.bg-grau .grid-3-3 .ce_text,
.grid-3-3 .inside-wrapper{
	padding-left:0;
}
.grid-3-3 figcaption {
	padding-left:5px;
	padding-right:5px;
	hyphens:auto;
}
#popup .inside {
  padding-left: 10px;
  padding-right: 10px;
  width: calc(100% - 60px);
}
}
@media only screen and (min-height: 800px) and (min-width: 1500px) {
  .danke-seite #footer {
    position: fixed;
    width:100%;
    bottom:0;
  }
}
@media only screen and (max-width: 700px) {
.image-overlay {
  max-width: calc(100% - 20px);
}
.image-overlay br {
	display:none;
}
		.ce_text.fliesstext {
  column-count: 1;
	}
		.text-medium table td:nth-child(2) {
  width:calc(100% - 105px)!important;
    word-break: break-all;
}
	.text-medium table td:first-of-type {
	width:105px !important;
}
#popup .ce_text figure {
	display:none;
}
}
@media only screen and (max-width: 600px) {
.bereiche.col-3 {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  grid-gap: 0;
  max-width:350px;
  margin-left:auto;
  margin-right:auto;
}
	.bereiche .ce_text {
	  padding: 0 40px 40px 40px;
	}
	.footer {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 10px;
  row-gap:20px;
}
.slider-control .slider-menu {
	width:50%;
}
.slider-menu b {
  width: 30px;
  height: 4px;
  margin-left: 4px;
  margin-right: 4px;
}
.image-overlay, .cta .text-large, figcaption {
	font-size:20px;
}
.image-overlay {
	font-size:18px;
}
.absolute-center .inside-wrapper {
	position:relative;
	padding-bottom:15px;
}
.grid-3-3 img {
  object-fit: cover;
  height: auto;
  width: 100%;
}
.grid-3-3 .text-medium p{
	font-size:16px;
}
.grid-3-3 .small {
	display:none;
}
.grid-3-3 .large {
	display:block;
}
.grid-3-3 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 6fr;
  grid-gap: 20px;
}
.grid-3-3 div:nth-child(1) {
  grid-column-start: 1;
  grid-column-end: 1;
  grid-row-start: 1;
  grid-row-end: 3;
}
.grid-3-3 div:nth-child(2) {
  grid-column-start: 2;
  grid-column-end: 2;
  grid-row-start: 5;
  grid-row-end: 6;
}
.grid-3-3 div:nth-child(3) {
  grid-column-start: 1;
  grid-column-end: 1;
  grid-row-start: 3;
  grid-row-end: 4;
}
.grid-3-3 div:nth-child(4) {
  grid-column-start: 2;
  grid-column-end: 2;
  grid-row-start: 3;
  grid-row-end: 5;
}
.grid-3-3 div:nth-child(5) {
  grid-column-start: 2;
  grid-column-end: 2;
  grid-row-start: 1;
  grid-row-end: 3;
}
.grid-3-3 div:nth-child(6) {
  grid-column-start: 1;
  grid-column-end: 1;
  grid-row-start: 4;
  grid-row-end: 6;
}
}
@media only screen and (max-width: 480px) {
	.footer {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  grid-gap: 10px;
  row-gap:20px;
}
.slider-control .slider-menu {
  width: 100%;
  left: 25%;
}
}

@media only screen and (max-width: 980px) {
header .icons, .cta icons {
  padding-top: 0;
}
	.header nav ul.level_2 {
	  position: relative;
	  float: right;
	  clear: both;
	}
	.header nav ul li a,
	.header nav ul li strong{
		float:right;
	}
	.header nav li {
	    display: block;
	    padding-bottom: 40px;
	    float:left;
	    clear:both;
	}
	.header nav li.show-submenu {
		float:left;
	}
	.header nav{
		/*border-left:3px solid #009fe3;*/
		position: absolute;
		background-color: #c4c5c5;
		top: 0;
		right: 0;
		/*left:0;*/
		margin-top: 90px;
		padding: 20px;
		/*height: 100vh;*/
		width: auto;
		overflow-y: auto;
		z-index: 20;
		z-index: 100;
		/*border-left: 1px solid rgba(0,0,0,0.5);*/
		/*min-width: 98px;*/
		min-width:320px;
		box-sizing:border-box;
	}
	.header nav li:not(:last-child)::after {
	  content: '';
	  padding-left: 0;
	}
	.header nav ul{
		padding-top: 0;
	}
	.header nav ul.level_2 {
		padding-top: 0;
	}
	header nav a, header nav strong, header nav a.trail {
		margin-left:0;
	}
	header ul.level_2 {
	min-width: 100px;
	}
	header nav ul,
	header nav ul li,
	header nav ul li span,
	.header nav ul.level_2{
		float:left;
	}
	.header nav ul.level_2 {
	  min-width: 280px;
	  padding-bottom: 5px;
	  padding-top: 5px;
	  /*width: calc(100vw - 40px);*/
	}
	.header nav li {
		padding-bottom:20px;
	}
}
	/* btn */
.popup-btn {
	width: 46px;
	height: 46px;
	margin: 0 15px 0 15px;
    cursor: pointer;
    position: absolute;
    right:0;
    z-index: 200;
    /*top: -12px;*/
	top: -21px;
	border-radius: 100%;
	background-color: #bc1732;
	right: -36px;
}
	.popup-btn span {
	    height: 2px;
	    display: block;
	    position: absolute;
	    top: 22.5px;
	    left: 0;
	    right: 10%;
	    background-color: #ffffff;
	    -webkit-transition: background 0.15s linear 0.15s;
	    -o-transition: background 0.15s linear 0.15s;
	    transition: background 0.15s linear 0.15s;
	}
	.popup-btn span::before {
	    top: -10px;
	    -webkit-transition: top 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    transition: top 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    -o-transition: top 0.15s linear 0.15s, transform 0.15s linear;
	    transition: top 0.15s linear 0.15s, transform 0.15s linear;
	    transition: top 0.15s linear 0.15s, transform 0.15s linear, -webkit-transform 0.15s linear;
	}
	.popup-btn span::after {
	    bottom: -10px;
	    -webkit-transition: bottom 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    transition: bottom 0.15s linear 0.15s, -webkit-transform 0.15s linear;
	    -o-transition: bottom 0.15s linear 0.15s, transform 0.15s linear;
	    transition: bottom 0.15s linear 0.15s, transform 0.15s linear;
	    transition: bottom 0.15s linear 0.15s, transform 0.15s linear, -webkit-transform 0.15s linear;
	}
	.popup-btn span::before, .popup-btn  span::after {
		content: "";
		width: 30px;
		height: 2px;
		display: block;
		position: absolute;
		left: 8px;
	    background-color: #ffffff;
	}
.popup-btn span {
	    -webkit-transition: background 0.15s linear;
	    -o-transition: background 0.15s linear;
	    transition: background 0.15s linear;
	    background: none;
	}
.popup-btn span::before {
	    top: 0px;
	    -webkit-transform: rotate(45deg);
	    -ms-transform: rotate(45deg);
	    transform: rotate(45deg);
	    -webkit-transition: top 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    -o-transition: top 0.15s linear, transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, transform 0.15s linear 0.15s;
	    transition: top 0.15s linear, transform 0.15s linear 0.15s, -webkit-transform 0.15s linear 0.15s;
	    background-color: #ffffff;
	}
.popup-btn span::after {
	    bottom: 0px;
	    -webkit-transform: rotate(-45deg);
	    -ms-transform: rotate(-45deg);
	    transform: rotate(-45deg);
	    -webkit-transition: bottom 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, -webkit-transform 0.15s linear 0.15s;
	    -o-transition: bottom 0.15s linear, transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, transform 0.15s linear 0.15s;
	    transition: bottom 0.15s linear, transform 0.15s linear 0.15s, -webkit-transform 0.15s linear 0.15s;
	    background-color: #ffffff;
	}
/* btn ENDE */
@media (prefers-color-scheme: light) {
	.logo img {
		display:block;
	}
	.logo img.dark {
		display:none;
	}
}
@media (prefers-color-scheme: dark) {
	.logo img {
		display:none;
	}
	.logo img.dark {
		display:block;
	}
}

/* formular */
.kontaktformular input,
.kontaktformular select,
.kontaktformular textarea{
	width:100%;
/*	background-color:#ffffff;*/
	background-color:transparent;
	border:1px solid #000000;
	line-height:50px;
	box-sizing:border-box;
	color:#000000;
	padding-left:20px;
	padding-right:20px;
	margin-bottom:10px;
	font-size:16px;
	font-family: 'Lato';
	  webkit-border-radius: 0;
	border-radius: 0;
	height:50px;
}
.kontaktformular input:focus,
.kontaktformular select:focus,
.kontaktformular textarea:focus {
	border:1px solid #bc1732;
}
.kontaktformular textarea{
	min-width:100%;
	height: 115px;
}
.kontaktformular button.submit {
border: 3px solid #000000;
  color: #ffffff;
  background-color: #000000;
  text-decoration: none;
  width: auto;
  display: inline-block;
  line-height: 55px;
  font-weight: bold;
  max-width: 500px;
  border-radius: 0;
  float: none;
  margin-left: auto;
  margin-right: auto;
  padding-left: 50px;
  padding-right: 50px;
  cursor: pointer;
  font-size: 16px;
  margin-top:10px;
  line-height:50px;
}
.kontaktformular button.submit:hover {
	color:#ffffff;
	background-color:#bc1732;
border: 3px solid #bc1732;
}
.kontaktformular .form-wrapper {
  display: grid;
  overflow: hidden;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 0 20px;
}
.widget-checkbox {
	margin-top:15px;
	margin-bottom:30px;
}
.checkbox_container {
	border:0;
}
.widget-checkbox input {
	float: left;
  width: auto;
  height: auto;
  margin-right: 15px;
  margin-top: 4px;
}
.widget-checkbox a {
	color:#000000;
}

/* kontaktformular ende */

@media only screen and (max-width: 680px) {
	.kontaktformular .form-wrapper {
		column-count: 1;
	}
	.kontaktformular .widget-explanation {
		width: 100%;
		padding-right: 0;
		font-size:15px;
	}
}
@media only screen and (max-width: 520px) {
	
.kontaktformular .form-wrapper {
  display: grid;
  overflow: hidden;
  grid-template-columns: repeat(1, 1fr);
  grid-gap: 15px;
  margin-bottom: 15px;
}
}
.kontaktformular {
	margin-top:50px;
	/*margin-bottom:100px;*/
}

/* erweiterung mit bild */
/*.ce_form {*/
  /*width: calc(100% - 400px);*/
/*}*/
.ce_text.kontaktdaten {
  max-width: 50%;
  float: right;
  width: 330px;
  margin-top: 68px;
}
.ce_text.kontaktdaten p,
.ce_text.kontaktdaten a {
	font-size: 20px;
  line-height: 32px;
  font-weight: 400;
  text-decoration:none;
}
.ce_text.kontaktdaten figure {
	margin-bottom:20px;
}
.kontaktformular textarea{
	height: 170px;
}
@media screen and (max-width: 680px) {
	#kontakt {
		display:grid;
	}
  .ce_form {
    width: 100%;
  }
  .ce_text.kontaktdaten {
   	order:2;
  	margin-top:0;
  }
  .kontaktformular {
  	margin-bottom:75px;
  }
}
