/* 	www.personenschiffahrt.com */

/****************************************************************  all  */

html, body, span, a, table, td, form, input, textarea, h1, h2, h3, h4, p, ul, li, select, tt {
	margin: 0;
	padding: 0;
	font-family: georgia, serif;
	font-size: 11px;
}

body  {
   color: #333;
   background: #fff url(img/bg_body.jpg) no-repeat;
   background-position: 890px 0;
}

.hidden, .invisible {
	height: 0;
	width: 0;
	overflow: hidden;
	position: absolute;  /* for the benefit of IE5 Mac */
}

.clearit {
	clear: both;
}

img {
	border: 0;
}

a {
	outline: none;
}

/****************************************************************  typo */

#head h1 a {
	width: 151px;
	height: 119px;
	text-indent: -10000px;
	display: block;
	text-decoration: none;
	background: url(img/logo_soellner.gif) no-repeat;
}

#content_left h1  {
	width: 560px;
	height: 51px;
	background: url(img/headline_bg.gif) no-repeat 120px 0;
    font-size: 26px;
    color: #db012f;
    text-indent: 124px; }

#content_right h2  {
	width: 560px;
	height: 51px;
	background: url(img/headline_start.gif) no-repeat 120px 0;
	text-indent: -10000px; }

#content_left h2, #content_left .event h2  {
  	font-size: 14px;
	font-weight: bold;
	padding: 18px 0 5px 129px;
	color: #00509E;
	width: 560px; }

#content_left .event h2, #kontakt-fahrplan h2  {
  	font-size: 14px;
	font-weight: bold;
	padding: 0 0 5px 129px;
	color: #00509E;
	width: 560px; }

#kontakt-fahrplan h2  {
	padding: 15px 0 5px 0; }

/* h2.karte {  width: 196px; background: url(img/headline_karte.gif) no-repeat 29px 0; }
h2.zissel {  width: 196px; background: url(img/headline_zissel.gif) no-repeat 29px 0; }
h2.dampfer {  background: url(img/headline_dampfer.gif) no-repeat 120px 0; }
h2.route {  background: url(img/headline_route.gif) no-repeat 120px 0; }
h2.fahrplan {  background: url(img/headline_fahrplan.gif) no-repeat 120px 0; }
h2.bordkarten {  background: url(img/headline_bordkarten.gif) no-repeat 120px 0; }
h2.feste {  background: url(img/headline_feste.gif) no-repeat 120px 0; }
h2.kombuese {  background: url(img/headline_kombuese.gif) no-repeat 120px 0; }
h2.kontakt {  background: url(img/headline_kontakt.gif) no-repeat 120px 0; }
h2.presse {  background: url(img/headline_presse.gif) no-repeat 120px 0; }
h2.gutscheine {  background: url(img/headline_gutscheine.gif) no-repeat 120px 0; }
h2.impressum {  background: url(img/headline_impressum.gif) no-repeat 120px 0; }  */
#content_right h2.flaschenpost {  width: 196px; background: url(img/headline_flaschenpost.gif) no-repeat 29px 0; }
#content_right h2.logbuch {  width: 196px; background: url(img/headline_logbuch.gif) no-repeat 29px 0; }
#content_right h2.galerie {  width: 196px; background: url(img/headline_galerie.gif) no-repeat 29px 0; }
#content_right h2.logbuch-blick {  background: url(img/headline_logbuch_blick.gif) no-repeat 120px 0; }
#content_right h2.logbuch-eintrag {  background: url(img/headline_logbuch_eintrag.gif) no-repeat 120px 0; }
#content_right h2.logbuch-fehler {  background: url(img/headline_logbuch_fehler.gif) no-repeat 120px 0; }

h3 {
	font-size: 12px;
	font-weight: bold;
	padding: 18px 0 5px 129px;
	color: #333333;
}

#content_right h3 {
	font-size: 14px;
	font-weight: bold;
	padding: 18px 0 5px 29px;
	color: #00509E;
}

h4 {
	font-size: 12px;
	font-weight: bold;
	padding: 9px 0 5px 129px;
}

.gaestebuch-eintrag h4 {
	font-size: 11px;
	font-weight: normal;
	font-style: italic;  
	color: #333; 
	padding-top: 4px; 
}

