* {
  margin: 0;
  padding: 0;
}

html {
  height: 100%;
  margin-bottom: 1px;
  font-size: 100%;
}

body {
  background: #ffffcc url(./img/background.png) repeat-x;
  font-family: Arial, sans-serif;
  font-size: 10px;
  color: #424242;
}

h1, h2, h3, h4, h5, h6 {
  font-family: Georgia, "Times New Roman", Times, serif;
  font-weight: normal;
  font-size: 1em;
}

img {
  border: 0 none;
}

/* Link Styles
---------------------------------------- */
a, a:link, a:visited {
  color: #003a81;
  text-decoration: underline;
}

a:hover {
  color: #38382e;
  text-decoration: none;
}

/* Main Blocks
---------------------------------------- */
#wrap {
  position: relative;
  margin: 0 auto;
  width: 1000px;
  clear: both;
}

#page-header {
  width: 100%;
  height: 307px;
  clear: both;
}

#globalnav {
  margin: 0 auto;
  width: 925px;
  height: 50px;
  clear: both;
  background: url(./img/bg_globalnav.png) no-repeat 0 0;
}

#page-body {
  margin-top: 2em;
  width: 100%;
  clear: both;
}

#page-footer {
  margin-top: 2em;
  padding-bottom: 2em;
  clear: both;
  text-align: center;
  font-size: 1em;
  font-weight: bold;
}

/* Page Header Styles
---------------------------------------- */
#stuehle {
  position: absolute;
  top: 0;
  left: 0;
  width: 544px;
  height: 307px;
  background: url(./img/stuehle.png) no-repeat left bottom;
}

#logo {
  position: absolute;
  top: 0;
  right: 160px;
  width: 322px;
  height: 234px;
}
#logo h1 {
  width: 322px;
  height: 234px;
  text-indent: -50000px;
}
#logo h1 a {
  display: block;
  width: 322px;
  height: 234px;
  background: url(./img/logo.png) no-repeat;
}

#bus {
  position: absolute;
  top: 240px;
  right: 50px;
  width: 145px;
  height: 86px;
  background: url(./img/bus.png) no-repeat;
}

/* Global Navigation Styles
---------------------------------------- */
#globalnav ul {
  list-style: none;
}
#globalnav li {
  float: left;
}
#globalnav li a {
  display: block;
  height: 50px;
  background-image: url(./img/bg_globalnav.png);
  background-repeat: no-repeat;
  text-indent: -5000px;
}

#globalnav li#gn-vereine a { width: 260px; }
#globalnav li#gn-gruppen a { width: 233px; }
#globalnav li#gn-gourmet a { width: 198px; }
#globalnav li#gn-busse a { width: 234px; }

#globalnav li#gn-vereine a { background-position: 0px 0; }
#globalnav li#gn-gruppen a { background-position: -260px 0; }
#globalnav li#gn-gourmet a { background-position: -493px 0; }
#globalnav li#gn-busse a { background-position: -691px 0; }

#globalnav li#gn-vereine a:hover { background-position: 0px -50px; }
#globalnav li#gn-gruppen a:hover { background-position: -260px -50px; }
#globalnav li#gn-gourmet a:hover { background-position: -493px -50px; }
#globalnav li#gn-busse a:hover { background-position: -691px -50px; }

/* Page Body Styles
---------------------------------------- */
#sidebar {
  margin-right: 28px;
  padding-right: 28px;
  float: left;
  width: 280px;
  border-right: 1px solid #d9cfa6;
}
#sidebar h4 {
  margin-bottom: 0.6em;
  padding-left: 72px;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 1.3em;
  font-weight: bold;
  text-transform: uppercase;
  color: #656554;
}
#sidebar p {
  margin-bottom: 0.8em;
  font-size: 1.1em;
  line-height: 1.3;
  font-weight: bold;
}

.sb-icon {
  margin-bottom: 0;
  padding: 12px 0 16px 72px;
  background-repeat: no-repeat;
  background-position: 28px 0px;
}
.icon-rent {
  background-image: url(./img/icon_rent.jpg);
}

#searchbox {
  margin-bottom: 2em;
  padding-left: 60px;
}
#searchbox input#q {
  padding: 9px 10px;
  width: 152px;
  height: 14px;
  background: url(./img/bg_searchbox.png) no-repeat;
  border: 0 none;
  font-size: 0.9em !important;
}
#searchbox input#searchbtn {
  margin-left: 6px;
  vertical-align: bottom;
}

