/* --------------------------------------------------------------- */
/*                                                                 */
/*    HAUPT CSS-DATEI                                              */
/*    Webstobe GmbH, www.webstobe.ch                               */
/*                                                                 */
/* --------------------------------------------------------------- */

/* --------------------------------------------------------------- */
/* --- FARBEN ---------------------------------------------------- */
/* --------------------------------------------------------------- */
/*
	ROT:				#d82a0b
	DUNKELGRAU:			#333333
	HELLGRAU:			#dad1ba
	
*/

/* --------------------------------------------------------------- */
/* --- SCHRIFTEN ------------------------------------------------- */
/* --------------------------------------------------------------- */
/* Tablet Gothic Thin
font-family: "tablet-gothic",sans-serif;
font-style: normal;
font-weight: 200;
*/

/* Tablet Gothic Thin Italic
font-family: "tablet-gothic",sans-serif;
font-style: italic;
font-weight: 200;
*/

/* Tablet Gothic Regular
font-family: "tablet-gothic",sans-serif;
font-style: normal;
font-weight: 400;
*/


/* Tablet Gothic Italic
font-family: "tablet-gothic",sans-serif;
font-style: italic;
font-weight: 400;
*/

/* Tablet Gothic SemiBold
font-family: "tablet-gothic",sans-serif;
font-style: normal;
font-weight: 600;
*/

/* Tablet Gothic SemiBold Italic
font-family: "tablet-gothic",sans-serif;
font-style: italic;
font-weight: 600;
*/

/* Tablet Gothic Bold
font-family: "tablet-gothic",sans-serif;
font-style: normal;
font-weight: 700;
*/

/* Tablet Gothic Bold Italic
font-family: "tablet-gothic",sans-serif;
font-style: italic;
font-weight: 700;
*/

/* --------------------------------------------------------------- */
/* --- HTML TAGS ------------------------------------------------- */
/* --------------------------------------------------------------- */

* {
	margin: 0;
	padding: 0;
}
*, *:before, *:after {
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
body > html {
	height: 100%;
}
body {
	text-align: left;
	background-color: #333333;
	color: #fff;
}
img {
	border: none;
}
a {
	color: #d82a0b;
	text-decoration: none;
	outline: none;
}
a:hover {
	color: #333333;
}
/* --------------------------------------------------------------- */
/* --- FONT  ----------------------------------------------------- */
/* --------------------------------------------------------------- */

body {
	font-family: "tablet-gothic", sans-serif;
	font-style: normal;
	font-weight: 400;
	font-size: 87.5%;
	font-size-adjust: none;
	font-stretch: normal;
	font-variant: normal;
	line-height: 1.4em;
	-webkit-font-smoothing:antialiased;
}
nav ul {
	margin: 0;
	padding: 0;
	list-style: none;
}
nav ul li {
	margin: 0;
	line-height: 1.1em;
	font-style: normal;
}
ul {
	margin: 0;
	list-style: inside url("../images/icons/square.gif") square;

}

ol {
	margin: 0 0 0 25px;
}
p, li {
	font-size: 1.1em;
	line-height: 1.6em;
	margin: 0 0 .6em;
	padding: 0;
}

b {
	font-weight:700;
	font-style:normal;
}
#site-title {
}
h1 {
	font-family: "tablet-gothic", sans-serif;
	font-weight: 200;
	font-style: normal;
	font-size: 2.142em;
	padding-bottom: 0.3em;
	margin: 0 0 .6em;
	border-bottom: 1px solid #fff;
}
h2 {
	font-size: 1.3em;
	margin: 0 0 .6em;
	font-style: normal;
	font-weight: 700;
	line-height:1.2em;
}
table {
	border-collapse: collapse;
}
table tr th {
	font-weight: 700;
}
table tr td {
}
.content-element {
}

div.csc-textpic-intext-right-nowrap .csc-textpic-imagewrap {
    float: right;
    margin-top: -6px;
}
.csc-textpic-intext-right-nowrap .csc-textpic-text {
    margin-right: 0;
}

/* --------------------------------------------------------------- */
/* --- STANDARD-KLASSEN ------------------------------------------ */
/* --------------------------------------------------------------- */
.clear {
	clear: both;
}
.cf::after, .inner::after, nav ul::after {
	clear: both;
	content: "";
	display: table;
}
.inner {
	width: 100%;
	padding: 0 45px 0 30px;
	position: relative;
	z-index: 1;
}
/* --------------------------------------------------------------- */
/* --- HAUPT AUFBAU ---------------------------------------------- */
/* --------------------------------------------------------------- */

