* {
  margin: 0;
  padding: 0;
  font-family: Arial, sans-serif;
}

html, body {
  height: 100%;
  width: 100%;
  background: #f60;
}

#vcenter {
  width:1px;
  height: 50%;
  margin-bottom: -279px;
  float: left;
}

#page {
  clear: left;
  width: 870px;
  height: 550px;
  margin: 0 auto;
  position: relative;
  background: #fff;
  padding: 4px;
  font-size: 70%;
}

#menu {
  height: 540px;
  width: 130px;
  border: 5px solid #ccc;
  border-right-width: 4px;
  float: left;
  position: relative;
}

#headline, 
#logo {
  height: 100px;
  width: 326px;
  border: 4px solid #ccc;
  border-top-width: 5px;
  border-left: 0 none;
  float: left;
  position: relative;
}

#logo {
  border-right-width: 5px;
  width: 396px;
  background: url(../files/logo.jpg) no-repeat center center;
}

#logo a {
  display: block;
  height: 100%;
  width: 100%;
  text-decoration: none;
}

#logo a span {
  display: none;
}

#text, 
#right,
#flash {
  height: 436px;
  width: 326px;
  border-right: 4px solid #ccc;
  border-bottom: 5px solid #ccc;
  float: left;
  position: relative;
}

#right,
#flash {
  border-right-width: 5px;
  width: 396px;
  height: 436px;
  display: block;
  vertical-align: middle;
  text-align: center;
  background: #fff;
}

/*#flash {
  padding: 4px;
  height: 428px;
}*/

#right #image {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
  width: 396px;
  height: 436px;
  background-repeat: no-repeat;
  background-position: center center;
}

.withdescription #image {
  height: 298px !important;
}

.withdescription #image img {
  max-height: 290px;
}

#right #description {
  border-top: 4px solid #ccc;
  padding: 4px; 
  height: 126px;
  text-align: left;
}

#right #description div {
  padding: 4px;
  background: #fc9;
  height: 118px;
  overflow: auto;
  line-height: 140%;
}

#flash object {
  display: block;
  margin: 4px;
  background: #fff;
}

#image * {
  vertical-align: middle;
}

#photographer {
  display: block;
  position: absolute;
  right: 0;
  bottom: 0;
  color: #333;
  font-size: 90%;
  height: auto !important;
}

#photographer a {
  text-decoration: none;
  display: block;
  padding: 5px 12px 10px 7px;
}

#photographer a.noLink {
  cursor: default;
}

#photographer span {
  display: none;
}

#photographer a.withAddress:hover {
  background: #fff;
  color: #000 !important;
  opacity: 0.9;
}

#photographer a.withAddress:hover span {
  display: block;
}

.protection {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: transparent;
}

#menu ul {
  position: absolute;
  bottom: 20px;
  left: 0;
  width: 100%;
}

#menu ul li {
  list-style-type: none;
  margin-bottom: 1px;
}

#menu ul li.blankline {
  margin-top: 1.4em;
}

#menu ul li a, 
#menu ul li span {
  display: block;
  color: #333;
  text-decoration: none;
  font-size: 120%;
  padding: 0px 10px 2px 10px;
  margin: 1px 0 0 0;
  font-weight: bold;
}

#menu ul li a:hover,
#menu ul li a.rootline,
#menu ul li span {
  background: #f60;
  color: #fff;
}

#menu ul ul {
  position: relative;
  bottom: 0;
}

#menu ul ul li {
  margin-bottom: 0;
}

#menu ul ul li a,
#menu ul ul li span {
  font-size: 100%;
  padding: 0 10px 1px 20px;
}

#menu ul ul li a:hover,
#menu ul ul li a.rootline,
#menu ul ul li span {
  background: #fc9;
  color: #333;
}

#headline div {
  position: absolute;
  bottom: 15px;
  margin-left: 15px;
}

#headline h1 {
  color: #f60;
  font-size: 200%;
  font-weight: bold;
  line-height: 150%;
}

#headline h2 {
  color: #f60;
  font-size: 140%;
  font-weight: normal;
}

#headline #icons {
  position: absolute;
  right: 4px;
  bottom: 4px;
  height: 17px;
}

#headline #icons a {
  display: block;
  float: left;
  height: 17px;
  width: 17px;
  margin-left: 4px;
  background: url(../files/print.jpg) left no-repeat;
}

#headline #icons a.deutsch {
  background-image: url(../files/de.jpg);
}

#headline #icons a.english {
  background-image: url(../files/en.jpg);
}

#headline #icons a:hover {
  background-position: right;
}

#headline #icons a span {
  display: none;
}

#text .section,
#text .news,
#text .press,
#text .books,
#text .guestbook,
#text .guestbookform,
#text .contactform,
#text .gallery {
  height: 432px;
  overflow: auto;
  margin-bottom: 4px;
  position: relative;
}

#text .section {
  height: 402px;
  overflow: auto;
  padding: 15px 15px 15px 15px;
}

#text .section p,
#text .section table {
  margin-bottom: 1em;
}

#text .section a img {
  border: 0 none;
}

#text .section table td {
  border: 0;
  vertical-align: top;
}

