body{
  font-family: Arial, "MS Trebuchet", sans-serif;
  font-size:80%;
  line-height:120%;
  padding:0;
  margin:0;
/*  background-color:#eee;*/
/*  color:#666;*/
}

body.IE6, body.IE7{
  font-size:75%;
}

a{
  text-decoration:undeline;
  color:#666;
}
a:hover{
  color:#9a3141;
}

a img{
  border:none;
}

/*	Tyopgrafische Leerstellen: */
span.mspace{
  font-size:135%;
  line-height:1px;
}
span.lspace{
  font-size:30%;
  line-height:1px;
}

#head{
  position:relative;
  height:130px;
  border-top:1px solid #ddd;
  z-index:1;
  margin:0;
  padding:0;
}
.IE6 #head{
  overflow: hidden;
  background-color:#9a3141;
}

#head_image{
  position:absolute;
  left:0;
  margin:0;
  width:56em;
  height:130px;
  background: white url('/layout_images/header/Startseite.jpg') no-repeat scroll right top;
  z-index:2;
}
.IE6 #head_image, .IE7 #head_image{ width:59em; }

#logo{
  position:absolute;
  left:0px;
  margin:45px 30px;
}

#kontakt{
  display:relative;
  background-color:#9a3141;
  margin:-3em 0 0 56em;
  padding:70px 0 38px 20px;
  min-width:17em;
  color:white;
}

.IE6 #kontakt, .IE7 #kontakt{
  padding-top:30px;
  padding-bottom:35px;
}

.IE6 #kontakt, .IE7 #kontakt{ margin-left:59em; }

.IE6 #kontakt{ width:17em; } /*für min-width*/ 


#kontakt p{
  margin:0;
  padding:0;
  font-size:90%;
  line-height:110%;
}

#kontakt a{
  color:white;
  text-decoration:underline;
}

#notenlinien{
  position:relative;
  width:56em;
  margin-top:-15px;
  background: transparent url('/images/notenlinien-oben.gif') repeat-x scroll 0 0;
  height:15px;
  z-index:10;
}

.IE6 #notenlinien, .IE7 #notenlinien{ width:59em; }

#navbar{
  position:relative;
  padding:0;
  min-width:72.5em; /*Damit die Navbar bis rechts geht, wenn man waagrecht scrollen muss*/
  z-index:10;
}

#navbar ul{
  list-style-type:none;
  line-height:20px;
  height:40px;
  margin:0;
  padding:0 0 0 60px;
  background: transparent url('/images/nav_bak.gif') repeat-x scroll 0px 0px;
}
#navbar ul li{
  display:inline;
  padding:0;
}
#navbar ul li a, #navbar ul li span{
  padding:3px 0.8em 0 0.8em;
  height:32px;
  text-transform: uppercase;
  display:block;
  float:left;
  color:white;
  text-decoration:none;
}
#navbar ul li a:hover, #navbar ul li span#current, #navbar ul ul li a.r_10, #navbar ul ul li a.r_20{
  background: transparent url('/images/notenlinien-unten.gif') repeat-x scroll left bottom;
}

#nav{
  float:left;
  margin:45px 25px 0 0;
  min-width:14em;
}

.IE6 #nav{ width:14em; }
.IE6 #nav, .IE7 #nav{ margin-top:32px; }

#nav ul{
  list-style-type:none;
  width:14em;
  padding:0;
  margin:0;
}
#nav ul ul{
  border-bottom:1px solid #666;        
}
#nav ul ul ul{
  border:none;
  list-style-type:none;
  margin:0 10px 0 20px;
  padding:0;
  width:10em;
}
#nav ul li{
  border-top:1px solid #666;
  padding:0;
  padding-left:20px;
}

#nav ul li a{
  text-decoration:none;  
}

#nav ul li li{
  border:none;
  padding-left:0px;
}

#nav span#current, #nav a.r_10{
  color:#9a3141;
}

#maincol{
  float:left;
  width:37em;
  margin:23px 25px 30px 0.7em;
}

.IE6 #maincol, .IE7 #maincol{ margin-top:13px;}

#maincol h1{ color: #9a3141; }
#maincol h2, #maincol h3{ color: #000; }
#maincol h1{ font-size:130%; margin:1.5em 0 1em 0; }
#maincol h2{ font-size:120%; margin:1.5em 0 1em 0; padding:0; }
#maincol h3{ font-size:100%; margin:1.5em 0 0 0; padding:0; }
#maincol p{ margin-top:0x; }

#maincol ul{ padding-left:1.5em; margin:1em 0; }
#maincol ul li{ list-style-image:url('/images/spiegelstrich.png');}

#sidecol{
  position:absolute;
  padding:0;
  margin:0 0 0 56em;
  top:156px;
  right:0;
  bottom:0;
  left:0;
/*  float:right;*/
  min-width:18.5em; /*Damit Head und Foot der Sidecol so breit ist, wie das Adressfeld*/
}

.IE6 #sidecol, .IE7 #sidecol{ margin-left: 59em; }

.IE6 #sidecol{ width: expression(document.body.offsetWidth - document.getElementById('sidecol').offsetLeft - 22); }

#sidecol_head{
  position:absolute;
  top:0;
  right:0;
  left:0;
  background-color:#eee;
  padding:5px 12px;
  height:16px;
}
.IE6 #sidecol_head{ width: expression(document.getElementById('sidecol').offsetWidth); }

.sidecol_image{
  margin-top:26px;
}

#footer{
  position:fixed;
  background-color:#9a3141;
  bottom:0;
  left:62.5em;
  right:0;
  color:white;
  padding:5px 2em;
  height:18px;
  font-size:90%;
  clear:both;
  min-width:16em;
}
#footer a{
  color:white;
}

.IE7 #footer{ left:65.5em; }

.IE6 #footer{
  position:absolute;
  top: expression(document.body.offsetHeight);
  margin-left:3em;
  margin-bottom:-5em;
  width: expression(document.body.offsetWidth - document.getElementById('content').offsetWidth - document.getElementById('nav').offsetWidth - 133);
}

#content{
}

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

tr{
}

td, th{
  border-top:1px solid #666;
  border-bottom:1px solid #666;
  text-align:left;
  padding:4px 10px;
  vertical-align:top;
}

th{
  padding:3px 10px 1px 10px;
  vertical-align:middle;
  background-color:#eee;
}

tr.termindaten td{ border-bottom:none; }
tr.terminbeschreibung td{ border-top:none; }

/*tr.termindaten td{ padding-bottom:0; }*/
tr.terminbeschreibung td{ padding-top:0; padding-bottom:0; }

table.form tr{
  border:none;
}


table.form tr td{
  padding:2px;
  border:none;
  vertical-align:middle;
}

table.form tr td.top{
  vertical-align:top;
  padding-top:8px;
}

#maincol table tr.header{
  border-top:1px solid #999;
}


#maincol table tr.header h3{
  margin:1.5em 0 1em 0;
}

input, select, textarea, option{
  font-family: Arial, "MS Trebuchet", sans-serif;
  font-size:100%;
  margin:2px;
}

table.form select{
  width:15em;
}

table.form input{
  margin:0;
}

table.form .dateselect select{
  width:4em;
}

form div.field, form div.field_with_errors{
  display: block;
	float:left;
	border:2px solid white;
}
form div.field_with_errors{ border:2px solid red; }

ul.error_msg{
  color:red; 
}

.blue{
  color:blue;
}

hr{
  border:none;
  border-top:1px solid #666;
  background-color:white;
  height:1px;
}