#wrapper {
	width: 100%;
	margin: 0 auto;
	text-align: center;
	min-width:980px;
}
#header {
	width: 100%;
	padding-top: 63px;
	height: 141px;
	z-index: 2;
	position: relative;
}
.wrapper-content {
	text-align: left;/*padding-bottom: 100px;*/
	min-height: 550px;
	position:relative;

}

.content-box.padding-box {
    padding: 0 45px;
}


div.csc-textpic .csc-textpic-imagewrap .csc-textpic-image {
    margin-bottom: 10px;
    margin-top: 10px;
}




/* --------------------------------------------------------------- */
/* --- SLOGAN BOX MIT SLIDERDOTS --------------------------------- */
/* --------------------------------------------------------------- */

.slogan-box {
	position:absolute;
	height: 100%;
	width: 30%; /*311px*/
	float: left;
	padding: 125px 10px 10px 10px;
	background-color: #d82a0b;
}
.slider-caption {
	clear: both;
	float: left;
	font-family: "tablet-gothic", sans-serif;
	font-style: normal;
	font-weight: 200;
	font-size: 2.35em; /*2.5em*/
	line-height: 1.2em;
	margin: 0 0 0.6em;
	padding: 20px;
	width: 304px;
	/*-moz-hyphens: auto;
   -o-hyphens: auto;
   -webkit-hyphens: auto;
   -ms-hyphens: auto;
   hyphens: auto; */	
}
.slider-paging {
	bottom: 20px;
	text-align:center;
	position: absolute;
    width: 100%;
	left:0;
}
.slider-paging a {
	background: none repeat scroll 0 0 #fff;
	border-radius: 50%;
	display: inline-block;
	height: 8px;
	margin-right: 15px;
	text-align: center;
	width: 8px;
	position: relative;
	

}

.slider-paging a:last-child {
	margin-right:0;
}

.slider-paging a:hover .pager-container,
.slider-paging a.cycle-pager-active .pager-container{
	border: 1px solid #fff;
	border-radius: 50%;
	left: -5px;
	padding: 8px;
	position: absolute;
	top: -5px; 
}

.content-column-25-right.content-text-doted {
    margin: 5px 0 20px;
    width: 100%;
}


/* Referenz-Slider */
.reference-slider {
	position:relative;
	z-index:1;
}

.grid-2 .slider-paging {
	bottom: 20px;
	position: absolute;
	left: 0;
	z-index:101;
	text-align: center;
    width: 100%;
}


.grid-2 .slider-paging a {
	background-color: #d82a0b;
}
.grid-2 .slider-paging a:hover .pager-container,
.grid-2 .slider-paging a.cycle-pager-active .pager-container{
	border: 1px solid #d82a0b;
}

.reference-images > figure {
	width:100%;
	margin: 0;
}

.reference-images figure .fancybox > img {
    height: auto;
    max-width: 100%;
}

.content-count-1 {
    max-width: 417px;
}

/* --------------------------------------------------------------- */
/* --- SLIDER ---------------------------------------------------- */
/* --------------------------------------------------------------- */
.content-box {
    background-color: #333333;
    float: right;
    height: 100%;
    position: relative;
    width: 70%;
}


.grid-bildslider {
	height: 0;
	margin-right: 45px;
	position: relative;
	min-height: 550px;
}
.items {
	height: 100%;
	overflow: hidden;
	position: absolute;
	width: 100%;
	z-index: 0;
	max-height: 550px;
}
.grid-bildslider .item {
	height: 100%;
	width: 100%;
}
/* --------------------------------------------------------------- */
/* --- LOGO ------------------------------------------------------ */
/* --------------------------------------------------------------- */
.logo {
	float: left;
	position: relative;
	width:40%;
}

.logo img {
    height: auto;
    max-width: 100%;
}

/* --------------------------------------------------------------- */
/* --- REFERENZEN ------------------------------------------------ */
/* --------------------------------------------------------------- */

.teasear-block li {
    list-style: outside none none;
}

.teasear-block img {
    height: auto;
    width: 100%;
}

/* --------------------------------------------------------------- */
/* --- MAIN NAVIGATION ------------------------------------------- */
/* -----------------------------------------------------slid---------- */

