@charset "utf-8";



@import url(font-awesome.min.css);



/*

@import url("https://fonts.googleapis.com/css?family=Open+Sans:400,600,400italic,600italic|Roboto+Slab:400,700");

*/



/* ------------------------------------------------------------------------- Basic ----------------------------------------------------------------------------------- */



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



* {	-webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }



html, body { max-width: 100%; }

html { height:100%; min-height: 100%; }

body { overflow-y: scroll; -webkit-overflow-scrolling: touch; margin: 0; padding: 0; overflow-y:scroll; position: relative; width: 100%; height: 100%; min-height: 100%; -webkit-font-smoothing: antialiased; font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; font-size: 15px; line-height: 1.5em; color: #404040; background: #fff; font-family: 'Roboto', sans-serif; font-weight: 400; }



section { clear: both; }

section, header, hgroup, address, main, nav, article, aside, footer, video { display: block; }



h1 { margin: 0 0 1em 0; font-size: 1.8em; line-height: 1.3em; color: #404040; font-weight: normal; font-style: normal;}

h2 { margin: 1em 0 1em 0; font-size: 1.8em; line-height: 1.3em; color: #404040; font-weight: normal; font-style: normal; }

h2 span { font-size: 0.5em; color: #FABB00; }

h3 { margin: 1em 0 1em 0; font-size: 1.5em; line-height: 1.2em; font-weight: normal; font-style: normal; }

h4 { margin: 0 0 0 0; font-weight: 600; font-size: 1.0em; line-height: 1.0em; }

h5 { margin: 0 0 0.8em 0; font-size: 0.6em; font-weight: 100; letter-spacing: 4px; text-transform: uppercase; }

h6 { margin: 0 0 0 0; font-size: 1em; line-height: 1.5em; font-weight: 100; letter-spacing: 4px; color: rgb(255,255,255); position: relative; transition: 600ms 0ms; top: 80px; visibility: hidden; opacity: 0.0; }



p { /*margin: 0 0 0 0; padding: 0;  -moz-hyphens: auto; -webkit-hyphens: auto; -ms-hyphens: auto; hyphens: auto; */ margin:10px 0 30px 0;}



a { text-decoration: none; color: rgba(0,0,0,1); }

a:hover { border-bottom: none; }



b, strong { font-weight: 700; font-style: normal; }

i { font-weight: normal; font-style: normal; }



blockquote {

    font-family: Georgia, serif;

    font-size: 18px;

	width:500px;

    font-style: italic;

    margin: 0.25em 0.25;

    padding: 0.25em 40px;

    text-align: justify; 

    line-height: 1.45;

    position: relative;

    color: #383838;

    /*background: #fafafa;

    border: 1px solid silver; */

}

 

blockquote:before {

    display: block;

    content: "\201C";

    position: absolute; 

    font-size: 80px;

    left: -20px;

    top: -20px;

    color: #7a7a7a;

}

 

blockquote cite {

    color: #999999;

    font-size: 14px;

    display: block;

    margin-top: 5px;

}

 

blockquote cite:before {

    content: "\2014 \2009";

}





ul { margin: 0 0 0 0; padding: 0 0 0 22px; display: inline-block; }

ol { margin: 0 0 0 0; padding: 0 0 0 22px; }

li { /*list-style: none;*/ }



form { text-align: left; }

form br { clear: both; }



label { display: block; margin: 0; padding: 10px 0; line-height: 1.6em; }

label.labelzusatz { margin: -20px 0 0 0; font-size: 0.75em; opacity: 0.7; }

input { border: none; width: 100%; padding: 0; background: #fafafa; font-size: 14px; padding: 12px; margin: 6px 0 4px; border: 1px solid #ccc; border-radius: 2px; color: #000; }

textarea { background: #fafafa; border: none; font-size: 14px; padding: 12px; width: 100%; display: block; min-height: 200px; border: 1px solid #ccc; font-family: inherit; }



input[type=submit] { width: auto; font-size: 0.75em; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; background: #ffffff; padding: 14px 20px; color: #c71d22; border: 2px solid #c71d22; cursor: pointer; margin: 30px 0 0; }

input[type=submit]:hover { background: #c71d22; color: #ffffff; }



/* Radio + Checkbox */

.radio, .checkbox { display: none; }

.radio + label, .checkbox + label { -webkit-appearance: none; background: rgb(254,210,36); border-radius: 2px; width: 100%; display: inline-block; position: relative; margin: 5px 14px 0 0; width: 22px; height: 22px; }

.radio:checked + label, .checkbox:checked + label { background: rgb(254,210,36) url(../_img/icon_check.png) no-repeat center; }



label.error { color: #cd1719; }

input.error { border: 1px solid #cd1719; }

textarea.error { border: 1px solid #cd1719; }

 

select { color: inherit; font: inherit; padding: 8px; width: 100%; border: 1px solid #ccc; background: #fafafa; border-radius: 2px; margin: 0 0 10px 0; }



div, section, header, footer { position: relative; }

img { border: 0; height: auto; }

hr { margin: 9px 0 12px 0; border: 0 none; background-color: #eceded; height: 1px; }



table { width: 100%; border-spacing: 0; border-collapse: collapse; }

tr { border-bottom: 1px solid #d4d4d5; }

th { border-right: 1px solid #ffffff; background: #d4d4d5; padding: 10px; font-weight: 100; }

td { border-right: 1px solid #d4d4d5; padding: 10px; }

th:first-child, td:first-child { padding: 10px 10px 10px 0; }

th:last-child, td:last-child { border-right: none; }



.clear { height: 0; clear: both; }

.fl { float: left; }

.fr { float: right; }

.al { text-align: left; }

.ar { text-align: right; }

.ac { text-align: center; }



.collapse_2 { margin: 0; padding: 0; position: static; }

.collapse_2 .row_2 { border-bottom: 1px solid #a1a1a1; position: static; }

.collapse_2 .row_2 .titel_2 { padding: 20px 0 20px 10px; cursor: pointer; font-weight: 400i; font-style: italic; color: #404040; font-size: 2em; }

.collapse_2 .row_2 .arrow { position: absolute; right: 10px; top: 26px; width: 0; height: 0; border-style: solid; border-width: 8px 8px 0 8px; border-color: #404040 transparent transparent transparent; }

.collapse_2 .row_2.active .arrow { transform: rotateX(180deg); -webkit-transform: rotateX(180deg); }

.collapse_2 .row_2 .content_2 { padding: 0 0 20px 0; display: none; transition: 0ms; position: static; }

@media only screen and (max-width: 767px) {

	.collapse_2 .row_2 .titel_2 { padding: 12px 0 12px 10px; font-size: 1.5em; }

	.collapse_2 .row_2 .arrow { top: 18px; }

}



.collapse.produktcollapse { margin: 0; padding: 0; border-radius: 10px; overflow: hidden; }

.collapse.produktcollapse .row { border-bottom: 1px solid #a1a1a1; }

.collapse.produktcollapse .row:last-child { border-bottom: none; }

.collapse.produktcollapse .row .titel { background: rgba(0,0,0,0.1); padding: 10px 10px 10px 10px; cursor: pointer; font-weight: 700; color: #FFFFFF; font-size: 1em; }

.collapse.produktcollapse .row .arrow { position: absolute; right: 10px; top: 19px; width: 0; height: 0; border-style: solid; border-width: 8px 8px 0 8px; border-color: #ffffff transparent transparent transparent; }

.collapse.produktcollapse .row.active .arrow { transform: rotateX(180deg); -webkit-transform: rotateX(180deg); }

.collapse.produktcollapse .row .content { padding: 20px 0 20px 0; display: none; transition: 0ms; }



.collapse.standardcollapse { margin: 40px 0; padding: 0; }

.collapse.standardcollapse .row { border-bottom: 1px solid #000; }

.collapse.standardcollapse .row .titel { padding: 10px 30px 10px 0; cursor: pointer; }

.collapse.standardcollapse .row .titel h3 { margin: 0; }

.collapse.standardcollapse .row .arrow { position: absolute; right: 0; top: 21px; width: 0; height: 0; border-style: solid; border-width: 8px 8px 0 8px; border-color: #404040 transparent transparent transparent; }

.collapse.standardcollapse .row.active .arrow { transform: rotateX(180deg); -webkit-transform: rotateX(180deg); }

.collapse.standardcollapse .row .content { padding: 0 0 10px 0; display: none; transition: 0ms; }



.mitarbeiter_container { margin: 0 -15px; padding: 30px 0 0; }

.mitarbeiter { margin: 0 0 40px 0; }

.mitarbeiter img { width: 100%; }



@media only screen and (max-width: 767px) {

	.mitarbeiter_container .span33 { width: 50%; font-size: 0.9em; }

}



code { font-size: 0.7em; line-height: 1.5em; background-color: #f7f7f9; border: 1px solid #e1e1e8; border-radius: 4px; display: block; padding: 20px; margin: 0 0 40px 0; overflow-x: scroll; }

pre { margin: 0; }



.b_grau { background: #dadada; }

.rot { color: #c71d22; }



/* -------------------------------------------------------------------------- Rastereinheiten -------------------------------------------------------------------------------------- */



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



.width1280 { max-width: 1280px; padding: 0 0px; margin: 0 auto; }

.width890 { max-width: 890px; padding: 0 0px; margin: 0 auto; }

.overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: table; background: rgba(0,0,0,0.3); }

.table_container { position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: table; }

.textcenter { display: table-cell; vertical-align: middle; }

.cover { background-position: center; background-repeat: no-repeat; background-size: cover; }



.span10 { width: 10%; float: left; padding: 0 15px; }

.span20 { width: 20%; float: left; padding: 0 15px; }

.span25 { width: 25%; float: left; padding: 0 15px; }

.span30 { width: 30%; float: left; padding: 0 15px; }

.span33 { width: 33.33%; float: left; padding: 0 15px; }

.span40 { width: 40%; float: left; padding: 0 15px; }

.span50 { width: 50%; float: left; padding: 0 15px; }

.span60 { width: 60%; float: left; padding: 0 15px; }

.span66 { width: 66.66%; float: left; padding: 0 15px; }

.span70 { width: 70%; float: left; padding: 0 15px; }

.span75 { width: 75%; float: left; padding: 0 15px; }

.span80 { width: 80%; float: left; padding: 0 15px; }

.span90 { width: 90%; float: left; padding: 0 15px; }

.span100 { width: 100%; padding: 0 15px; }



@media only screen and (max-width: 767px) {

	.span10 { width: 100%; }

	.span20 { width: 100%; }

	.span25 { width: 100%; }

	.span30 { width: 100%; }

	.span33 { width: 100%; }

	.span40 { width: 100%; }

	.span50 { width: 100%; }

	.span60 { width: 100%; }

	.span66 { width: 100%; }

	.span70 { width: 100%; }

	.span75 { width: 100%; }

	.span80 { width: 100%; }

	.span90 { width: 100%; }

	.span100 { }

}



/* ------------------------------------------------------------------------------- Main -------------------------------------------------------------------------------------------- */



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



main { width: 100%; z-index: 10; }

section { margin: 0; padding: 80px 0 30px 0; }

header { width: 100%; margin: 0; padding: 0 0 0 0; z-index: 11; }



.logo { float: left; width: 360px; margin: 20px 0 10px 0; }

.logo img { width: 100%; }

@media only screen and (max-width: 767px) {

	.logo { width: 220px; margin: 20px 0 10px 10px; }

}



/*.mainnav { float: right; margin: 0 0 0 0; padding: 0 20px; font-size: 1.2em; background: #c71d22; -ms-transform: skew(-10deg); -webkit-transform: skew(-10deg); transform: skew(-10deg); }*/
.mainnav { float: right; margin: 0 0 0 0; padding: 0 20px; font-size: 1.2em; background: #232D32; -ms-transform: skew(-10deg); -webkit-transform: skew(-10deg); transform: skew(-10deg); }

.mainnav > ul { padding: 0 0 0 0; display: block; }

.mainnav > ul > li { list-style: none; float: left; }

.mainnav > ul > li a { color: #ffffff; text-transform: uppercase; display: block; padding: 8px 10px; -ms-transform: skew(10deg); -webkit-transform: skew(10deg); transform: skew(10deg); }

.mainnav > ul > li a:hover { color: rgba(0,0,0,1); }



.mainnav > ul > li:hover .subnav { display: block; }



@media only screen and (max-width: 1200px) {

	.logo { float: none; }

	.mainnav { display: none; float: none; margin: 0 -15px; text-align: center; -ms-transform: skew(0deg); -webkit-transform: skew(0deg); transform: skew(0deg); }

	.mainnav > ul > li { float: none; }

	.mainnav > ul > li a { -ms-transform: skew(0deg); -webkit-transform: skew(0deg); transform: skew(0deg); }

}



/*.subnav { display: none; position: absolute;  background: #c71d22; }*/
.subnav { display: none; position: absolute;  background: #232D32; }

.subnav ul { padding: 0 0 0 0; }

.subnav ul li { list-style: none; }

.subnav ul li a {}

@media only screen and (max-width: 1200px) {

	.subnav { display: block; position: relative; font-size: 0.8em; }

}



.socialnav { float: left; font-size: 0.75em; }

.socialnav ul { padding: 0 0 0 0; }

.socialnav ul li { list-style: none; float: left; margin: 0 0 0 10px; }

.socialnav ul li a { color: rgba(40,26,23,.6); letter-spacing: 2px; text-transform: uppercase; display: block; }

.socialnav ul li a:hover { font-weight: 700; }

.socialnav ul li.aktiv a { font-weight: 700; }



#intro { padding: 50px 0; height: 500px; background-position: center; background-repeat: no-repeat; background-size: cover; }

#intro .width1280 { height: 100%; }

#intro .left { position: absolute; left: 15px; bottom: 0; width: 35%; }

#intro .right { position: absolute; top: 0; bottom: 0; width: 60%; right: 15px; background: rgba(255,255,255,0.8); -ms-transform: skew(-10deg); -webkit-transform: skew(-10deg); transform: skew(-10deg); }

#intro .textcenter { padding: 0 60px; -ms-transform: skew(10deg); -webkit-transform: skew(10deg); transform: skew(10deg); }

#intro h1 { color: #ffffff; }



@media only screen and (max-width: 1200px) {

	#intro .left { position: relative; width: auto; left: auto; padding: 0 15px; }

	#intro .right { top: 100px; width: auto; left: 100px; right: 100px; }

}

@media only screen and (max-width: 767px) {

	#intro { height: auto; }

	#intro .left { }

	#intro .right { position: relative; top: auto; bottom: auto; width: auto; left: auto; right: auto; -ms-transform: skew(0deg); -webkit-transform: skew(0deg); transform: skew(0deg); }

	#intro .textcenter { padding: 20px; -ms-transform: skew(0deg); -webkit-transform: skew(0deg); transform: skew(0deg); }

	#intro .table_container { position: relative; }

	#intro .width1280 { padding: 0 10px; }

}



#homenav { padding: 0; }

.homenav {}

.homenav h1 { color: #ffffff; }

.homenav h2 { margin: 0 0 1em 0; font-size: 2.6em; line-height: 1.2em; color: #ffffff; text-transform: uppercase; }

@media only screen and (max-width: 767px) {

.homenav h2 { margin: 0 0 1em 0; font-size: 1.8em; line-height: 1.3em; }

}



.homenav ul { display: block; padding: 3px; }

.homenav ul li { list-style: none; float: left; width: 33.33%; height: 500px; padding: 0 20px; border: solid 3px #ffffff; background: #aaaaaa; position: relative; }

.homenav ul li a { display: block; width: 100%; height: 100%; position: relative; }

.homenav ul li .bild { position: absolute; left: 0; top: 0; width: 100%; height: 100%; opacity: 0.3; background-position: center; background-repeat: no-repeat; background-size: cover; transition: 500ms; }



.homenav ul li .text_container { position: absolute; bottom: 0; top: 150px; left: 15%; right: 15%; padding: 30px 50px; background: rgba(255,255,255,0.7); -ms-transform: skew(-10deg); -webkit-transform: skew(-10deg); transform: skew(-10deg); }

.homenav ul li .text_container .text { -ms-transform: skew(10deg); -webkit-transform: skew(10deg); transform: skew(10deg); }

.homenav ul li h2 { position: absolute; top: 20px; width: 100%; margin: 0; }



.homenav ul li:nth-child(3n+2) .text_container { bottom: 150px; top: 0; }

.homenav ul li:nth-child(3n+2) h2 { top: auto; bottom: 20px; text-align: right; }



.isNoMobile .homenav ul li:hover .bild { opacity: 0.7; }



@media only screen and (max-width: 1440px) {

	.homenav ul li { width: 50%; }

	.homenav ul li:nth-child(2n) .text_container { bottom: 150px; top: 0; }

	.homenav ul li:nth-child(2n) h2 { top: auto; bottom: 20px; text-align: right; }	

}

@media only screen and (max-width: 980px) {

	.homenav ul li { width: 100%; height: auto; padding: 20px; }

	.homenav ul li .text_container { position: relative!important; top: auto!important; bottom: auto!important; left: auto!important; right: auto!important; padding: 20px 20px!important; -ms-transform: skew(-0deg)!important; -webkit-transform: skew(-0deg)!important; transform: skew(-0deg)!important; }

	.homenav ul li .text_container .text { -ms-transform: skew(0deg); -webkit-transform: skew(0deg); transform: skew(0deg); }

	.homenav ul li h2 { position: relative!important; top: auto!important; bottom: auto!important; text-align: left!important; margin-bottom: 0.5em!important; }	

}

@media only screen and (max-width: 767px) {

}



#produkte_section { }

@media only screen and (max-width: 767px) {

	#produkte_section { padding: 50px 0 30px 0; }

}

#produkte_section .span100, #produkte_section .width1280 { position: static; }



.produkte-titel-zusatztext {margin:15px 10px;padding:10px;border:1px solid #d6d8db;background-color: #e2e3e5;color: #383d41;border-radius: .25rem;}

.produkte-titel-zusatztext p {margin:0;}



ul#produkte { padding: 0; display: block; }

ul#produkte > li { overflow: hidden; list-style: none; float: left; width: 25%; height: 120px; transition: 600ms; -webkit-tap-highlight-color: rgba(255,255,255,0.0); }

ul#produkte > li:nth-child(4n+5) { clear: both; }

ul#produkte li .link { height: 120px; font-size: 1.25em; cursor: pointer; }

ul#produkte li .link .icon img { width: 100%; }

ul#produkte li .link span.icon { display: block; width: 50px; position: absolute; margin: -25px 0 0 0; left: 15px; top: 50%; }



ul#produkte li .link .arrow {  position: absolute; bottom: -20px; left: 28px; top: auto; right: auto; width: 0; height: 0; border-style: solid; border-width: 0 15px 20px 15px; border-color: transparent transparent #d4d4d5 transparent; }



ul#produkte li.aktiv .arrow { bottom: 0; transform: rotateX(0deg); -webkit-transform: rotateX(0deg); }



ul#produkte li .textcenter { padding: 0 80px; }



ul#produkte li .produktinhalt_holder { background: #d4d4d5; width: 100%; position: absolute; left: 0; height: 0; overflow: hidden; transition: 600ms; -webkit-transition: 600ms; }

ul#produkte li .produktinhalt { padding: 40px 0; }

ul#produkte li .produktinhalt li { }



ul#produkte li .produktinhalt .icon { padding: 0 60px 0 0; }

ul#produkte li .produktinhalt .icon img { width: 100%; } 



ul#produkte li .close { position: absolute; right: 20px; top: 20px; cursor: pointer; font-size: 1.5em; }

ul#produkte li .line { position: absolute; width: 100%; height: 2px; }



@media only screen and (max-width: 1100px) {

	ul#produkte > li { width: 50%; }

	ul#produkte > li:nth-child(3n+4) { clear: none; }

	ul#produkte > li:nth-child(2n+3) { clear: both; }

}

@media only screen and (max-width: 767px) {

	ul#produkte > li { width: 100%; }

	ul#produkte > li:nth-child(2n+0) { clear: none; }

	ul#produkte .span33 { display: none; }

	ul#produkte .span66 { padding: 0 15px; }

	

	ul#produkte li .textcenter { padding: 0 80px ; }

}



.newsliste {}

.newsliste .header { padding: 0 0 20px 0; }

.newsliste .row { border-bottom: 1px solid #000; margin: 0 0 40px 0; }

.newsliste .span70 { padding-left: 0; }

.newsliste .span30 { float: right; padding-right: 0; }

.newsliste .bild { width: 100%; height: 150px; float: right; }

.newsliste .content { display: none; }

.newsliste .datum { margin: 0 0 0px 0; }

.newsliste h3 { margin: 0.2em 0 1em 0; }

.newsliste .lead { font-size: 1.3em; line-height: 1.3em; }

.newsliste .newsliste_mehr_link_container { cursor: pointer; }

.newsliste .newsliste_mehr_link { display: inline-block; padding: 0 20px 10px 0; }

.newsliste .arrow { position: absolute; width: 0; height: 0; top: 8px; right: 0; border-style: solid; border-width: 8px 8px 0 8px; border-color: #404040 transparent transparent transparent; }

@media only screen and (max-width: 767px) {

	.newsliste .span30 { padding-left: 0; margin-bottom: 20px; }

}



ul.download { padding: 0; }

ul.download li { list-style: none; position: relative; margin: 0 0 20px 0; padding: 8px 0 0px 40px; }

ul.download img { position: absolute; left: 0; top: 0; display: block; width: 30px; }



.menuicon { display: none; position: absolute; right: 10px; top: 28px; width: 25px; height: 25px; margin: -2px 0 0 0; transition: 0ms; }

.line { width: 25px; height: 2px; background: #000000; position: absolute; }

.line:nth-of-type(1) { top: 0; }

.line:nth-of-type(2) { top: 8px; }

.line:nth-of-type(3) { top: 16px; }



.menuicon.active {}

.menuicon.active .line:nth-of-type(1) { top: 8px; transform: rotate(-45deg); -webkit-transform: rotate(-45deg); }

.menuicon.active .line:nth-of-type(2) { opacity: 0.0; visibility: hidden; }

.menuicon.active .line:nth-of-type(3) { top: 8px; transform: rotate(45deg); -webkit-transform: rotate(45deg); }



@media only screen and (max-width: 1200px) {

	.menuicon { display: block; }

}



@media only screen and (max-width: 767px) {

	.menuicon { top: 10px; }

}



/* ----------------------------------------------------------------------------- Detail -------------------------------------------------------------------------------------------- */



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



a.button { border: solid 2px #000000; padding: 10px 20px; color: #1a171b; cursor: pointer; font-size: 1em; display: inline-block; text-align: center; }



a.buttonbim { width: auto; font-size: 1em; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; background: transparent; padding: 14px 20px; color: #c71d22; border: 2px solid #c71d22; cursor: pointer; margin: 30px 0 0; }

a.buttonbim:hover { background: #c71d22; color: #ffffff; }



.c_white a.button { border: solid 2px #ffffff; color: #ffffff; }



footer { padding: 20px; font-size: 0.8em; }



/* ---------------------------------------------------------------------------- Animation -------------------------------------------------------------------------------------------- */



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



@keyframes pfeilscroll

{

0% { bottom: 21px; }

100% { bottom: 12px; }

}



@-webkit-keyframes pfeilscroll

{

0% { bottom: 21px; }

100% { bottom: 12px; }

}



/* --------------------------------------------------------------------------- Media Queries --------------------------------------------------------------------------------------- */



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



@media only screen and (max-width: 1140px) {

	/*.menuicon { display: block; }*/

}



@media only screen and (max-width: 640px) and (orientation : landscape) {

	html { /* -webkit-text-size-adjust: none; */ }

}



/* ------------------------------------------------------------------------------ Print -------------------------------------------------------------------------------------------- */



@media print {

	#main { width: 100%; }

}





