
html
	{

	margin:0;
	padding:0;
	
	}
	
body
	{
	
	margin:0;
	padding:0;	
	
	font-family: 'Open Sans', sans-serif;
	font-weight: normal;	
	
	}



/* ####################################################################################################################
   SPLASH
   #################################################################################################################### */
	

#splash_w, #splash_g
	{
	width:50%;
	height:100%;
	overflow:hidden;
	box-sizing: border-box;
	position:relative;
	}
	
#splash_w
	{
	float:left;
	border-right:4px solid #000;
	}

#splash_g
	{
	float:right;
	border-left:4px solid #000;
	}

#splash_w .child, #splash_g .child
	{
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	background-position: center;
	transition: all .5s;	
	}

#splash_w .child
	{
	background-image:url(/images/splash_w.jpg);
	background-size: cover;
	}

#splash_g .child
	{
	background-image:url(/images/splash_g.jpg);
	background-size: cover;
	}
	
#splash_w:hover .child, #splash_w:focus .child, #splash_g:hover .child, #splash_g:focus .child
	{
	transform: scale(1.2);
	transition: all .5s;
	}
	
.splashbox
	{
	
	box-sizing: border-box;
	
	position:absolute;
	top:50%;
	left:50%;
	padding:20px;
	background-color:#fff;
	background-color:rgba(255, 255, 255, 0.9);
	width:340px;
	height:260px;
	margin-top:-130px;
	margin-left:-170px;
	
	-webkit-box-shadow: 1px 1px 10px 0px rgba(0,0,0,0.75);
	-moz-box-shadow: 1px 1px 10px 0px rgba(0,0,0,0.75);
	box-shadow: 1px 1px 10px 0px rgba(0,0,0,0.75);	
	
	-webkit-border-radius: 8px;
	-moz-border-radius: 8px;
	border-radius: 8px;	
	
	transition: all .5s;
	
	text-align:center;
	
	}
	
	
.splashbox:hover
	{
	background-color:rgba(255, 255, 255, 1);
	
	}
	
	
.splashbox img
	{
	width:100%;
	margin: 0 0 40px 0;
	}
	
.splashbox span
	{
	padding:5px 25px;
	background: #eee;
	color:#eee;
	font-weight:normal;
	font-size:26px;
	
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	border-radius: 4px;	
	
	display:inline-block;
	margin-bottom:10px;
	transition: all .5s;
	
	}
	
#splash_w .splashbox span
	{
	background:#f47321;
	}

#splash_g .splashbox span
	{
	background:#90a5bf;
	}


.splashbox span:hover
	{
	color:#333;
	}

	
.splashbox span:after{ 
   content: '\f0da';
   font-family: FontAwesome;
   font-weight: normal;
   font-style: normal;
   margin:0px 0px 0px 10px;
   text-decoration:none;

} 	



/* ####################################################################################################################
   BEREICHE
   #################################################################################################################### */

.contentwidth
	{
	width:1000px;
	margin: 0 auto;
	}
	

#header	
	{
	padding:0;
	xborder-bottom:1px solid #000;
	background:#fff;
	position:fixed;
	left:0;
	top:0;
	width:100%;
	z-index:99;
	
	-webkit-box-shadow: 0px 1px 10px 0px rgba(0,0,0,0.75);
	-moz-box-shadow: 0px 1px 10px 0px rgba(0,0,0,0.75);
	box-shadow: 0px 1px 10px 0px rgba(0,0,0,0.75);	
	
    	-webkit-transition: all 0.3s;
    	-moz-transition: all 0.3s;
    	-ms-transition: all 0.3s;
    	-o-transition: all 0.3s;
    	transition: all 0.3s;	
	
	}

#header-wrap
	{
	position:relative;
	}

#logo
	{
	padding:15px 0 15px 0;
	display:inline-block;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	-ms-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;	
	}
	
#logo img
	{
	max-width:350px;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	-ms-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;		
	}



#header.smaller #logo img
	{
	max-width:250px;
	}

.rightcol
	{
	float:right;
	margin-left:40px;
	}


.leftcol
	{
	float:left;
	max-width:500px;
	}

.mapcontainer
	{
	width:50%;
	}


.mapcontainer iframe
	{
	pointer-events: none;
	}

