* {
	position: relative;
	-moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #4f4f4f;
  border: 0;
}
html { height: 100%; }
body { min-height: 101%; margin: 0; padding: 0; }
#container { overflow-x: hidden; }
.valign { 
	top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%); 
}
ul.nostyle { margin: 0; padding: 0; list-style: none; }
img.fit { width: 100%; height: auto; }
img.fit.max { width: auto; max-width: 100%; height: auto; }
a.button { display: inline-block; }
#header a, #footer a, .flex>*, .icon.button { display: block; }
textarea, input:not(.check), button { outline: none; border-radius: 0; -webkit-appearance: none;  }
.button, button, .range.ui-slider * { cursor: pointer !important; }
.whitebg { z-index: 4; }

ul.flex, ul.menu, ul.submenu, .nolist {	
	margin: 0;
	list-style-type: none; 
	-webkit-padding-start: 0; 
}
.flex {
	display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-orient: horizontal;
  -moz-box-orient: horizontal;
  -webkit-box-direction: normal;
  -moz-box-direction: normal;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
	flex-direction: row; 
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap; 
}
.flex.center, .flex.row {
	-webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
	-webkit-justify-content: center; 
	justify-content: center; 
	
}
.flex.right {
	-webkit-box-pack: end;
  -moz-box-pack: end;
  -ms-flex-pack: end;
	-webkit-justify-content: flex-end;
	justify-content: flex-end; 
}
.flex>.stretch { 
	-webkit-box: auto;
  -moz-box: auto;
  -webkit-flex: 1 auto;
  -ms-flexbox: 1 auto;
	flex: 1 auto;	
}
.flex.row, .flex.row.side>*,
.flex.col1>*, .col1:not(.flex),
.flex.col2>*, .col2:not(.flex),
.flex.col3>*, .col3:not(.flex),
.flex.col4>*, .col4:not(.flex) { width: 100%; }

.table, .table>*:not(input):not(label), .table>*>*, .tablecell { display: block; }


#content .flex:not(.row) { margin: 0 -10px 0 -10px; }
.accordion { margin: 0 -10px 0 -10px !important; }
#content .flex:not(.row)>*,
trigger, .toggle, input, textarea, label.radiocheck { padding: 0 10px; }
#content .wrap, hr { margin-top: 0em; margin-bottom: 0em; }
#content { padding-bottom: 2em !important; }
#content .panorama .wrap { margin-top: 0; }
.box, .menu a, #content .panorama.header .box, textarea { padding: 10px; }
.greybox { padding: 20px 30px; }
.space { padding: 10px 0; }
.button, button { padding: 10px 15px 9px 15px; }
.bullet span.button { display: inline-block; padding: 10px 5px; }
.icon.button { padding: 15px; }
input, #breadcrumb .box, .table>*>*, ul.submenu a, .accordion .item { padding: 5px 10px; }
ul.flex, #breadcrumb .flex>* { padding: 0; }
#verkaufsprozess .toggle { margin-top: -15px; padding: 1px 10px 0 16px; }
.wrap, .tight, .panorama, .bgfixed, .robotnic.slider~.control { margin-right: auto; margin-left:auto; }
input { line-height: 1.75em; }

.wrap, .robotnic.slider~.control { width: 100%; max-width: 1160px; }
.tight { max-width: 860px; }
.wide { max-width: 1360px; }
.panorama, .bgfixed { max-width: 1920px; }
.panorama { height: 42vw; min-height: 440px; max-height: 680px; }

#logo { width: 75vw; height: auto; max-width: 320px; margin: 0 0 10px 0; }
.tabbox~.control>.bullet { margin: 0 2px 2px 0; }
.hasSub:after { padding-left: 2px; }

.icon.blue { padding: 5px 8px; border-radius: 4px; }