p.fehler {
	color: #DB012F;
}

#content_left p, #content_left p.blue {
	width: 436px;
	line-height: 18px;
	padding-bottom: 12px;
	padding-left: 129px;
}

#content_left .empty {
	line-height: 18px;
	padding-bottom: 12px;
	padding-left: 129px;
    font-weight: bold;
}

.mod_eventlist .header {
	width: 436px;
	line-height: 18px;
	padding: 12px 0 20px 129px;
    font-weight: bold;
  	font-size: 14px;
	color: #00509E;
}

.mod_upcoming_events {
    padding: 0 0 20px 0;
}


#content_left p.blue {
	color: #00509E;
}

#content_right p {
	width: 170px;
	line-height: 14px;
	font-size: 10px;
	padding-bottom: 14px;
	padding-left: 29px;
}

#content_right img {
	padding: 0 7px 7px 0;
}

img.text {
	float: left; 
	padding: 4px 12px 0 0; }
	
img.text_right {
	float: right;
	padding: 4px 0 0 12px; }

a.arrow {
	display: block;
	padding: 0 0 0 20px;
	background: url(img/bg_arrow.gif) no-repeat;
	font-size: 10px;
}

.line {
	width: 73px;
	height: 19px;
	background: url(img/bg_line.gif) no-repeat;
	margin: 0 0 0 15px;
}

#jetztaber {
}

ul.footer_left {
	list-style-type: none;
	padding: 36px 0 0 129px; }
   
ul.footer_right {
	list-style-type: none;
	padding: 36px 0 0 0; }

ul.footer_left li {
	float: left;
	padding: 0 7px 0 0;
}

ul.footer_right li {
	float: left;
	padding: 0 7px 0 29px;
}

#head_quicknav ul {
	list-style-type: none;
}

#head_quicknav li {
	float: left;
	padding: 0 7px 0 0;
}

#content_left ul {
	list-style-type: none;
	padding: 9px 0 18px 0;
}

#content_left ul li {
	padding: 0 0 5px 139px;
	background: url(img/list_style_image.gif) no-repeat;
	line-height: 18px;
}


/****************************************************************  forms  */

input.norm {
	width: 260px;
	padding: 2px; 
	color: #DB012F; }
	
input.email {
	width: 130px;
	padding: 2px;
	margin: 0 3px 0 29px;
	color: #DB012F; }

.box-captcha {
    padding: 0 0 20px 100px;
}

.error {
    color: red;
    font-weight: bold;
}


.captcha {
	width: 50px;
	padding: 2px;
	margin: 0 3px 0 0;
	color: #DB012F; }

.gaestebuch-form, #kontakt-fahrplan {
	padding: 0 0 0 129px;
}

#kontakt-fahrplan p {
    padding: 0 0 12px 0;
}

.gaestebuch-form h3, #content_left .gaestebuch-form p  {
	padding-left: 0;
} 

.gaestebuch-form form {
	padding-top: 15px;
}

.gaestebuch-form .special {
	display: none;
}  

.gaestebuch-form label, label.mandatory {
	display: block;
	padding: 0 0 5px 0;
	float: left;
	width: 100px;
}

.gaestebuch-form .textinput, input.mandatory {
	margin: 0 0 20px 0;
	width: 300px;
	padding: 2px; 
}

.gaestebuch-form .textarea, .textarea {
	height: 150px;
	overflow: auto;
}

.gaestebuch-form .submitbutton, #kontakt-fahrplan .submitbutton {
	margin: -5px 0 0 100px;
}

.gaestebuch-form .actions {
	clear: both;
} 

.gaestebuch-form .checkbox {
	margin-bottom: 20px;
}

	
	
/****************************************************************  divs  */

#head {
	height: 398px;
	width: 950px;
	background: url(img/bg_head.gif) no-repeat; }

.head_foto {
	height: 333px;
	width: 512px;
	background: url(img/bg_head_start.jpg) no-repeat;
	float: left; }

.route {
	background: url(img/bg_head_spiekershausen.jpg)  no-repeat;	}
	
.fahrplan {
	background: url(img/bg_head_kassel.jpg)  no-repeat;	}

