/* Css-Reset +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-weight: inherit;
	font-style: inherit;
	font-size: 100%;
	font-family: inherit;
	vertical-align: baseline;
}

/* remember to define focus styles! */
:focus {
	outline: 0;
}
body {
	line-height: 1;
	color: black;
	background: white;
}
ol, ul {
	list-style: none;
}
/* tables still need 'cellspacing="0"' in the markup */
table {
	border-collapse: separate;
	border-spacing: 0;
}
caption, th, td {
	text-align: left;
	font-weight: normal;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: "";
}
blockquote, q {
	quotes: "" "";
}

/* Css-Reset ---------------------------------------------------------------*/


html {
	height: 101%;
	font-size: 14px;
}

body {
	background-color: #fafafa;
	/*margin-top: 22px;*/
	font: 1em/1.28571428571em Arial;
	padding-bottom: 5em;
}

body.grid {
		background: url("../images/grid.gif");
}

#accessibility_navigation {
	display: none;
}

hr {
	display: none;
}

a:link,
a:visited {
	color: #7b7b7c;
	text-decoration: none;
}

#wrapper {
	margin: 0 auto;
	width: 768px;
	overflow: hidden;
	background-color: #fff;
	padding-left: 24px;
	padding-right: 24px;
}

/* Logo ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
#logo {
	display:block;
	float:right;
	margin-bottom:20px;
	margin-top:19px;
}
/* Logo --------------------------------------------------------------------*/


/* Global Navigation +++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

#global_navigation {
	margin-top:20px;
}

#global_navigation li {
	display: inline;
	font-size: 9px;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	margin-right: 15px;
}

#global_navigation a:hover {
	text-decoration: underline;
}

/* Global Navigation -------------------------------------------------------*/

/* Main Navigation +++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

#main_navigation {
	clear: both;
	border-top: 1px solid #b6c0c6;
	border-bottom: 1px solid #b6c0c6;
	text-align: center;
	margin-bottom: 44px;
	padding: 2px 0;
	display: block;
	height: 24px;
	line-height: 23px;
}

#main_navigation li {
	display: inline;
	line-height: 18px;
	padding-bottom: 1px;
}

#main_navigation a {
	line-height: 22px;
	padding: 3px 10px;
	text-transform: uppercase;
	font-size: 11px;
	letter-spacing: 0.1em;
	margin: 0;
}

#main_navigation a:hover,
#main_navigation .active a {
	background: #f0f0f0;
}
/* Main Navigation ---------------------------------------------------------*/

/* Sub Navigation ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

#sub_navigation {
	width: 168px;
	color: #7b7b7c;
	font-size: 12px;
	float: left;
	margin: 3px 23px 20px 0;
}

#sub_navigation li {
	margin-bottom: 6px;
	line-height: 14px;
}

#sub_navigation li a {
	line-height: 14px;
}

#sub_navigation a:hover {
	text-decoration: underline;
}

#sub_navigation .active a {
	color: #bd121c;
}

#sub_navigation span {
	text-transform: uppercase;
	color: #7B7B7C;
	display: block;
	padding-bottom: 2px;
	border-bottom: 1px solid #B6C0C6;
	font-size: 11px;
	letter-spacing: 0.1em;
	margin-bottom: 6px;
}

#sub_navigation .products {
	border-bottom: 1px solid #B6C0C6;
	margin-bottom: 20px;
}

/*Sub Navigation -----------------------------------------------------------*/


/* Area Image ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
#area_image {
	float: left;
	width:97px;
	margin-right: 22px;
	margin-top: 5px;
}
/* Area Image --------------------------------------------------------------*/

