body, html{
	margin: 0 0 0 0;
	padding: 0 0 0 0;
}

#custom-doc{
	width: 978px;
	text-align: center;
	margin: 0px auto 200px auto;
	z-index: 0;
	position: relative;
}

#custom-doc-inner{
	position: relative;
	top: 98px;
	/*height: 1%;*/
	zoom:1;
}

/* container with branding, logo, menu, searchbox - - - - - - - - - - - - - */

#hd{
	height: auto;
	position: relative;
	z-index: 1000;
	/*position: relative;*/
	/*overflow: hidden;*/
}

#hd h1{
	margin: 0;
	padding: 0;
	width: 100%;
	height: 185px !important;
	line-height: 185px !important;
	position: absolute;
	top: -84px;
	left: 0px;
}

#hd h1 a{
	display: block;
	text-align: left;
	text-indent: -9999px;
	margin: 0;
	padding: 0;
	width: 100%;
	/* do not put double line-height...
	height: 185px !important;
	line-height: 185px !important;
	*/
}

#hd h2, #hd blockquote, #mnu-skiplink{
	position: absolute;
	top: -9999px;
}

/* mnu-main  - - - - - - - - - - - - - - - */
#mnu-main{
	position: absolute;
	left: -1px;
	top: 160px;
	width: 170px;
	overflow: hidden;
}

/* searchbox - - - - - - - - - - - - - - - */
#searchbox-container{
	position: absolute;
	top: 2px;
	right: 0;
	width: 310px;
	height: 25px;
	text-align: right;
}

#searchbox{
	float: right;
	display: inline;
	padding: 2px 20px 0px 0px;
	margin: 0;
}
#searchbox form, #searchbox fieldset{
	display: inline;
	margin: 0;
	padding: 0;
}
#searchbox form fieldset label{
	float: left;
	display: inline;
	padding-right: 5px;
	line-height: 18px;
	*line-height: 18px;
}
#searchbox form fieldset input.input-text{
	float: left;
	display: inline;
	border-top: 1px solid #999;
	border-bottom: 1px solid #999;
	border-left: 1px solid #999;
	border-right: 0px none white !important;
	padding: 0;
	margin: 0;
	height: 16px;
	line-height: 16px;
	width: 117px;
}
#searchbox form fieldset input.input-submit-image{
	display: inline;
	width: 18px;
	height: 18px;
	margin: 0;
	padding: 0;
	border-width: 0;
}
#searchbox form:after{content:".";display:block;height:0;clear:both;visibility:hidden;}

/* sitefunc menu with sitefunc and lang - - - - - - - - - - - - - - - */
#mnu-sitefunc-container{
	position: absolute;
	top: 15px;
	right:50%;  
	width: 800px;
	margin: 0 -400px 0 0;
	text-align: right;
}

#mnu-sitefunc-container-inner{
	float: right;
	display: inline;
	text-align: right;
}

ul#mnu-sitefunc{
	margin: 0;
	padding: 0;
	display: inline;
} 

ul#mnu-sitefunc li{
	display: inline;
	line-height: 18px;
	list-style-type: none;
	margin: 0;
	padding: 0;
}

ul#mnu-sitefunc li a{
	display: inline;
	text-align: left;
	padding: 0px 5px 0px 5px;
	margin: 0;
	zoom: 1;
	/*border-left: 1px solid #999;*/
}

ul#mnu-sitefunc li.mnu-last a{
	/*border-left: 0px none white;*/
}

ul#mnu-language{
	margin: 0;
	padding: 0;
	display: inline;
} 

ul#mnu-language li{
	display: inline;
	list-style-type: none;
	margin: 0;
	padding: 0;
}

ul#mnu-language li a{
	display: inline;
	text-align: left;
	padding: 0px 5px 0px 5px;
	margin: 0;
	zoom: 1;
	/*border-left: 1px solid #999;*/
}

ul#mnu-language li.mnu-last a{
	/*border-left: 0px none white;*/
}