#head_middle {
	width: 151px;
	height: 398px;
	float: left; }

#head_logo {
	height: 119px;
	width: 151px;
}

#nav_mother {
	padding: 22px 0 0 0;
	color: #fff;
	height: 250px;
	width: 151px;
}

.mod_calendar {
	width: 198px;
	height: 136px;
	padding: 177px 0 0 31px;
	float: left; }
	
#content {
}

#head_quicknav {
	position: absolute;
	left: 129px;
	top: 340px;
	width: 270px;
	height: 20px;
	color: #fff;
	font-size: 10px; }
	
#content_left, #footer_left {
	width: 662px;
	float: left;
	background-color: white; }
	
#footer_left {
	background: #fff;
	background: url(img/line.gif) no-repeat 129px 28px;
	font-size: 10px; }
	 
#content_right, #footer_right {
	width: 228px;
	float: left;
	background: #fff url(img/bg_content_right.gif) no-repeat; }
	
#footer_right {
	background: #fff;
	background: url(img/line_small.gif) no-repeat 29px 28px; }
	
.left {
	width:120px; 
	float: left; 
	padding: 0 0 18px 129px; }
	
.right { 
	width:260px; 
	float: left;}

.gaestebuch-eintrag {
	background: url(img/line.gif) no-repeat 129px 0px;  
}

.mod_dlh_googlemaps {
    padding: 0 0 20px 130px;
}


/****************************************************************  nav  */

ul#nav {
	list-style: none;
	list-style-position: outside;
}

ul#nav li {
	width: 151px;
	height: 25px;
	text-align: center;
}

ul#nav a {
	display: block;
	width: 151px;
	height: 25px;
	text-decoration: none;
	color: #fff;
	text-align: center;
}

ul#nav a:hover, ul#nav a.act, li.active  {
	font-weight: bold;
}

/****************************************************************  links  */