/* Content +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

#content {
	margin-bottom: 2px;
	overflow: hidden;
	color: #7b7b7c;
	font-family: Arial;
	margin-bottom: 5em;
}

#content h1 {
	clear: none;
	font-size: 30px;
	line-height: 36px;
	font-family: "CorporateS-Light";
	color: #7b7b7c;
	margin-bottom: 23px;
}

#content h2 {
	text-transform: uppercase;
	font-weight: bold;
	font-size: 12px;
	line-height: 16px;
	margin-bottom: 8px;
	letter-spacing: 1px;
	color: #7B7B7C;
	display: block;
	clear: both;
}

#content h3 {
	font-size: 14px;
	font-weight: bold;
	letter-spacing: 0.03em;
	margin-bottom: 6px;
}

#content h4 {
	margin-bottom: 6px;
}

#content a {
	text-decoration: underline;
}

#content em {
	font-style: italic
}

#content strong {
	font-weight: bold;
	letter-spacing: 0.01em;
	font-size: 13px;
}

#content a:hover {
	color: #BD121C;
	text-decoration: underline;
}

#wrapper .start a {
	text-decoration: none;
}
#wrapper .start a:hover {
	color: #7B7B7C;
	text-decoration: underline;
}

#content p {
	font-size: 14px;
	line-height: 24px;
	margin-bottom: 12px;
}

#content p.bildunterschrift {
	font-size: 12px;
	line-height: 15px;
}

#content p img {
	display: block;
}

#content hr {
	display: block;
	clear: both;
	background: #fff;
	border: 1px solid;
}

#wrapper .p_columns {
	overflow: hidden;
	width: auto;
	margin-right: -24px;
}

#wrapper .p_columns p{
	float: left;
	width: 234px;
	margin-right: 24px;
}

.links {
	float: left;
	width: 308px;
	margin-bottom: 29px;
}

.rechts {
	width: 247px;
	float: right;
	margin-bottom: 29px;
}

#content ul {
	clear: both;
	padding: 8px 12px 8px 24px;
	list-style: outside;
	line-height: 22px;
	list-style-type: disc;
}

.leistungen {
	border: 1px solid #7b7b7c;	
	position: relative;
	margin-bottom: 12px;
}

.ecke {
	display: block;
	width: 5px;
	height: 5px;
	background: url("../images/circle_7b7b7c.gif") no-repeat;
	position: absolute;
}

.ecke-1 {
	left: -1px;
	top: -1px;
}

.ecke-2 {
	top: -1px;
	right: -1px;
	background-position: -6px 0;
}

.ecke-3 {
	bottom: -1px;
	right: -1px;
	background-position: -6px -6px;
}

.ecke-4 {
	left: -1px;
	bottom: -1px;
	background-position: 0 -6px;	
}


#content li {
	font-size: 12px;
}

#content .pusher {
	width: 458px;
	float: right;
}

#content .right_col {
	float: right;
	width: 247px;
	margin-left: 24px;
}

#content .article {
	padding-bottom: 3em;
	border-bottom: 1px solid #B6C0C6;
	margin-bottom: 3em;
}

#content .date {
	text-transform: uppercase;
	letter-spacing: 1px;
	font-size: 11px;
}

/*Content ------------------------------------------------------------------*/


/* Startseite ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

#wrapper .start {
	padding: 0;
	float: none;
	width: 100%;
}

.tripple_h1 {
	overflow: hidden;
	width: auto;
}

#content .tripple_h1 h1{
	float: left;
	font-family: Arial;
	font-size: 14px;
}

.tripple_h1 img {
	margin: 0 auto;
	margin-top: 48px;
	display: block;
	margin-bottom: 18px;
}

.tripple_h1 a {
	display: block;
	overflow: hidden;
	text-transform: uppercase;
	font-size: 9px;
	letter-spacing: 0.15em;
	width: 240px;
	text-align: center;
	height: 170px;
/*	margin-right: 12px;
	margin-left: 12px;
*/
}

.tripple_h1 a:hover {
	text-decoration: underline;
}

.dark {
	border-top: 1px solid #b6c0c6;
/*	background: #f5f5f5;*/
	margin-bottom: 1em;
}

.tripple_div {
	border-top: 2px solid #fff;
	border-bottom: 2px solid #fff;
	overflow: hidden;
	padding-bottom: 10px;
}

.tripple_div div {
	float: left;
	width: 232px;
	padding-top: 7px;
	padding-right: 24px;	
}

.tripple_div h1 {
	margin-bottom: 10px;
}

.tripple_div h1 a{
	color: #787878;
	font-size: 12px;
	line-height: 12px;
	font-weight: bold;
}

.tripple_div h1 a:hover {
	color: #BD121C;
}

.tripple_div .date {
	text-transform: uppercase;
	font-size: 9px;
	letter-spacing: 0.1em;
	color: #5D5D5D;
	line-height: 12px;
	padding-bottom: 12px;
	display: block;
}

.tripple_div p {
	font-size: 12px;
	line-height: 16px;
	color: #5D5D5D;
}

.tripple_div .more {
	display: inline;
	position: relative;
}

.tripple_div .more span {
	position: absolute;
	top: 0px;
	left: 6px;
	display: block;
	text-indent: -10000em;
	width: 20px;
	height: 15px;
	background: url("../images/arrow-right.gif") 0 50% no-repeat;
}

.tripple_div .more:hover span {
	background: url("../images/arrow-right-hover.gif") 0 50% no-repeat;
}

/*Startseite ---------------------------------------------------------------*/


/*sIFR +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

/* These are standard sIFR styles... do not modify */

.sIFR-flash {
	visibility: visible !important;
	margin: 0;
}

.sIFR-replaced {
	visibility: visible !important;
}

span.sIFR-alternate {
	position: absolute;
	left: 0;
	top: 0;
	width: 0;
	height: 0;
	display: block;
	overflow: hidden;
}

/* Hide Adblock Object tab: the text should show up just fine, not poorly with a tab laid over it. */
.sIFR-flash + div[adblocktab=true] {
  display: none !important;
}

/* These "decoy" styles are used to hide the browser text before it is replaced... the negative-letter spacing in this case is used to make the browser text metrics match up with the sIFR text metrics since the sIFR text in this example is so much narrower... your own settings may vary... any weird sizing issues you may run into are usually fixed by tweaking these decoy styles */

.sIFR-hasFlash h1 {
	visibility: hidden;
}

/*sIFR ---------------------------------------------------------------------*/