.main-navigation {
	position: relative;
	float: right;
	top: 14px;
	text-align:right;
	width:55%;
}
.main-navigation ul {
	list-style: none;
	display:inline-block;
}
.main-navigation ul:after {
	content: "";
	display: table;
	clear: both;
}

.main-navigation ul li {
	font-size: 1.28em;
	display: block;
	float: left;
	margin: 0 25px 0 0;
}

@media (max-width:990px) {
	.main-navigation ul li {
		font-size: 1.142em;
	}
}


@media (min-width:1200px) {
.main-navigation {
	top: 19px;

}
}

@media (min-width:1180px) {
.main-navigation {
	top: 19px;

}
}


@media (min-width:1150px) {
.main-navigation {
	top: 19px;

}
}


.main-navigation ul li:last-child {
	margin: 0;
}


.main-navigation ul li a {
	color: #fff;
	
}
.main-navigation ul li a:hover {
	color: #d82a0b;
}
/* AKTIVER ZUSTAND */
.main-navigation ul li.act a {
	color: #d82a0b;
	/*font-weight: 700;*/
}
.main-navigation ul li.act a:hover {
}
/* MIT SUBLEVEL */
.main-navigation ul li.sub a {
}
.main-navigation ul li.sub a:hover {
}
/* --------------------------------------------------------------- */
/* --- SUB NAVIGATION -------------------------------------------- */
/* --------------------------------------------------------------- */

.sub-navigation {
}
.sub-navigation ul {
}
.sub-navigation ul li {
}
.sub-navigation ul li a {
}
.sub-navigation ul li a:hover {
}
/* AKTIVER ZUSTAND */
.sub-navigation ul li.act a {
}
.sub-navigation ul li.act a:hover {
}
/* MIT SUBLEVEL */
.sub-navigation ul li.sub a {
}
.sub-navigation ul li.sub a:hover {
}
/* --------------------------------------------------------------- */
/* --- SERVICE NAVIGATION ---------------------------------------- */
/* --------------------------------------------------------------- */

.service-navigation {
}
.service-navigation ul {
	list-style: none;
}
.service-navigation ul:after {
	content: "";
	display: table;
	clear: both;
}
.service-navigation ul li {
}
.service-navigation ul li a {
	color: #333333;
}
.service-navigation ul li a:hover {
	color: #d82a0b;
	font-weight: 200;
}
/* AKTIVER ZUSTAND */
.service-navigation ul li.act a {
	color: #d82a0b;
	font-weight: 400;
}
.service-navigation ul li.act a:hover {
	color: #d82a0b;
}
/* --------------------------------------------------------------- */
/* --- META NAVIGATION ------------------------------------------- */
/* --------------------------------------------------------------- */

.meta-navigation {
	position: relative;
	top: -5px;
}
.meta-navigation ul {
	list-style: none;
	text-align: left;
}
.meta-navigation ul li {
	float: left;
	margin-right: 20px;
}
.meta-navigation ul li a {
	color: #333333;
}
.meta-navigation ul li a:hover {
	color: #d82a0b;
}
/* AKTIVER ZUSTAND */
.meta-navigation ul li.act a {
}
.meta-navigation ul li.act a:hover {
}
/* --------------------------------------------------------------- */
/* --- INHALTE --------------------------------------------------- */
/* --------------------------------------------------------------- */

.content-column-100.home {
	float: left;
	width: 100%;
	max-width:100%;
}
.content-column-100 {
	float: left;
	width: 100%;
	max-width:850px;
}

.firstItem {
    list-style: outside none none;
	line-height:1em;
}


.grid-2 p,
.grid-2 h1,
.grid-2 h2,
.grid-2 h3 {
	padding:0;
}


.grid-2 {
	float: left;
	width: 49%;
}


.grid-2:nth-child(2n+1) {
    margin-right: 2%;
    width: 49%;
}

/* --------------------------------------------------------------- */
/* --- ADDRESS & CONTACT ------------------------------------------ */
/* --------------------------------------------------------------- */

.phone p {
	color: #333333;
	line-height: 0.5em;
	margin: 0;
	padding: 0;
}
.address p {
	font-size: 1em;
	font-style: normal;
	font-weight: 400;
	text-align: right;
}
.contact p {
	font-size: 1em;
	font-style: normal;
	font-weight: 400;
	text-align: left;
}
.address {
	float: right;
}
.contact {
	float: left;
}
/* --------------------------------------------------------------- */
/* --- STICKY FOOTER --------------------------------------------- */
/* --------------------------------------------------------------- */