#header *, #footer * { color: #727271; }
ul.menu li:hover>a, ul.menu li:hover>a>i:before { color: #0e66b3 !important; }
h1, h2, h3, h4, .h2, .h2>*:before, #content a:not(.nolink), a.nolink:hover, .big { color: #0e66b3; }
#breadcrumb *, .button, button, .button:before, #content a.button, .wrap.cta .box *, .button .icon, .icon.blue { color: #fff; }
hr { border: 0; border-bottom: 2px solid #0e66b3; }
input:not(.button), textarea, label.radiocheck { border: 1px solid #f5f5f5; }
input:not(.button):not(.readonly):focus, textarea:focus { border: 1px solid #0e66b3; }
input.readOnly { background: #f5f5f5; cursor: default; }
.greybox { border: 0px solid #0e66b3; background: #f5f5f5 !important; }
#menu, .fixHeader.fixed #header {
	border-bottom: 1px solid #ccc;
	box-shadow: 0 0 2px #ccc;
}

body, #footer, .table>*:nth-child(even) { background: #eee; }
#container, #header, #header ul.menu, .whitebg { background: #fff; }
#breadcrumb, .button, button, .icon.blue { background: #0e66b3; }
.button:hover, button:hover { }
.bullet.active .button { color: #4f4f4f; background: #f5f5f5; }

.bluebox { border: 2px solid #0e66b3; }
.header .control { margin-bottom: 1em !important; }
.header .control .bullet {
	width: 26px;
	height: 26px;
	margin-left: 5px;
	border-radius: 14px;
	border: 2px solid #0e66b3;
	background: none;	
}
.header .control .bullet.active,
.header .control .bullet:hover {
	background: #0e66b3;	
}
.arrow>.icon { text-shadow: 0 0 0 #fff; }
#gruendeSlider .arrow {}

/*
.icon.big {
	display: inline-block;
	padding: 12px 10px 8px 10px;
	line-height: 1em;
	border-radius: 6px;
	color: #0e66b3;
	border: 1px solid #0e66b3;
	background: none;
}
.wrap.cta .icon.big {
	color: #fff;
	border: 1px solid #fff;
	background: none;
}
*/
#menu {
	width: 100%;
	position: fixed; top: 0; right: 0;
	visibility: hidden; opacity: 0;
	z-index: 10;
	margin-top: -400px;
	-webkit-transform: translateY(0%);
  -ms-transform: translateY(0%);
  transform: translateY(0%);
}
#menu li { width: 100%; }
#menu>li>a { z-index: 11; }
#mIcon { 
	display: block;
	position: relative;
}
#mIcon:hover ~ #menu, 
#mIcon:focus ~ #menu, #menu:hover {
	margin-top: 0;
	visibility: visible; opacity: 1;	
	CSS-Eigenschaften; 
	-webkit-user-select: none; 
	-webkit-touch-callout: none;
}
#menu, #menu *, .icon {
	-webkit-transition: opacity 0.4s, visibility 0.4s, margin 0.4s ease-out;
	-ms-transition: opacity 0.4s, visibility 0.4s, margin 0.4s ease-out;
	transition: opacity 0.4s, visibility 0.4s, margin 0.4s ease-out;
}
.control .button,
.control .bullet {
	-webkit-transition: all 0.6s;
	-ms-transition: all 0.6s;
	transition: all 0.6s;
}

.fixHeader.fixed #header { position: fixed; right: 0; left: 0; }
#breadcrumb { z-index: 1; }
.panorama .image { position: absolute; top: 0; right: 0; bottom: 0; left: 0; }
.panorama .image img { display: block; width: auto; height: 100%; margin-right: auto; margin-left:auto; }

.bgfixed {
	padding: 2em 0;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	background-attachment: fixed;
}
.kontakt-url {
	z-index:999;
  position:absolute;
  height:0;
  width:0;
  border:none !important;
  background:none;
  margin:0;
  top:0;
  left:0;
  clear:both;
  font-size:0px;
  line-height:0px;	
}

@media screen and (-webkit-min-device-pixel-ratio:0){
	.bgfixed { background-attachment: scroll; }
} /* Chrome fixed-bug! */

.nostyle.tabbox { padding-top: 2em; }
.tabbox~.control { padding-top: 1em; }

.alignright { float: right; }

#scrollBack.pos {
	opacity: 0.5;
	position: fixed; right: 0; bottom: 0;
	-webkit-transition: opacity 0.8s, visibility 0.8s;
	-ms-transition: opacity 0.8s, visibility 0.8s;
	transition: opacity 0.8s, visibility 0.8s;
}
#scrollBack.pos.hide {
	opacity: 0; visibility: hidden;	
}
#scrollBack.pos:hover { opacity: 1; }

.button.trigger { margin: 0; text-align: center; transition: all 0.6s; }
/* .item:not(.active)>.itemWrap>.trigger { color: #4f4f4f; background: none; } */
.arrow .icon { display: block; opacity: 0.3; }
.button.trigger .icon, .arrow:hover .icon { opacity: 1; }
.item.active .button.trigger .icon { opacity: 0; }

form .text { display: block; width: 100%; }
iframe {
	box-sizing: border-box; 
	-moz-box-sizing: border-box; 
	-webkit-box-sizing: border-box;
}
.panorama.map { height: 100%; }

#box {
	position: fixed; top: 0; right: 0; bottom: 0;	left: 0;
	z-index: 10;
	display: none;
	overflow: auto;
	background: white;
}
a.closebox {
	position: absolute; top: 0; right: 0;
	border: 1px solid #000; 	
	z-index: 20;
}
img.shadow { box-shadow: 0 5px 10px  #ccc; }

.accordion > .item {
	-webkit-transition: background-color 0.4s, visibility 0.4s, margin 0.4s ease-out;
	-ms-transition: background-color 0.4s, visibility 0.4s, margin 0.4s ease-out;
	transition: background-color 0.4s, visibility 0.4s, margin 0.4s ease-out;
	border-bottom: 2px solid #fff;
}
.accordion > .item.active, .accordion > .item:hover { background: #f5f5f5; }

.icon.rating:before { 
	color: #ffcc00;	
}

@media screen and (min-width: 398px){
	.flex.col2>*, .col2:not(.flex),
	.flex.col3>*, .col3:not(.flex),
	.flex.col4>*, .col4:not(.flex) { width: 50%; }
}
@media screen and (min-width: 663px){
	.table { display: table; width: 100%; }
	.table>*:not(input):not(label) { display: table-row; }
	.table>*>*, .tablecell { display: table-cell; }
	.flex.col3>*, .col3:not(.flex),
	.flex.col4>*, .col4:not(.flex) { width: 33.33%; }
	.fixHeader #header { z-index: 5; }
	.bgParallax { top: -43px; margin-bottom: -43px; }
	.panorama.map { height: 61.8vw; }
	.bullet span.button { padding: 10px 15px; }
}	
@media screen and (min-width: 928px){
	#content .wrap, hr { margin-top: 2em; margin-bottom: 2em; }
	.flex.row { 
		display: table; 
		border-collapse: collapse;
		margin: 0 !important;
	}
	.flex.row>* { display: table-cell; vertical-align: top; }
	.flex.row.side>* { width: 66.66%; }
	.flex.row.side>.aside { width: 33.33%; }
	.flex.row>*:first-child { 
		padding-right: 20px !important;
		padding-left: 0 !important;
	}
	.flex.row>* + * { 
		padding-right: 0 !important;
		padding-left: 20px !important; 
	}
	.flex.col4>*, .col4:not(.flex) { width: 25%; }
	#logo { margin-top: 0; }
	#mIcon, #menu .mobile { display: none; }
	#menu {
		width: auto;
		margin-top: auto;
		position: relative !important; right: 0;
		visibility: visible; opacity: 1;
		-webkit-transform: translateY(-50%);
		-ms-transform: translateY(-50%);
		transform: translateY(-50%);
		border-bottom: none;
		box-shadow: none;
	}
	#menu, #menu:hover { top: 50%; }
	#menu li { width: auto; }
	ul.submenu { 
		position: absolute;
		margin-top: -42px;
		min-width: 200px;
		visibility: hidden; opacity: 0;
		box-shadow: 0 0 1px #ccc;
	}
	ul.submenu>li { background: url('dot-w80.png'); }
	ul.submenu>li:not(:last-child) { border-bottom: 1px solid #ccc; }
	ul.menu>li:hover ul.submenu {
		margin-top: 0;
		visibility: visible; opacity: 1; 
	}
	.panorama .image img { width: 100%; height: auto; }
}
@media screen and (max-width: 927px){
	.desktop { display: none; }	
}
html .impressum #content .wrap,
html .widerrufsbelehrung #content .wrap {
padding: 10px;
}

/* no listelement on privacy */

html ul.no_listelement li {
    list-style-type: none
}

html .stand {
    font-size: 0.8em;
}

/* contradiction background on privacy */

html .rechtaufwiderspruch {
    background: #efefef;
    border: 1px solid #181818;
    padding: 0 15px;
}