.sidebar-element {
  padding-left: 60px;
}

#main {
  float: right;
  width: 660px;
}

#main h1 {
  font-size: 3.4em;
  font-style: italic;
  border-bottom: 2px solid #003a81;
  color: #003a81;
}
#main h2 {
  margin-bottom: 30px;
  font-size: 2em;
  font-weight: bold;
  color: #003a81;
}
#main h3 {
  margin-bottom: 6px;
  text-align: right;
  font-family: "Myriad Pro", Verdana, Arial, sans-serif;
  font-size: 1.4em;
  font-weight: bold;
  color: #003a81;
}

#main p.descr {
  margin: 1.2em 0 2em 0;
  font-size: 1.2em;
  line-height: 1.4;
}

.column1 {
  padding-right: 12px;
  width: 408px;
  float: left;
}
.column2 {
  width: 214px;
  float: right;
  background-color: #f4f4bf;
}

.eventbox {
  margin: 0 8px 8px 0;
  padding: 8px;
  float: left;
  width: 140px;
  height: 169px;
  background: url(./img/bg_eventbox.png) no-repeat;
  text-align: center;
}
.eventbox h3 {
  margin-bottom: 6px;
  font-weight: bold;
  font-size: 1.6em;
  text-transform: uppercase;
  text-align: left;
  color: #003a81;
  background-color: #ffffcc;
}
.eventbox h3 a {
  text-decoration: none !important;
  color: #003a81 !important;
}
.eventbox img {
  margin-bottom: 0.4em
}
.eventbox p {
  font-size: 1.1em;
  font-weight: normal;
  text-align: left;
}
.eventbox h3, .eventbox p {
  margin-left: 8px;
  margin-right: 8px;
}

/* Table Styles
---------------------------------------- */
table.content-table {
  font-size: 1.2em;
  font-family: Tahoma, Verdana, sans-serif;
  line-height: 1.4;
}
table.content-table td {
  padding-bottom: 12px;
}
table.content-table td.section {
  padding-right: 12px;
  font-weight: bold;
  white-space: nowrap;
  vertical-align: top;
}

.table-bg {
  padding-top: 38px;
  width: 550px;
  background: #e5d8aa url(./img/bg_table1.jpg) no-repeat;
}

.table-verein-bg {
  padding-top: 38px;
  width: 550px;
  background: #e5d8aa url(./img/bg_table2.jpg) no-repeat;
}

table.table1 {
  width: 100%;
  font-size: 1.1em;
  font-weight: bold;
  color: #3c3c3c;
}
table.table1 a {
  font-size: 1.1em;
  font-weight: bold;
  color: #3c3c3c;
  text-decoration:none;
}
table.table1 td {
  padding: 8px;
  border-bottom: 1px solid #d9d0b6;
  border-top: 1px solid #ffffcc;
}

.bg1 { background-color: #efe5c7; }
.bg2 { background-color: #f2ead2; }
.bg3 { background-color: #f5eedb; }

/* Misc. Styles
---------------------------------------- */
fieldset {
  border: 0 none;
}

.left {
  float: left;
  padding: 4px 4px 4px 0;
}

.big {
  font-size: 1.6em !important;
  font-weight: normal !important;
  font-family: Georgia, "Times New Roman", Times, serif;
  color: #003a81;
}
.big strong {
  font-size: 0.8em;
  color: #656554;
}
h3.detail-head, h3.detail-head span {
  display: block;
  width: 214px;
  height: 55px;
}
h3.detail-head span {
  background: url(./img/map_photo_head.jpg) no-repeat;
}
.reise-foto, .reise-karte {
  margin-bottom: 12px;
  text-align: center;
}
.reise-karte {
  position: relative;
}
.vergroessern {
  position: absolute;
  right: 12px;
  bottom: 12px;
  width: 35px;
  height: 35px;
  background: url(./img/vergroessern.png) no-repeat;
}

/* Tweaks
---------------------------------------- */
*:focus {
  outline: none;
}

/* Nice method for clearing floated blocks without having to insert any extra markup (like spacer above)
   From http://www.positioniseverything.net/easyclearing.html */
#page-body:after, #globalnav ul:after, .sidebar-element:after {
  content: "."; 
  display: block; 
  height: 0; 
  clear: both; 
  visibility: hidden;
}