#sitetabs
	{
	position:absolute;
	top:0;
	right:0;
	margin:0;
	padding:0;
	background-repeat:no-repeat;
	background-position:left bottom;
	}

#sitetabs li {
    list-style:none;
    float:left;
    
  }
  
  
#sitetabs a {
    display:block;
    text-align:center;
    text-decoration:none;
    position:relative;
    text-transform:uppercase;
    color:#fff;
    line-height:20px;
    width:122px;
    font-size:14px;
    padding-bottom:3px;
    }


#sitetabs li.active a
	{
	width:127px;
	}

#sitetabs li.notactive a
	{
	width:117px;
	}

#sitetabs li.notactive a:hover
	{
	color:#000;
	}



	
/* ####################################################################################################################
   SECTIONS
   #################################################################################################################### */

section
	{
	padding:40px 0;
	margin:0;
	}




#sec_intro
	{
	height:450px;
	padding:0;
	}

#sec_area
	{
	padding:10px 0;
	margin:0;
	
	}

#page_wrap.w #sec_area
	{
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#f47321+0,f47321+50,ffffff+100 */
	background: #f47321; /* Old browsers */
	background: -moz-linear-gradient(left, #f47321 0%, #f47321 50%, #ffffff 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(left, #f47321 0%,#f47321 50%,#ffffff 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(to right, #f47321 0%,#f47321 50%,#ffffff 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f47321', endColorstr='#ffffff',GradientType=1 ); /* IE6-9 */	
	}



#page_wrap.g #sec_area
	{
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#90a5bf+0,90a5bf+50,ffffff+100 */
	background: #90a5bf; /* Old browsers */
	background: -moz-linear-gradient(left, #90a5bf 0%, #90a5bf 50%, #ffffff 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(left, #90a5bf 0%,#90a5bf 50%,#ffffff 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(to right, #90a5bf 0%,#90a5bf 50%,#ffffff 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#90a5bf', endColorstr='#ffffff',GradientType=1 ); /* IE6-9 */
	}

#sec_philosophie
	{
	-webkit-box-shadow: 0px 10px 10px -10px rgba(0,0,0,0.75);
	-moz-box-shadow: 0px 10px 10px -10px rgba(0,0,0,0.75);
	box-shadow: 0px 10px 10px -10px rgba(0,0,0,0.75);
	}


#sec_geschaeftsfeld
	{
	color:#eee;
	
	
	}

#page_wrap.w #sec_geschaeftsfeld h2
	{
	color:#eee;
	}

#page_wrap.g #sec_geschaeftsfeld h2
	{
	color:#eee;
	}

#sec_referenzen
	{
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#eeeeee+0,eeeeee+75,dddddd+100 */
	background: #eeeeee; /* Old browsers */
	background: -moz-linear-gradient(top, #eeeeee 0%, #eeeeee 75%, #dddddd 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(top, #eeeeee 0%,#eeeeee 75%,#dddddd 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(to bottom, #eeeeee 0%,#eeeeee 75%,#dddddd 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#eeeeee', endColorstr='#dddddd',GradientType=0 ); /* IE6-9 */
	}

#sec_kontakt
	{
	background:#333;
	padding-bottom:300px;
	color:#ccc;
	}

#sec_kontakt a, #sec_impressum a
	{
	color:#ccc;
	}
	
#sec_impressum
	{
	background:#292929;
	color:#ccc;
	}	
	
/* ####################################################################################################################
   MAINMENU
   #################################################################################################################### */	

#nav_main_wrap
	{
	display: inline-block;
	position:absolute;
	right:0;
	bottom:15px;
	}

#nav-main
	{
	display: table;
	width: 100%;
	/*table-layout: fixed;*/	
	list-style: none;
	margin:0;
	padding:0;
	
	}

#nav-main li
	{
	margin:20px 0 20px 0;
	padding:0 0 0 20px;
	display: table-cell;	
	}

#nav-main li a, #nav-main li a:visited
	{
	text-decoration:none;
	color: #333;
	font-size:18px;
	}


/* Effect 4: bottom border enlarge */

#nav-main li a span
	{
	position:relative;
	display:inline-block;
	margin-top:0px;
	max-width:280px;
	}

#nav-main li a span::after {
	position: absolute;
	top: 100%;
	left: 0;
	width: 100%;
	height: 1px;
	background: #000;
	content: '';
	opacity: 0;
	-webkit-transition: height 0.3s, opacity 0.3s, -webkit-transform 0.3s;
	-moz-transition: height 0.3s, opacity 0.3s, -moz-transform 0.3s;
	transition: height 0.3s, opacity 0.3s, transform 0.3s;
	-webkit-transform: translateY(-10px);
	-moz-transform: translateY(-10px);
	transform: translateY(-10px);
}

#nav-main li.active a span::after,
#nav-main li a:hover span::after {
	height: 1px;
	opacity: 1;
	-webkit-transform: translateY(0px);
	-moz-transform: translateY(0px);
	transform: translateY(0px);
}

	
/* ####################################################################################################################
   HEADLINES
   #################################################################################################################### */

h1
	{
	font-weight:normal;
	font-size:45px;
	color:rgba(255,255,255,0.8);
	margin:0;
	}

h2
	{
	font-family: 'Merriweather', serif;
	}

#page_wrap.w h2
	{
	color:#ad2e24;
	}

#page_wrap.g h2
	{
	color:#687d97;
	}



p
	{
	line-height:1.5em;
	}

	
/* ####################################################################################################################
   KACHEL
   #################################################################################################################### */

.kachel_wrap
	{
	margin:0 -24px;
	}

div.kachel
	{	
	width: 300px;
	height:300px;
	background-size: contain;
	background-repeat:no-repeat;
	background-position: center center;
	float:left;
	margin: 0 24px 48px 24px;
	-webkit-box-shadow: inset 0px 0px 0px 1px rgba(70,70,70,1);
	-moz-box-shadow: inset 0px 0px 0px 1px rgba(70,70,70,1);
	box-shadow: inset 0px 0px 0px 1px rgba(70,70,70,1);	
	position:relative;
	overflow:hidden;
	}
	
div.kachel:nth-child(113n+0)
	{
	margin-right:0;
	}
	
a.kachelcontent
	{
	display:table-cell;
	vertical-align: middle;
	width:300px;
	height:78px;
	padding-top:222px;
	text-align:center;
	color:#fff;
	
	text-transform:uppercase;
	font-size:16px;		

	background: -moz-linear-gradient(top, rgba(0,92,169,1) 0%, rgba(0,92,169,1) 100%);
	background: -webkit-linear-gradient(top, rgba(0,92,169,1) 0%,rgba(0,92,169,1) 100%);
	background: linear-gradient(to bottom, rgba(0,92,169,1) 0%,rgba(0,92,169,1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d93497c9', endColorstr='#d93497c9',GradientType=0 );
	background-position: center bottom;
	background-size:auto 75px;
	background-repeat:repeat-x;
	}

#page_wrap.w a.kachelcontent
	{
	background: -moz-linear-gradient(top, rgba(173,46,36,0.8) 0%, rgba(173,46,36,0.8) 100%);
	background: -webkit-linear-gradient(top, rgba(173,46,36,0.8) 0%,rgba(173,46,36,0.8) 100%);
	background: linear-gradient(to bottom, rgba(173,46,36,0.8) 0%,rgba(173,46,36,0.8) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ad2e24', endColorstr='#ad2e24',GradientType=0 );
	background-position: center bottom;
	background-size:auto 75px;
	background-repeat:repeat-x;	
	}
	
#page_wrap.w a.kachelcontent:hover
	{
	background: -moz-linear-gradient(top, rgba(173,46,36,1) 0%, rgba(173,46,36,1) 100%);
	background: -webkit-linear-gradient(top, rgba(173,46,36,1) 0%,rgba(173,46,36,1) 100%);
	background: linear-gradient(to bottom, rgba(173,46,36,1) 0%,rgba(173,46,36,1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ad2e24', endColorstr='#ad2e24',GradientType=0 );
	background-position: center bottom;
	background-size:auto 75px;
	background-repeat:repeat-x;	
	}	

#page_wrap.g a.kachelcontent
	{
	background: -moz-linear-gradient(top, rgba(87,83,102,0.8) 0%, rgba(87,83,102,0.8) 100%);
	background: -webkit-linear-gradient(top, rgba(87,83,102,0.8) 0%,rgba(87,83,102,0.8) 100%);
	background: linear-gradient(to bottom, rgba(87,83,102,0.8) 0%,rgba(87,83,102,0.8) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#575366', endColorstr='#575366',GradientType=0 );
	background-position: center bottom;
	background-size:auto 75px;
	background-repeat:repeat-x;	
	}
	
#page_wrap.g a.kachelcontent:hover
	{
	background: -moz-linear-gradient(top, rgba(87,83,102,1) 0%, rgba(87,83,102,1) 100%);
	background: -webkit-linear-gradient(top, rgba(87,83,102,1) 0%,rgba(87,83,102,1) 100%);
	background: linear-gradient(to bottom, rgba(87,83,102,1) 0%,rgba(87,83,102,1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#575366', endColorstr='#575366',GradientType=0 );
	background-position: center bottom;
	background-size:auto 75px;
	background-repeat:repeat-x;	
	}



div.kachel:hover
	{
	-webkit-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.35);
	-moz-box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.35);
	box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.35);
	
	}	
	
/* Effect 4: bottom border enlarge */

div.kachel span
	{
	position:relative;
	display:inline-block;
	margin-top:0px;
	max-width:280px;
	}

div.kachel span::after {
	position: absolute;
	top: 100%;
	left: 0;
	width: 100%;
	height: 1px;
	background: #fff;
	content: '';
	opacity: 0;
	-webkit-transition: height 0.3s, opacity 0.3s, -webkit-transform 0.3s;
	-moz-transition: height 0.3s, opacity 0.3s, -moz-transform 0.3s;
	transition: height 0.3s, opacity 0.3s, transform 0.3s;
	-webkit-transform: translateY(-10px);
	-moz-transform: translateY(-10px);
	transform: translateY(-10px);
}

div.kachel:hover span::after,
div.kachel:focus span::after {
	height: 1px;
	opacity: 1;
	-webkit-transform: translateY(0px);
	-moz-transform: translateY(0px);
	transform: translateY(0px);
}	


.corner-ribbon{
  width: 260px;
  background: #ed1c24;
  position: absolute;
  top: 50px;
  left: -50px;
  text-align: center;
  line-height: 35px;
  font-size:14px;
  font-weight:bold;
  color: #ffffff;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  -moz-transform:    rotate(-45deg);
  -ms-transform:     rotate(-45deg);
  -o-transform:      rotate(-45deg);  
  
 background: linear-gradient(#F70505 0%, #8F0808 100%);
  box-shadow: 0 3px 10px -5px rgba(0, 0, 0, 1);  
  text-transform:uppercase;
  
}


/* ####################################################################################################################
   REFERENZ_DETAIL
   #################################################################################################################### */
   
div.referenz_detail
	{
	display:none;
	
	padding:20px 0;
	background:#333;
	margin-bottom:20px;
	height:650px;
	color:#eee;
	}



	
div.referenz_detail h2
	{
	color:#eee!important;
	}

div.referenz_detail a
	{
	color:#eee;
	}

a.pdf:before
	{
   	content: '\f1c1';
   	font-family: FontAwesome;
   	font-weight: normal;
   	font-style: normal;
   	margin:0px 5px 0px 0px;
   	text-decoration:none;	
	}

a.referenz_close
	{
	
	float:right;
	color:#ccc;
	font-size:30px;
	text-decoration:none;
	clear:both;
	}
	
a.referenz_close:hover
	{
	color:#fff;
	}
	
a.referenz_close:after{ 
   content: '\f00d';
   font-family: FontAwesome;
   font-weight: normal;
   font-style: normal;
   margin:0px 0px 0px 0px;
   text-decoration:none;
   

} 	

table.referenztable
	{
	border-spacing: 0;
	border-collapse: collapse;
	
	}

table.referenztable td
	{
	vertical-align:top;
	padding:7px 0;
	border-bottom:1px solid #ccc;
	}


table.referenztable td:nth-child(1)
	{
	color:#ccc;
	}

table.referenztable td:nth-child(2)
	{
	padding-left:15px;
	}


table.referenztable tr:last-child td
	{
	border-bottom:0;
	}

.flexslider_wrapper
	{
	float:right;
	width:400px;
	margin-left:50px;
	}
	
	