html, body {
	height: 100%;
}
#wrapper {
	position: relative;
	width: 100%;
	margin: 0 auto;
	min-height: 100%;
	margin-bottom: -62px;
	text-align: left;
}
#wrapper:after {
	content: "";
	display: block;
	height: 62px;
}
#wrapper-content {
	position: relative;
	z-index: 2;
	text-align: left;
}
.footer {
	height: 79px;
	background-color: #dad1ba;
	color: #333333;
	position: relative;
	width: 100%;
	clear: both;
	padding-top: 18px;
	top: 0;
}
/* --------------------------------------------------------------- */
/* --- MAPS ------------------------------------------------------ */
/* --------------------------------------------------------------- */

.maps {
    float: right;
	margin-left: 20px;
	margin-right: 5px;
}

.contact-address {
    float: left;
    width: 35%;
}

iframe {
    min-width: 500px;
}

@media (max-width:1290px) {
	iframe {
		min-width: 440px;
	}

}

@media (max-width:1150px) {
	iframe {
		min-width: 400px;
	}

}

@media (max-width:1090px) {
	iframe {
		min-width: 350px;
	}

}



/* --------------------------------------------------------------- */
/* --- IMAGE RENDERING TYPO3 ------------------------------------- */
/* --------------------------------------------------------------- */

div.csc-textpic-right .csc-textpic-imagewrap, div.csc-textpic-left .csc-textpic-imagewrap {
	width: 100%;
}
div.csc-textpic-right .csc-textpic-imagewrap .csc-textpic-image img {
	float: right;
}
div.csc-textpic .csc-textpic-imagewrap figure, div.csc-textpic figure.csc-textpic-imagewrap {
	display: block;
}
DIV.csc-textpic .csc-textpic-imagewrap FIGURE {
	max-width: 100%;
	overflow: hidden;
	display: block;
}
DIV.csc-textpic-center .csc-textpic-imagewrap, DIV.csc-textpic-center FIGURE.csc-textpic-imagewrap {
	width: 100%;
	display: block;
}
DIV.csc-textpic-center .csc-textpic-center-outer {
	max-width: 100%;
}
DIV.csc-textpic-center .csc-textpic-center-inner {
	width: 100%;
}
/* --------------------------------------------------------------- */
/* --- LINK-KLASSEN ---------------------------------------------- */
/* --------------------------------------------------------------- */

span.link-decoration {
	color: #d82a0b;
	text-decoration: none;
}
span.link-decoration:hover {
	color: #333333;
	text-decoration: none;
}

.content-column-100 span.link-decoration:hover {
	color: #fff;
	text-decoration: none;
}
a.no-decoration-page span.link-decoration, a.no-decoration-file span.link-decoration, a.no-decoration-url span.link-decoration, a.no-decoration-email span.link-decoration {
	text-decoration: none;
	border: none;
}
a.internal-link-file, a.internal-link-url, a.internal-link-page {
	text-decoration: none;
}
a.mail, a.popup-link-url, a.popup-link-page, a.popup-link-file, a.external-link-file, a.external-link-url, a.external-link-page {
	text-decoration: none;
	position: relative;
}
a.mail span.link-icon, a.popup-link-file span.link-icon, a.popup-link-url span.link-icon, a.popup-link-page span.link-icon, a.external-link-file span.link-icon, a.external-link-url span.link-icon, a.external-link-page span.link-icon {
	width: 14px;
	height: 18px;
	display: inline-block;
	background-image: url(../images/icons/icon-sprite.gif);
	background-repeat: no-repeat;
}
a.external-link-file span.link-icon, a.external-link-url span.link-icon, a.external-link-page span.link-icon {
	background-position: -4px -18px;
}
a.popup-link-file span.link-icon, a.popup-link-url span.link-icon, a.popup-link-page span.link-icon {
	background-position: -40px -18px;
}
a.mail span.link-icon {
	background-position: -58px -18px;
}
a.download, a.pdf, a.word, a.excel, a.powerpoint, a.zip {
	position: relative;
	text-decoration: none;
	padding: 2px 0 2px 22px;
}
a.download span.link-icon, a.pdf span.link-icon, a.word span.link-icon, a.excel span.link-icon, a.powerpoint span.link-icon, a.zip span.link-icon {
	width: 18px;
	height: 18px;
	display: block;
	position: absolute;
	left: 0px;
	bottom: 0px;
	background-image: url(../images/icons/icon-sprite.gif);
	background-repeat: no-repeat;
}
a.download span.link-icon {
	background-position: -162px -0px;
}
a.pdf span.link-icon {
	background-position: -108px -0px;
}
a.word span.link-icon {
	background-position: -54px -0px;
}
a.excel span.link-icon {
	background-position: -0px -0px;
}
a.powerpoint span.link-icon {
	background-position: -144px -0px;
}
a.zip span.link-icon {
	background-position: -18px -0px;
}
/* --------------------------------------------------------------- */
/* --- PAGE BROWSER ---------------------------------------------- */
/* --------------------------------------------------------------- */