#text .section ul {
  margin-left: 1.5em;
  margin-bottom: 1em;
}

#text .section a,
#text .news a,
#text .guestbook li .head a,
#text .pagination a {
  color: #f60;
  text-decoration: underline;
}

#text .section a:hover,
#text .news a:hover,
#text .guestbook li .head a:hover,
#text .pagination a:hover {
  color: #333;
  text-decoration: underline;
}

#text .news li,
#text .newsarchive li,
#text .press li,
#text .books li,
#text .guestbook li,
#text .guestbookform li,
#text .contactform li,
#text .gallery li {
  list-style-type: none;
}

#text .gallery {
  overflow-y: scroll;
}

#text .gallery li {
  float: left;
}

#text .news li a,
#text .news li div,
#text .newsarchive li a,
#text .press li a,
#text .books li a,
#text .guestbook li,
#text .guestbookform li,
#text .contactform li,
#text .gallery li a {
  display: block;
  background-color: #ccc;
  color: #333;
  text-decoration: none;
  margin: 4px 4px 0 4px;
  padding: 4px;
  border: 0 none;
  position: relative;
}

#text .press li a {
  padding: 0 30px 0 0;
  border-right: 4px solid #fc9;
  background: #fc9 url(../files/pdf.gif) no-repeat right center;
}

#text .press li.link a {
  background-image: url(../files/link.gif);
}

#text .press li a span {
  background: #ccc;
}

#text .gallery li a {
  margin-right: 0;
  width: 90px;
  height: 100px;
  position: relative;
  background-position: center center;
  background-repeat: no-repeat;
}

#text .gallery li a img {
  border: 0 none;
  /*display: none;*/
}

#text .news li a:hover,
#text .press li a:hover span,
#text .books li a:hover,
#text .gallery li a:hover {
  background-color: #fc9;
}

#text .news li a,
#text .news li a:hover {
  text-decoration: none;
}

#text .news li span,
#text .newsarchive li a span,
#text .press li a span,
#text .books li a span,
#text .guestbook li span {
  display: block;
}

#text .news li .head,
#text .press li a .h1,
#text .books li a .h1,
#text .guestbook li .head {
  font-size: 120%;
  font-weight: bold;
  color: #f60;
}

#text .press li a .h1 {
  padding: 4px 4px 1px 4px;
}

#text .news li .date {
  color: #f60;
  font-weight: bold;
}

#text .news li .head {
  margin-bottom: 2px;
}

#text .guestbook li .head {
  font-size: 100%;
  margin-bottom: 2px;
}

#text .guestbook li.notice {
  background: #fc9;
  font-weight: bold;
}

#text .guestbook li .answer {
  background: #fc9;
  margin-top: 4px;
  padding: 4px;
}

#text .press li a .h2,
#text .books li a .h2 {
  margin: 1px 0 0 0;
}

#text .press li a .h2 {
  margin: 0;
  padding: 0 4px 4px 4px;
}

#text .guestbook .notice,
#text .gallery .notice,
#text .pagination {
  background: #fc9;
  margin: 4px;
  color: #333;
  padding: 2px 4px;
  font-weight: bold;
}

#text .pagination {
  color: #333;
  font-size: 120%;
  text-align: right;
  font-weight: normal;
}

#text .pagination a,
#text .pagination a:hover,
#text .pagination strong {
  font-weight: bold;
  text-decoration: none;
}

#text .guestbookform li,
#text .contactform li {
  height: 22px;
}

#text .guestbookform li:hover,
#text .guestbookform li.focus,
#text .contactform li:hover,
#text .contactform li.focus {
  background: #fc9;
}

#text .guestbookform li.error,
#text .contactform li.error {
  background: #f66;
}

#text .guestbookform li.error:hover,
#text>.guestbookform li.error.focus,
#text .contactform li.error:hover,
#text>.contactform li.error.focus {
  background: #f33;
}

#text .guestbookform .text {
  height: 284px;
}

#text .contactform .text {
  height: 250px;
}

#text .guestbookform label,
#text .contactform label {
  font-weight: bold;
  line-height: 20px;
  vertical-align: middle;
  display: block;
  float: left;
  height: 20px;
  width: 80px;
  color: #333;
  font-size: 110%;
}

#text .guestbookform label.optional {
  font-weight: normal;
}

#text .guestbookform .text label,
#text .contactform .text label {
  float: none;
  width: 200px;
}

#text .guestbookform input,
#text .contactform input {
  border: 1px solid #f60;
  background: #fff;
  display: block;
  float: right;
  width: 200px;
  height: 18px;
  background: #fff;
  padding: 1px 2px 1px 2px;
}

#text .guestbookform textarea,
#text .contactform textarea {
  border: 1px solid #f60;
  background: #fff;
  display: inline;
  width: 303px;
  height: 257px;
  background: #fff;
  padding: 2px;
}

#text .contactform textarea {
  height: 224px;
}

#text .guestbookform .submit input,
#text .contactform .submit input {
  float: none;
  margin: 0 auto;
  height: 22px;
  background: #f60;
  border-color: #fff;
  color: #fff;
  font-weight: bold;
}