/* breadcrumb menu - - - - - - - - - - - - - */
#mnu-breadcrumbtrail{
	clear: both;
	text-align: left;
	padding: 12px 18px 12px 18px;
}

/* content */

#bd{
	text-align: left;
	margin: 116px auto 116px auto;
	width: 678px;
	overflow: hidden;
	/*min-height: 300px;*/
	position: relative;	
	z-index: 0;
}

#bd-inner{
	min-height: 260px;
	margin: 20px;
	padding: 0px;
	*zoom:1;
}

#bd h1, #bd h2, #bd h3, #bd h4, #bd h5{
	margin: 0.3em 0 0.3em 0;
}


/* footer  - - - - - - - - - - - - - */
#ft{
	margin: -13px 20px 5px 20px;
	min-height: 20px;
	overflow: hidden;
	text-align: right;
	line-height: 100%;
}


#ft h3, #ft h4, #ft h5{
	margin: 0.2em 0 0.1em 0;
}

#ft span.ft-copy{
}

#ft ul#mnu-footer{
	display: inline;
	margin: 0;
	padding: 0;
}
#ft ul#mnu-footer li{
	list-style-type: none;
	display: inline;
	margin: 0 0 0 8px;
	padding: 0 0 0 4px;
	border-left: 1px solid black;
}

#ft ul#mnu-footer li.mnu-first{}
#ft ul#mnu-footer li.mnu-last{}


#ft h2{
	position: absolute;
	top: -9999px;
}



/* content settings - - - - - - - - - */
.content{
}

/* overwrite yui settings we have ems and don't want this with zoom function, need fixed width  638 - 2* 1px border = 636px */

/* 1 col normal and normal b */
.yui-g{
	margin: 18px 0 18px 0;
}
.yui-g .content{
	padding: 0px 18px 0px 18px;
}


/* three cols 3-3-3*/
.yui-gb{
	margin: 18px 0 18px 0;
}
.yui-gb .yui-u{
	padding: 0;
	margin: 0;
	overflow: hidden;
}

.yui-gb .first{
	width: 212px !important;
}
.yui-gb .second{
	width: 212px !important;
}
.yui-gb .third{
	width: 212px !important;
}
.yui-gb .first .content{
	padding: 0px 18px 0px 18px;
}
.yui-gb .second .content{
	padding: 0px 18px 0px 18px;
}
.yui-gb .third .content{
	padding: 0px 18px 0px 18px;
}


/* two cols 66-33 */
.yui-gc{
	margin: 18px 0 18px 0;
}
.yui-gc .yui-u{
	padding: 0;
	margin: 0;
	overflow: hidden;	
}
.yui-gc .first{
	width: 424px !important;
}
.yui-gc .last{
	width: 212px !important;
}

.yui-gc .first .content{
	padding: 0px 18px 0px 18px;
}

.yui-gc .last .content{
	padding: 0px 18px 0px 18px;
}

/* two cols 33-66 */
.yui-gd{
	margin: 18px 0 18px 0;
}
.yui-gd .yui-u{
	padding: 0;
	margin: 0;
	overflow: hidden;	
}
.yui-gd .first{
	width: 212px !important;
}
.yui-gd .last{
	width: 424px !important;
}

.yui-gd .first .content{
	padding: 0px 18px 0px 18px;
}

.yui-gd .last .content{
	padding: 0px 18px 0px 18px;
}

/* two cols 50-50 */
.yui-g{
	margin: 18px 0 18px 0;
}
.yui-g .yui-u{
	padding: 0;
	margin: 0;
	overflow: hidden;	
}

.yui-g .first .content{
	padding: 0px 18px 0px 18px;
}

.yui-g .last .content{
	padding: 0px 18px 0px 18px;
}

/* ##########################
** ### TYPO3 CMS     ########
** ##########################
*/

/* ##########################
** ### contenttable  ########
** ##########################
*/