.browsebox {
	list-style-type: none;
	margin: .5em 0 0;
}
.browsebox li {
	display: inline;
	margin: 0;
	padding: 0;
	line-height: 30px;
}
.browsebox li a {
	color: #900;
	padding: 4px 8px;
	border: 1px solid #CCC;
	background-color: #F2F2F2;
	margin: 0 2px 0;
}
.browsebox li a:hover {
	background-color: #E2E2E2;
}
.browsebox li.act a {
	text-decoration: underline;
}
/* --------------------------------------------------------------- */
/* --- FORM ------------------------------------------------------ */
/* --------------------------------------------------------------- */
form {
}
input, textarea {
	border: 1px solid #fff;
	background-color: #333333;
	padding: 2px;
	color: #fff;
	font-family: "tablet-gothic", sans-serif;
	font-size: 1em;
	font-weight:200;
}
input[type = "submit"], input[type = "button"], input[type = "reset"] {
	border: 1px solid #fff;
	background-color: #333333;
	padding: 2px 5px;
}
input[type = "radio"], input[type = "checkbox"] {
	background: none;
	border: none;
}
input:hover, select:hover, textarea:hover {
	background-color: #fff;
	color: #333333;
}
input:focus, select:focus, textarea:focus {
	background-color: #fff;
	color: #333333;
}
select {
	font-size: 1em;
	border: 1px solid #fff;
	background-color: #333333;
	padding: 1px;
}
fieldset {
	border: none;
}
.input-50 input {
	float: left;
	margin-right: 1%;
	margin-top: 1%;
	width: 49%;
}
.input-100 textarea {
	margin-top: 1%;
	min-height: 100px;
	width: 99%;
}

.input-33 {
	width: 32.32%;
	float: left;
	margin-right: 1%;
	margin-top: 1%;	
}

.input-33 input {
    width: 100%;
}

.input-50-submit input[type="submit"] {
	margin-top: 20px;
}
.input-50-pflicht {
	margin-top: 10px;
}
.greeting {
	margin: 20px 0 0 0;
}
legend {
	display: none;
}
label, select, input[type = "checkbox"], input[type = "radio"], input[type = "button"], input[type = "submit"] {
	cursor: pointer;
	margin-right: 20px;
}
.label {
	margin: 10px 0 3px;
	font-family: "tablet-gothic", sans-serif;
	font-style: normal;
	font-weight: 400;
}
.field {
	margin-right: 2%;
	font-family: "tablet-gothic", sans-serif;
	font-style: normal;
	font-weight: 200;
}
.radio.input-field {
	margin-right: 2px;
}
.js-error {
	padding: 10px;
	margin: 0 0 20px;
	border: 1px solid #900;
	background-color: #F0D9D9;
}
.js-error p {
	color: #d82a0b;
	padding: 0 0 0 15px;
	background-image: url(../images/icons/list_error.gif);
	background-position: left .4em;
	background-repeat: no-repeat;
}
.form-required {
	color: #fff;
}
.form-label {
	line-height: 2em;
}
.form-radio {
	background: none;
	border: none;
}
.form-error {
	padding: 10px;
	margin: 0 0 20px;
	border: 1px solid #900;
	background-color: #F0D9D9;
}
.form-error ul {
	list-style-type: none;
	margin: 5px 0 0;
}
.form-error ul li {
	background-image: url(../images/icons/list_error.gif);
	background-repeat: no-repeat;
	background-position: left center;
	padding: 0 0 0 15px;
}
.form-disabled {
}

.form-submitted .label {
    display: inline-block;
    width: 30%;
}
.form-submitted .field {
    display: inline-block;
    width: 60%;
}
.label.message {
    margin: 0;
    vertical-align: top;
}

.form-row.message {
    margin-top: 10px;
}