a:link, a:visited { color: #343434; text-decoration: underline; }
a:focus, a:hover, a:active { color: #DB012F; text-decoration: underline; }

#head_quicknav ul a:link, #head_quicknav ul a:visited { font-size: 10px; color: #fff; text-decoration: none; }
#head_quicknav ul a:focus, #head_quicknav ul a:hover, #head_quicknav ul a:active {font-size: 10px; color: #fff; text-decoration: none; }

ul.footer_left a:link, 
ul.footer_right a:link, 
ul.footer_left a:visited, 
ul.footer_right a:visited,
p.oben a:link, 
p.oben a:visited  { font-size: 11px; color: #DB012F; text-decoration: none; }

ul.footer_left a:focus, 
ul.footer_left a:hover, 
ul.footer_left a:active, 
ul.footer_right a:focus, 
ul.footer_right a:hover, 
ul.footer_right a:active, 
p.oben a:focus, 
p.oben a:hover, 
p.oben a:active { font-size: 11px; color: #DB012F; text-decoration: none; }

#content_right a {
	font-size: 10px; }

#head_quicknav span.active {
   font-size: 10px;
   font-weight: bold;
}

#footer_left span.active {
    color:  #DB012F;
    font-weight: bold;
}


/**************************************************************** calendar */

table.minicalendar {
    border:0;
}
table.minicalendar td {
    padding: 3px 4px 3px 4px;
    text-align:center;
    background-color:#ffffff;
    border:0;}

table.minicalendar .days {
  	background-color: #fff;
	color:            #00509e;
	font-family:      verdana, sans-serif;
	font-size:        10px;
}

table.minicalendar td, table.minicalendar .active a {
	background-color: #fff;
	color:            #00509e;
	font-family:      verdana, sans-serif;
	font-size:        10px;
}

table.minicalendar .weekend {

}

table.minicalendar .today {
    background-color: #fff;
	color:            #db012f;
	font-family:      verdana, sans-serif;
	font-size:        10px;
	font-weight:      normal;
	font-style:       normal;
}

table.minicalendar .label {
  	background-color: #fff;
    color:            #00509e;
	font-family:      verdana, sans-serif;
	font-size:        11px;
	font-weight:      bold;
	font-style:       normal;
    text-decoration: none;
    padding: 4px;
}

table.minicalendar .head {
  	color:            #db012f;
	font-family: georgia, serif;
	font-size: 11px;
    padding: 0 0 3px 0;
}

table.minicalendar th.head a {
  	color:            #db012f;
	font-family: georgia, serif;
	font-size: 12px;
    font-weight:      bold;
    text-decoration: none;
    display: block;
}

table.minicalendar .current {
  	background-color: #fff;
	color:            #db012f;
	font-family:      georgia, serif;
	font-size:        11px;
	font-weight:      bold;
	font-style:       normal;
    text-decoration: none;
}




/**************************************************************** Kalender */

table.calendar{width:100%;border-top:1px solid #cccccc;border-left:1px solid #cccccc;}
table.calendar .head{padding-top:4px;padding-bottom:5px;text-align:center;background-color:#f6f6f6;border-right:1px solid #cccccc;border-bottom:1px solid #cccccc;}
table.calendar .current{background-color:#ffffcc;}
table.calendar .label{padding-top:3px;padding-bottom:4px;text-align:center;background-color:#bbbbbb;border-right:1px solid #cccccc;border-bottom:1px solid #cccccc;font-weight:bold;font-size:10px;color:#ffffff;}
table.calendar td{width:14%;height:72px;padding:1px;vertical-align:top;background-color:#ffffff;border-right:1px solid #cccccc;border-bottom:1px solid #cccccc;}
table.calendar td.weekend{background-color:#f6f6f6;}
table.calendar .today{background-color:#ffffcc;}
table.calendar .empty,table.calendar .empty .header{background-color:#f6f6f6;}
table.calendar td .header{padding-bottom:2px;background-color:#e0e0e0;font-size:10px;}
table.calendar td .event a{font-size:10px;}

	
/**************************************************************** lightbox */

#lightbox{
	position: absolute;
	top: 40px;
	left: 0;
	width: 100%;
	z-index: 100;
	text-align: center;
	line-height: 0;
	}

#lightbox a img{ border: none; }

#outerImageContainer{
	position: relative;
	background-color: #fff;
	width: 250px;
	height: 250px;
	margin: 0 auto;
	}

#imageContainer{
	padding: 10px;
	}

#loading{
	position: absolute;
	top: 40%;
	left: 0%;
	height: 25%;
	width: 100%;
	text-align: center;
	line-height: 0;
	}
#hoverNav{
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	z-index: 10;
	}
#imageContainer>#hoverNav{ left: 0;}
#hoverNav a{ outline: none;}

#prevLink, #nextLink{
	width: 49%;
	height: 100%;
	background: transparent url(img/blank.gif) no-repeat; /* Trick IE into showing hover */
	display: block;
	}
#prevLink { left: 0; float: left;}
#nextLink { right: 0; float: right;}
#prevLink:hover, #prevLink:visited:hover { background: url(img/prevlabel.gif) left 15% no-repeat; }
#nextLink:hover, #nextLink:visited:hover { background: url(img/nextlabel.gif) right 15% no-repeat; }


#imageDataContainer{
	font: 10px Verdana, Helvetica, sans-serif;
	background-color: #fff;
	margin: 0 auto;
	line-height: 1.4em;
	}

#imageData{
	padding:0 10px;
	}
#imageData #imageDetails{ width: 70%; float: left; text-align: left; }	
#imageData #caption{ font-weight: bold;	}
#imageData #numberDisplay{ display: block; clear: left; padding-bottom: 1.0em;	}			
#imageData #bottomNavClose{ width: 66px; float: right;  padding-bottom: 0.7em;	}	
		
#overlay{
	position: absolute;
	top: 0;
	left: 0;
	z-index: 90;
	width: 100%;
	height: 500px;
	background-color: #000;
	filter:alpha(opacity=60);
	-moz-opacity: 0.6;
	opacity: 0.6;
	}
	

.clearfix:after {
	content: "."; 
	display: block; 
	height: 0; 
	clear: both; 
	visibility: hidden;
	}

* html>body .clearfix {
	display: inline-block; 
	width: 100%;
	}

* html .clearfix {
	/* Hides from IE-mac \*/
	height: 1%;
	/* End hide from IE-mac */
	}	
			