/* contenttable from tt_content */
table.contenttable{width: 100%; border: 0px none white; border-collapse: collapse; padding: 0; margin: 0px 0px 0px 0px;}
table.contenttable tr{}
table.contenttable tr td{padding: 1px 2px; text-align: left; vertical-align: top; empty-cells: show; }
table.contenttable tr.tr-even td {background: transparent !important;}
table.contenttable tr.tr-odd td {background: transparent !important;}
table.contenttable tr.tr-0 td{font-weight: normal; border-bottom: 0px none #fff !important; color: #000; background: transparent !important;}
table.contenttable tr.tr-last td{}
table.contenttable tr td{}
table.contenttable tr td.td-0{font-weight: normal;}
table.contenttable tr td.td-last{}

/*css style table used the same class for the table */
table.contenttable caption{text-align: left; color: #333; font-size: 1.1em; font-weight: bold;}
table.contenttable thead tr td{font-weight: bold; border-bottom: 0px none #fff !important; color: #000; }
table.contenttable tbody tr td, table.contenttable tbody tr th {vertical-align: middle; background: transparent; border-top: 1px solid #688500; border-bottom: 1px solid #688500; border-left: 0px none white; border-right: 0px none white;}
table.contenttable tfoot tr td{font-weight: bold; border-top: 0px none #fff !important; color: #000; background: transparent;}
table.contenttable th {font-weight: bold;}
table.contenttable td p.bodytext{display: inline;}
table.contenttable tbody tr:hover td, table.contenttable tbody tr:hover th{background: #efefef;}
table.contenttable a {font-weight: bold;}

/*forms in content - - - - - - - - -*/
.FORMGENERIC{
}
.FORMLABEL{
	padding-right: 5px;
}
.FORMINPUT{
	padding-right: 5px;
	width: 90%;
}
.FORMERROR{
	color:#890C00;
	font-weight:bold;
}
.FORMSECTION{
	font-weight: bold;
	color: #000099;
}
.FORMHEAD{
	font-size: 14px;
	font-weight: bold;
	color: #6699FF; 
}
.FORMTIPS{
	font-size: 10px;
}
.INPUTTEXT{
	border: 1px solid #666;
	width: 90% !important;
	background: transparent;
}
.INPUTSUBMIT{
	border: 1px solid #666;
	background-color:#890C00;
	color: #fff;
	padding: 2px 10px;
	font-weight: bold;
}
.INPUTSUBMITIMAGE{
}
.INPUTSELECT{
	border: 1px solid #666;
	width: 90%;
}
.INPUTCHECKBOX{
}
.INPUTOPTION{
}
.INPUTTEXTAREA{
	border: 1px solid #666;
	width: 90%;
	background: transparent;
}

/*typo3 css styled content and image - - - - -*/

.csc-caption{
	font-size: 10px;
	color:#333;
}

/*mail form styles - - - - - - - - - - - - - - - */

/*table.csc-mailform tr td.csc-form-labelcell p.csc-form-label/req*/

/*all controls are styled with the default form styles you may set styles here to override defaults*/

fieldset legend{
	margin-left: 0 !important;
	margin-right: 0 !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	text-indent:0 !important;
}

table.csc-mailform{
	padding: 0;
	margin: 0;
	width: 100%;
	border-collapse: collapse;
	border: 0px none white;
}

table.csc-mailform td{
	border: 0px none white;
	vertical-align: top;
}

td.csc-form-labelcell{
	margin: 0 0 0 0;
	padding-top: 1px;
	padding-bottom: 1px;
	padding-left: 0px;
	padding-right: 3px;
}
td.csc-form-fieldcell{
	margin: 0 0 0 0;
	padding-top: 1px;
	padding-bottom: 1px;
	padding-left: 0px;
	letter-spacing:1px;
	font-weight:bold;
	color:#000000;
}
.csc-form-label{
	color: #000000;
}
.csc-form-label-req{
	font-weight: bold;
	color: #000000;
}
.csc-form-radio{
	font-size:12px;
	font-weight:normal;
	letter-spacing: 0;
	color: #000000;
}
td.csc-form-fieldcell INPUT.INPUTSUBMIT{
	margin-top:10px;
}


/* ##########################
** ### ext: jp_page_teaser ##
** ##########################
*/

/* reset content element paddings */
.content .tx-jppageteaser-pi1{
	margin: 0px 0px 0px 0px;
	clear: both;
}

.content-normal .tx-jppageteaser-pi1{
}

.content-normal-b .tx-jppageteaser-pi1{
}

.tx-jppageteaser-pi1-list, .tx-jppageteaser-pi1-list-1-column, .tx-jppageteaser-pi1-list-2-column, .tx-jppageteaser-pi1-list-3-column{
		width: 100%;
		/*
		padding: 0 1px 0 1px;
		margin: 0 -1px 0 -1px;
		*/
		overflow:hidden;
}

.tx-jppageteaser-pi1-list-entry-header {
	padding: 0px 0px 0px 0px !important; 
	margin: 0 0 0.3em 0 !important;	
}

.tx-jppageteaser-pi1 a img {
	margin: 0; padding: 0; 
}
.tx-jppageteaser-pi1 a:hover img {
	margin: 0; padding: 0;
	opacity: 0.8; 	
	-moz-opacity:0.8;
	-khtml-opacity: 0.8;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)"; 
	filter: alpha(opacity=80); 
}

.tx-jppageteaser-pi1-list-entry{
	overflow: hidden;
}

.tx-jppageteaser-pi1-list-entry-first{} 
.tx-jppageteaser-pi1-list-entry-last{} 
.tx-jppageteaser-pi1-list-entry-odd{}
.tx-jppageteaser-pi1-list-entry-even{}


.tx-jppageteaser-pi1-list-entry-description{}

.tx-jppageteaser-pi1-list-entry-link-item{font-weight: bold;}

/* clearer in content */
.tx-jppageteaser-pi1-list-floatcleaner{clear: both; height: 0px; overflow:hidden;}


/* total clearer for 2 and 3 col layouts */

.tx-jppageteaser-pi1-column-clearer{
	display:none; 
	visibility: hidden;
	height: 1px;
	color: transparent;
	background: transparent;
	border: 0px none white;
}

/* browsebox */
.tx-jppageteaser-pi1-browsebox {
	border-top: 3px solid #b1b1b1;
	padding: 9px 0px 9px 0px;
}

.tx-jppageteaser-pi1-browsebox-show-results {}
.tx-jppageteaser-pi1-browsebox-browse-links {}
.tx-jppageteaser-pi1-browsebox-show-results-number {}
.tx-jppageteaser-pi1-browsebox-disabled-link {}
.tx-jppageteaser-pi1-browsebox-inactive-link {}
.tx-jppageteaser-pi1-browsebox-active-link {}


/* image orientation */
.tx-jppageteaser-pi1-list-image-left .tx-jppageteaser-pi1-list-entry-image{
	float: left;
	margin: 5px 10px 10px 0px;
}

.tx-jppageteaser-pi1-list-image-right .tx-jppageteaser-pi1-list-entry-image{
	float: right;
	margin: 5px 0px 10px 10px;
}

/* 1 column */
.tx-jppageteaser-pi1-list-1-column .tx-jppageteaser-pi1-list-entry-content{
	padding: 0px 0px 0px 0px !important; 
}

/* 2 Columns*/
.tx-jppageteaser-pi1-list-2-column{
	margin: 0 0 0 0 !important;
	width: 100%;
}

.tx-jppageteaser-pi1-list-2-column .tx-jppageteaser-pi1-list-entry-content{
	/*min-height: 9em;*/
	clear: both;
}
.tx-jppageteaser-pi1-list-2-column .tx-jppageteaser-pi1-list-entry{
}
.tx-jppageteaser-pi1-list-2-column .tx-jppageteaser-pi1-list-entry-odd{
	float: left; overflow: hidden;
	width: 49.999%;
	clear: both;
}
.tx-jppageteaser-pi1-list-2-column .tx-jppageteaser-pi1-list-entry-even{
	float: right; overflow: hidden;
	width: 49.999%;
}

.tx-jppageteaser-pi1-list-2-column .tx-jppageteaser-pi1-list-entry-odd .tx-jppageteaser-pi1-list-entry-content{
	margin: 0 0 0 0;
	padding: 0px 18px 18px 0px; 
	clear: both;
}

.tx-jppageteaser-pi1-list-2-column .tx-jppageteaser-pi1-list-entry-even .tx-jppageteaser-pi1-list-entry-content{
	margin: 0 0 0 0;
	padding: 0px 0px 18px 18px; 
	clear: both;
}

.tx-jppageteaser-pi1-list-2-column hr.tx-jppageteaser-pi1-list-entry-even{
	display: block !important;
	clear: both;
}

/* 3 Columns */
.tx-jppageteaser-pi1-list-3-column {
	margin: 0 0 0 0 !important;
	width: 100%;
}

.tx-jppageteaser-pi1-list-3-column .tx-jppageteaser-pi1-list-entry{
	float: left; overflow: hidden;
	width: 33.333%;
	*width: 33.3%;
	/*clear: both;*/
}

.tx-jppageteaser-pi1-list-3-column .tx-jppageteaser-pi1-list-entry-content{
	/*min-height: 12em;*/
}


.tx-jppageteaser-pi1-list-3-column .entryone .tx-jppageteaser-pi1-list-entry-content{
	margin: 0 0 0 0;
	padding: 0px 18px 18px 0px; 
}

.tx-jppageteaser-pi1-list-3-column .entrytwo .tx-jppageteaser-pi1-list-entry-content{
	margin: 0 0 0 0;
	padding: 0px 9px 18px 9px; 
}

.tx-jppageteaser-pi1-list-3-column .entrythree .tx-jppageteaser-pi1-list-entry-content{
	margin: 0 0 0 0;
	padding: 0px 0px 18px 18px; 
}

.tx-jppageteaser-pi1-list-3-column .entryfour .tx-jppageteaser-pi1-list-entry-content{
	margin: 0 0 0 0;
	padding: 0px 18px 18px 0px; 
}

.tx-jppageteaser-pi1-list-3-column .entryfive .tx-jppageteaser-pi1-list-entry-content{
	margin: 0 0 0 0;
	padding: 0px 9px 18px 9px; 
}

.tx-jppageteaser-pi1-list-3-column .entrysix .tx-jppageteaser-pi1-list-entry-content{
	margin: 0 0 0 0;
	padding: 0px 0px 18px 18px; 
}

.tx-jppageteaser-pi1-list-3-column .tx-jppageteaser-pi1-list-entry-content{
	clear: both;
}

.tx-jppageteaser-pi1-list-3-column hr.entrythree, .tx-jppageteaser-pi1-list-3-column hr.entrysix{
	display: block !important;
	clear: both;
	height: 0px;
	margin: 0;
	padding: 0;
	overflow: hidden;
}


/* ul and ol in teasers */
.tx-jppageteaser-pi1-list-entry-content ul{
	margin-top: 5px;
	margin-bottom: 5px;
	margin-left: 15px !important;
}


/* css styled content overwrite */
dd.csc-textpic-caption{
	color: #999;
	font-size: 90% !important;
}

/* frames */
div.csc-frame{
}

div.csc-frame-frame1{
}

div.csc-frame-frame2{
}

/* rggooglemaps */
.tx-rggooglemap-pi1 .mapcat, .tx-rggooglemap-pi1 .infobox, .tx-rggooglemap-pi1 .coordinfo{
	display: none;
	visibility: hidden;
}

/* loginform */
.tx-felogin-pi1 h3{display: none;}

/* seo */
div#seo{
	padding: 18px 18px 0 18px;
	word-wrap: break-word;
}

div#seo h1, div#seo h2, div#seo h3, div#seo h4, div#seo h5{
	display: inline;
	word-wrap: break-word;
}
div#seo p{
	margin: 0;
	padding: 0;
	word-wrap: break-word;
}