/* pt-sans-regular - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/pt-sans-v17-latin-regular.eot');
  src: local(''), url('../fonts/pt-sans-v17-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('../fonts/pt-sans-v17-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */ url('../fonts/pt-sans-v17-latin-regular.woff') format('woff'), /* Modern Browsers */ url('../fonts/pt-sans-v17-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */ url('../fonts/pt-sans-v17-latin-regular.svg#PTSans') format('svg');
  
  /* IE9 Compat Modes */
  /* Legacy iOS */
}
/* pt-sans-700 - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/pt-sans-v17-latin-700.eot');
  src: local(''), url('../fonts/pt-sans-v17-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('../fonts/pt-sans-v17-latin-700.woff2') format('woff2'), /* Super Modern Browsers */ url('../fonts/pt-sans-v17-latin-700.woff') format('woff'), /* Modern Browsers */ url('../fonts/pt-sans-v17-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */ url('../fonts/pt-sans-v17-latin-700.svg#PTSans') format('svg');
  
  /* IE9 Compat Modes */
  /* Legacy iOS */
}
/* ................................................................. Vars */
.rounded2 {
  border-radius: 2px;
}
.toprounded {
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}
.shade {
  background-color: rgba(0, 0, 0, 0.1);
}
.overlay {
  background-color: rgba(255, 255, 255, 0.9);
}
.stdfont {
  font-family: 'PT Sans', helvetica, arial, sans-serif;
}
.awesome {
  fomt-family: FontAwesome;
}
.dev {
  border: 1px solid red;
}
/* ................................................................. reset'em all */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  border: none;
  outline: none;
  text-decoration: none;
  text-align: left;
  vertical-align: baseline;
  font-style: normal;
}
/* ................................................................. Basics */
body {
  position: relative;
  background-color: #fff;
  background-image: url(../grafik/back.gif);
  background-position: center;
  background-repeat: repeat-y;
  color: #004494;
  font-family: 'PT Sans', helvetica, arial, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 16px;
  text-align: center;
}
b,
strong {
  font-weight: 700;
}
em {
  font-style: italic;
}
hr {
  margin: 0 0 -1px 0;
  height: 1px;
  border: none;
  visibility: hidden;
  clear: both;
}
/* ................................................................. Links */
a {
  text-decoration: none;
  transition: text-decoration 0.7s;
}
a:hover {
  text-decoration: underline;
  transition: text-decoration 0.3s;
}
/* ................................................................. Aufbau */
#wrapper {
  margin: 0 auto;
  max-width: 1290px;
  background: #FFFFFF;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.5);
  text-align: left;
}
#page {
  position: relative;
  margin: 0 auto;
  max-width: 1080px;
  width: 100%;
}
/* ................................................................. Utility */
#utnav {
  padding: 10px 0 0 0;
  text-align: right;
}
#utnav h2 {
  display: none;
}
#utnav ul {
  list-style-type: none;
  text-align: right;
}
#utnav li {
  display: inline-block;
  margin: 0 12px 0 0;
  text-align: right;
}
#utnav li#page1058 {
  display: none;
}
#utnav li:last-child {
  margin-right: 0;
}
#utnav a {
  color: #009036;
}
#utnav .active a,
#utnav .activeParent a {
  color: #e2001a;
  text-decoration: none;
  background: none;
}
.scrolled #utnav {
  border-bottom: 20px solid #fff;
}
.tpl_suche #utnav li#page1058 {
  display: inline-block;
}
/* ................................................................. Header */
#utilitywrapper {
  position: relative;
  width: 1080px;
}
#utility {
  position: fixed;
  z-index: 100;
  width: 100%;
  max-width: 1080px;
  background-color: #fff;
  opacity: .97;
}
.scrolled #utility {
  border-bottom: 1px solid #cfcfcf;
}
header {
  margin: 0 0 6em 0;
}
#logo {
  position: fixed;
  z-index: 110;
  margin-top: -140px;
  width: 260px;
  height: 260px;
  transition: height 0.4s, width 0.4s, margin-top 0.4s;
  background-size: cover;
}
#logo span {
  display: inline-block;
  text-indent: -10000000px;
}
#logo a {
  display: block;
  width: 260px;
  height: 260px;
}
.scrolled #logo {
  margin-top: -110px;
  height: 80px;
  width: 80px;
  transition: height 0.4s, width 0.4s, margin-top 0.4s;
}
.scrolled #logo a {
  margin-top: -110px;
  height: 190px;
  width: 80px;
  transition: height 0.4s, width 0.4s, margin-top 0.4s;
}
/* ................................................................. Hauptnavi */
#mainnav {
  position: relative;
  z-index: 5;
  margin-top: 110px;
  width: 100%;
  height: 239px;
  text-align: right;
}
#mainnav h2 {
  display: none;
}
#mainnav > ul {
  display: inline-block;
  width: 324px;
  list-style-type: none;
}
#mainnav > ul > li {
  position: relative;
}
#mainnav > ul > li > a {
  display: block;
  margin: 1px 0 0 0;
  padding: 22px 0 0 10px;
  height: 59px;
  overflow: hidden;
  background-color: rgba(255, 255, 255, 0.9);
  color: #009036;
  font-size: 1.75em;
  text-transform: uppercase;
  font-weight: bold;
  transition: color 0.7s, background-color 0.7s;
}
#mainnav > ul > li > a:hover {
  text-decoration: none;
  color: #e2001a;
  background-color: rgba(255, 255, 255, 0.75);
  transition: color 0.3s, background-color 0.2s;
}
#mainnav > ul > li .fa {
  display: none;
}
#mainnav > ul > li:first-child a {
  margin-top: 0;
}
#mainnav > ul > li.active > a,
#mainnav > ul > li.activeparent > a {
  text-decoration: none;
  color: #e2001a;
  background-color: rgba(255, 255, 255, 0.75);
}
#mainnav > ul > li .subnav {
  display: none;
  position: absolute;
  top: 0;
  right: 324px;
  list-style-type: none;
}
#mainnav > ul > li:hover .subnav {
  display: block;
}
#mainnav > ul > li:last-child .subnav {
  top: auto;
  bottom: 0;
}
#mainnav > ul > li .subnav li a {
  display: block;
  margin: 1px 0 0 0;
  padding: 4px 10px;
  background-color: rgba(255, 255, 255, 0.75);
  color: #009036;
  font-size: 1em;
  text-align: right;
  font-weight: bold;
  transition: color 0.7s, background-color 0.7s;
}
#mainnav > ul > li .subnav li a:hover,
#mainnav > ul > li .subnav li.active a {
  transition: color 0.7s, background-color 0.2s;
  background-color: rgba(255, 255, 255, 0.9);
  color: #e2001a;
  text-decoration: none;
}
#mainnav > ul > li .subnav li:first-child a {
  margin-top: 0;
}
/* ................................................................. Footer */
footer {
  padding: 10px;
  background-color: #eeeeee;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  font-size: .875em;
}
footer #footerNav ul {
  list-style-type: none;
  text-align: right;
}
footer #footerNav li {
  display: inline-block;
  margin: 0 0 0 12px;
  text-align: right;
}
footer #footerNav li:first-child {
  margin-left: 0;
}
footer #footerNav a {
  color: #009036;
}
footer #footerNav .active a {
  color: #e2001a;
}
.footerAddress {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid #fff;
  text-align: center;
}
.footerAddress span {
  display: inline-block;
  text-align: center;
}
.footerAddress span:after {
  content: '•';
  display: inline-block;
  padding: 0 5px;
}
.footerAddress .postal-code:after,
.footerAddress span:last-child:after {
  display: none;
}
.footerAddress a {
  color: #009036;
}
.footerAddress .active a {
  color: #e2001a;
}
#toTop {
  position: fixed;
  bottom: 80px;
  right: 30px;
  padding: 15px;
  background-color: rgba(0, 0, 0, 0.1);
  border-radius: 50%;
  transform: scale(0);
  transition: transform .3s;
  cursor: pointer;
}
#toTop.scrollVis {
  transform: scale(1);
}
#breadcrump {
  margin: 6em 6em 5px 10px;
  color: #004494;
  font-size: .875em;
}
#breadcrump ol {
  display: inline-block;
  list-style-type: none;
}
#breadcrump li {
  display: inline-block;
}
#breadcrump li:after {
  display: inline-block;
  padding: 0 4px;
  content: '\f054';
  font-family: FontAwesome;
  font-size: 0.625em;
}
#breadcrump li:last-child:after {
  display: none;
}
#breadcrump a {
  color: #009036;
}
#breadcrump:before {
  content: 'Sie sind hier: ';
}
.tpl_404 #breadcrump:before,
.tpl_home #breadcrump:before {
  display: none;
}
/* ................................................................. Content */
.entry {
  margin: 0 54px 0 0;
  width: 702px;
  overflow: hidden;
  float: left;
  line-height: 1.375em;
  /* Tabellen */
  /* Bilder */
  /* Links */
  /* Adresse auf der Kontaktseite */
}
.entry .pageHl {
  margin: 0 0 .5em 0;
  padding: 0 0 .5em 0;
  border-bottom: 1px solid #eeeeee;
  text-align: center;
  font-size: 1.5em;
  font-weight: 400;
}
.entry p,
.entry ul,
.entry ol,
.entry blockquote {
  margin: 0 0 1em 0;
}
.entry h3 {
  margin: 2em 0 3px 0;
  font-size: 1.25em;
  font-weight: 400;
}
.entry h4 {
  font-size: 1em;
  font-weight: 700;
}
.entry ul,
.entry ol {
  padding: 0 0 0 22px;
}
.entry ul.wide li,
.entry ol.wide li {
  margin: 0 0 1em 0;
}
.entry blockquote {
  position: relative;
  padding: 10px 10px 10px 50px;
  background-color: #eeeeee;
  font-style: italic !important;
  border-top-right-radius: 10px;
}
.entry blockquote p {
  margin-bottom: 0;
}
.entry blockquote * {
  font-style: italic !important;
}
.entry blockquote:before {
  position: absolute;
  top: 10px;
  left: 4px;
  content: '\f10e';
  font-family: FontAwesome;
  font-size: 2em;
  color: #cfcfcf;
}
.entry table {
  width: 100%;
  max-width: 100%;
  border-collapse: collapse;
}
.entry .tableinfo {
  display: none;
}
.entry thead th {
  padding: 0px 4px;
  background-color: #004494;
  color: #fff;
  font-weight: 700;
  border-right: 1px solid #fff;
  vertical-align: baseline;
}
.entry thead th:last-child {
  border-right: none;
}
.entry tbody tr td {
  padding: 2px 4px;
  border-right: 1px solid #83bcff;
  border-bottom: 1px solid #83bcff;
  vertical-align: top;
}
.entry tbody tr:last-child td {
  border-bottom: none;
}
.entry tbody tr td:last-child {
  border-right: none;
}
.entry tbody tr:nth-child(odd) td {
  background-color: #e9f3ff;
}
.entry tbody tr:nth-child(odd):hover td {
  background-color: #c7e1ff;
}
.entry tbody tr:nth-child(even):hover td {
  background-color: #eeeeee;
}
.entry img {
  max-width: 100%;
  height: auto;
}
.entry img.align_right {
  margin: 0 0 20px 20px;
  max-width: 50%;
  height: auto;
  float: right;
}
.entry img.align_left {
  margin: 0 20px 20px 0;
  max-width: 50%;
  height: auto;
  float: left;
}
.entry img:align_center {
  display: block;
  margin: 0 auto 20px auto;
}
.entry figure {
  background-color: #e9e9e9;
  line-height: 1em;
}
.entry figure.align_right {
  margin: 0 0 20px 20px;
  max-width: 50%;
  height: auto;
  float: right;
}
.entry figure.align_left {
  margin: 0 20px 20px 0;
  max-width: 50%;
  height: auto;
  float: left;
}
.entry figcaption {
  padding: 2px;
  font-size: .76470em;
}
.entry a {
  color: #009036;
  text-decoration: underline;
}
.entry a:hover {
  text-decoration: none;
  background-color: rgba(0, 0, 0, 0.1);
  border-radius: 1px;
}
.entry a:before {
  position: relative;
  bottom: 2px;
  content: '\f061';
  font-family: FontAwesome;
  display: inline-block;
  padding: 0 2px 0 0;
  font-size: .5em;
}
.entry a.extern:before {
  display: none;
}
.entry a.extern:after {
  position: relative;
  bottom: 6px;
  content: '\f061';
  font-family: FontAwesome;
  display: inline-block;
  padding: 0 0 0 2px;
  font-size: .5em;
  transform: rotate(-45deg);
}
.entry address {
  margin: 0 0 2em 0;
}
.entry address span {
  display: block;
}
.entry address .postal-code,
.entry address .locality {
  display: inline-block;
}
.entry address .fn {
  font-weight: 700;
}
.entry address .tel {
  margin-top: 6px;
}
.entry address a:before {
  content: '\f003';
}
.entry #headerImg {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 0 2em 0;
  width: 702px;
  height: 400px;
  border: 1px solid #cfcfcf;
  background-image: url(../grafik/mappreview.jpg);
  background-repeat: no-repeat;
  background-size: cover;
}
.entry #mapWarning {
  width: 80%;
  margin: 0 auto;
  padding: 10px;
  text-align: center;
  font-size: 14px;
  line-height: 18px;
  background-color: rgba(255, 255, 255, 0.9);
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.2);
  border-radius: 3px;
}
.entry #mapAccept {
  display: inline-block;
  margin: 10px auto ;
  padding: 10px 20px;
  background-color: #eeeeee;
  color: #004494;
  border: 1px solid #004494;
  border-radius: 4px;
  transition: all .3s;
  cursor: pointer;
}
.entry #mapAccept:hover {
  background-color: #004494;
  color: #eeeeee;
}
/* Ende .entry … */
.entrytags,
.entrytermine,
.entrysuche,
.entryblog,
.blogentry {
  float: none;
  width: 100%;
}
/* Links: Ausnahmen */
#shares a:before,
#shares a:after,
.imgLink:before,
.imgLink:after,
.suche a:after,
.suche a:before,
#txtTeaserNav a:before,
#terminListe a:before,
.blogEntries a:before,
#searchResults a:before,
figure a:before {
  display: none !important;
}
#shares a:hover,
#shares a:hover,
.imgLink:hover,
.imgLink:hover {
  background: none !important;
}
/* Bildergalerien */
#gallery {
  padding: 0;
  list-style-type: none;
  line-height: 0;
  text-align: center;
}
#gallery li {
  display: inline-block;
  margin: 10px;
}
#gallery img {
  position: relative;
  z-index: 5;
  border: 1px solid transparent;
  transition: border-color 0.7s;
  width: 200px;
  height: 133px;
}
#gallery img:hover {
  border: 1px solid #333333;
  transition: border-color 0.3s;
}
#gallery a {
  transition: opacity .8s;
}
#gallery a:hover {
  opacity: .8;
  transition: opacity .3s;
}
/* Galerien-Uebersicht */
#galleryList {
  padding: 0 !important;
  list-style-type: none;
}
#galleryList li {
  margin: 0 0 4em 0;
}
#galleryList h2 {
  margin: 0 0 2px 0;
  padding: 0 0 2px 0;
  border-bottom: 1px dotted #cfcfcf;
  font-weight: 400;
  font-size: 1em;
}
#galleryList h2 span {
  font-size: .75em;
  color: #cfcfcf;
}
#galleryList #gallery {
  text-align: left;
}
#galleryList #gallery li {
  margin: 3px;
}
#galleryList p {
  font-size: .75em;
  line-height: 1.4em;
}
.pagination ul {
  padding: 2px;
  background-color: #eeeeee;
  list-style-type: none;
  border-radius: 2px;
}
.pagination li {
  display: inline-block;
  width: 20px;
  text-align: center;
}
.pagination .MarkupPagerNavOn a {
  color: #fff;
}
.pagination a {
  display: block;
  width: 20px;
  text-align: center;
  text-decoration: none;
}
.pagination a:before {
  display: none;
}
/* iFrames */
.entry iframe {
  max-width: 100%;
}
/* Share'n'Care */
#shares {
  margin: 1em 0 1em 0;
  padding: 1em 0 1em 0;
  border-top: 1px solid #e9e9e9;
  border-bottom: 1px solid #e9e9e9;
}
#shares h3 {
  margin-top: 0;
  font-size: .875em;
  color: #004494;
  font-weight: 600;
}
#shares ol {
  margin: 0;
  padding: 0;
  list-style-type: none;
  font-size: 1.8em;
}
#shares li {
  margin: 0 10px 0 0;
  display: inline-block;
}
#shares li span {
  display: none;
}
#shares a {
  color: #009036;
  transition: color .2s;
  opacity: 1;
}
#shares a:hover {
  color: #e2001a;
}
/* Teaser für Kind-Seiten */
#txtTeaserNav {
  margin-top: 2em;
  padding-top: 2em;
  border-top: 1px solid #eeeeee;
  font-size: .875em;
  line-height: 1.35714em;
}
#txtTeaserNav h2 {
  margin: 0 0 4px 0;
  font-size: 1em;
  font-weight: 700;
}
#txtTeaserNav h3 {
  margin: 0 0 3px 0;
  font-size: 1em;
  font-weight: 700;
}
#txtTeaserNav ol {
  padding: 0;
  list-style-type: none;
}
#txtTeaserNav li {
  display: inline-block;
}
#txtTeaserNav li:after {
  display: inline-block;
  padding: 0 5px;
  content: '•';
}
#txtTeaserNav li:last-child:after {
  display: none;
}
#txtTeaserNav li.active a {
  color: #e2001a;
  text-decoration: none;
  background: none;
}
#txtTeaserNav.lrg li {
  display: block;
  margin: 0 0 2em 0;
}
#txtTeaserNav.lrg li:after {
  display: none;
}
#txtTeaserNav.lrg li.hasIcon {
  position: relative;
  padding: 0 0 0 40px;
}
#txtTeaserNav.lrg li.hasIcon .fa {
  position: absolute;
  left: 0;
  top: 0;
  width: 30px;
  font-size: 30px;
  color: #cfcfcf;
}
#txtTeaserNav.lrg h3 a {
  text-decoration: none;
}
/* ................................................................. Blogartikel */
.blogentry {
  margin: 0 auto;
  max-width: 800px;
}
.blogentry .back {
  font-size: .875em;
}
.blogentry .back a {
  text-decoration: none;
  background: none;
}
.blogentry .back a:hover {
  text-decoration: underline;
}
.blogentry .back a:before {
  content: '\f060';
}
/* ................................................................. Sidebar */
#sidebar {
  position: relative;
  float: left;
  margin: 0;
  width: 324px;
}
#sidebar nav,
#sidebar section {
  margin: 0 0 4em 0;
}
#sidebar h2 {
  padding: 3px 10px;
  font-size: 1em;
  line-height: 1.375em;
  color: #fcecac;
  background-color: #004494;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}
#sidebar #subnav h2 {
  position: relative;
  background-color: #009036;
}
#sidebar #subnav h2:after {
  position: absolute;
  right: 0;
  bottom: 24px;
  display: inline-block;
  content: ' ';
  background-image: url(../grafik/silgreen.png);
  width: 100px;
  height: 65px;
}
#sidebar p {
  padding: 10px;
  line-height: 1.3em;
  background-color: #eeeeee;
}
#sidebar ol,
#sidebar ul {
  padding: 10px;
  list-style-type: none;
  background-color: #eeeeee;
}
#sidebar ol li ol,
#sidebar ul li ul {
  padding-bottom: 0;
  padding-right: 0;
}
#sidebar li {
  margin: 0 0 .5em 0;
  padding: 0 0 .5em 20px;
  border-bottom: 2px solid #fff;
}
#sidebar li.parent {
  padding-left: 0;
}
#sidebar li:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}
#sidebar h3 {
  font-size: 1em;
  font-weight: 700;
}
#sidebar h3 a {
  color: #004494;
}
#sidebar h3 a:hover {
  text-decoration: none;
}
#sidebar a {
  color: #009036;
  text-decoration: none;
  transition: color .5s;
}
#sidebar a:hover {
  color: #e2001a;
  transition: color .3s;
}
#sidebar .active > a {
  color: #e2001a;
  cursor: default;
}
#sidebar .activeParent > a {
  color: #e2001a;
}
#sidebar #subnav .fa {
  position: relative;
  bottom: 2px;
  display: inline-block;
  padding: 0 4px 0 0;
  font-size: .5em;
}
/* ................................................................. Startseite */
#teaser {
  margin: 0 5% 3em 0;
  width: 65%;
  float: left;
}
#teaser .teaser {
  margin: 0 7.71428% 3em 0;
  width: 46.14285%;
  overflow: hidden;
  float: left;
  line-height: 1.4em;
}
#teaser .teaser h2 {
  padding: 3px 10px;
  color: #fcecac;
  background-color: #009036;
  font-size: 1em;
  line-height: 1.375em;
  font-weight: 700;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}
#teaser .teaser h2 a {
  color: #fcecac;
}
#teaser .teaser img {
  margin: 0 0 10px 0;
  width: 325px;
  max-width: 100%;
  height: auto;
  max-height: 200px;
  opacity: 1;
  transition: opacity .7s;
}
#teaser .teaser img:hover {
  opacity: 0.8;
  transition: opacity .2s;
}
#teaser .teaser .noImg {
  display: block;
  margin: 0 0 10px 0;
  width: 323px;
  height: 200px;
  background-image: linear-gradient(bottom, #b3ada3 0%, #ffffff 56%);
  background-image: -o-linear-gradient(bottom, #b3ada3 0%, #ffffff 56%);
  background-image: -moz-linear-gradient(bottom, #b3ada3 0%, #ffffff 56%);
  background-image: -webkit-linear-gradient(bottom, #b3ada3 0%, #ffffff 56%);
  background-image: -ms-linear-gradient(bottom, #b3ada3 0%, #ffffff 56%);
}
#teaser .teaser .readOn {
  margin: 1em 0 0 0;
}
#teaser .teaser .readOn a {
  color: #009036;
}
#teaser .teaser .readOn a:after {
  display: inline-block;
  padding: 0 0 0 4px;
  content: '\f054';
  font-family: FontAwesome;
  font-size: .625em;
}
#teaser .teaser:nth-child(even) {
  margin-right: 0;
}
#termine {
  margin: 0 0 3em 0;
  width: 30%;
  float: left;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}
#termine h1 {
  position: relative;
  margin: 0 0 1em 0;
  padding: 3px 10px;
  background-color: #e2001a;
  color: #fcecac;
  font-weight: 700;
  font-size: 1em;
  line-height: 1.375em;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}
#termine h1:after {
  position: absolute;
  right: 0;
  bottom: 24px;
  display: inline-block;
  content: ' ';
  background-image: url(../grafik/silred.png);
  width: 100px;
  height: 65px;
}
#termine ol {
  position: relative;
  z-index: 5;
  list-style-type: none;
}
#termine li {
  position: relative;
  margin: 0 0 1em 0;
  padding: 0 0 1em 0;
  border-bottom: 1px solid #cfcfcf;
  line-height: 2em;
}
#termine li.subscribe {
  margin-top: -1em;
  padding-top: 1em;
  border-bottom: none;
  border-top: 2px solid #cfcfcf;
}
#termine dt {
  font-weight: 700;
}
#termine dt .fa {
  color: #999999;
  font-size: 1.3em;
}
#termine dt a {
  color: #004494;
  text-decoration: none;
}
#termine span {
  opacity: 0;
  position: absolute;
  z-index: 10;
  padding: 6px;
  border: 1px solid #eeeeee;
  border-radius: 3px;
  box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
  background-color: #fff;
  color: #004494;
  font-family: 'PT Sans', helvetica, arial, sans-serif;
  pointer-events: none;
  transition: opacity .2s;
  font-size: .67307em;
}
#termine dd .fa {
  color: #999999;
  cursor: help;
  font-size: 1.3em;
}
#termine dd:hover span {
  opacity: 1;
  pointer-events: all;
}
#termine small.info {
  position: relative;
  z-index: 10;
  display: block;
  margin: 0 0 2em 0;
  padding: 7px;
  background-color: #eeeeee;
  text-align: center;
  font-size: .75em;
}
#termine small.info:before {
  position: absolute;
  top: -5px;
  left: -5px;
  content: '\f06a';
  font-family: FontAwesome;
  font-size: 2em;
}
#termine .readOn {
  margin: 1em 0 0 0;
}
#termine .readOn a {
  color: #009036;
}
#termine .readOn a:after {
  display: inline-block;
  padding: 0 0 0 4px;
  content: '\f054';
  font-family: FontAwesome;
  font-size: .625em;
}
/* ................................................................. Suchergebnisse */
#searchResults {
  list-style-type: none;
  padding-left: 0;
}
#searchResults li {
  margin: 0 0 2em 0;
  padding: 0 0 2em 0;
  border-bottom: 1px solid #e9e9e9;
}
#searchResults h2 {
  font-size: 1.29411em;
  line-height: 1.25em;
}
#searchResults li p {
  margin-bottom: 0;
  font-size: .82352em;
}
#searchResults .blogprefix:after {
  position: relative;
  bottom: 2px;
  display: inline-block;
  padding: 0 5px;
  content: '\f054';
  font-family: FontAwesome;
  font-size: .5em;
}
/* ................................................................. Such-Formular */
#searchForm {
  margin: 0 0 2em 0;
  padding: 0 0 2em 0;
  border-bottom: 1px solid #e9e9e9;
}
#searchFormUtility {
  display: inline-block;
}
#searchFormUtility input[type="text"] {
  width: 140px;
  transition: width .7s;
}
#searchFormUtility input[type="text"]:focus {
  width: 220px;
  transition: width .3s;
}
input[type="text"] {
  padding: 6px;
  width: 80%;
  border: 0px;
  font-size: 13px;
  font-weight: normal;
  font-family: helvetica, arial, sans-serif;
  line-height: 1.2em;
  background-color: #eeeeee;
  border-bottom: 1px solid #fff;
  border-radius: 2px;
  box-sizing: border-box;
  color: #000000;
}
input[type="submit"],
button[type="submit"] {
  cursor: pointer;
  background: #009036;
  border: none;
  display: inline-block;
  color: #FFFFFF;
  line-height: 1;
  text-align: center;
  padding: 4px;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  border-radius: 2px;
  margin: 3px 0;
  text-decoration: none;
  font-weight: 600;
  font-size: 13px;
}
/* ............................................................... Tags */
/*#tags {
    padding: 0;
    list-style-type: none;
    -moz-column-count: 3;
    -moz-coloumn-gap: 40px;
    column-count: 3;
    column-gap: 40px;
    
    > li {
        margin: 0 0 40px 0;
        padding: 20px;
        position: relative;
        display: inline-block;
    }
    h2 {
        position: absolute;
        top: 0;
        left: 0px;
        width: 22px;
        height: 22px;
        border-radius: 2px;
        background-color: @mittelgrau;
        color: #fff;
        font-size: 1.25em;
        text-align: center;
    }
    span {
        display: block;
        margin: -4px 0 2px 0;
        font-size: .75em;
        color: @mittelgrau;
    }
    
    ul {
        margin: 0 0 2em 0;
        list-style-type: none;
    }
    ul.word {
        margin: 6px 0 0px 0;
    }
    ul.word:nth-child(2) {
        margin-top: -22px;
    }
    ul.docs {
        margin: -4px 0 0 0;
        padding: 0 0 0 20px;
    }
    a:before {
        padding: 0 4px 0 0;
        content: '\f054';
        font-family: FontAwesome;
    }
    
    
    
    
    h3 {
        margin: 0;
        font-size: 1em;
        font-weight: @bold;
    }
}*/
.entrytags {
  margin: 0 auto;
  max-width: 600px;
}
#tags h3 {
  margin: 1px 0;
  padding: 6px 10px 3px 10px;
  background-color: #eeeeee;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  font-weight: 700;
  text-align: center;
}
#tags h3:after {
  display: inline-block;
  padding: 0 0 0 10px;
  font-size: .625em;
  font-family: FontAwesome;
  color: #cfcfcf;
}
#tags .ui-accordion-header:hover {
  color: #e2001a;
}
#tags .ui-accordion-header {
  cursor: pointer;
}
#tags .ui-accordion-header:after {
  content: '\f054';
}
#tags .ui-state-active {
  cursor: default;
}
#tags .ui-state-active:after {
  content: '\f078';
}
#tags .ui-state-active:hover {
  color: #004494;
}
#tags h4 {
  display: inline-block;
  font-weight: 700;
}
#tags .word {
  padding: 10px;
}
#tags .docs:last-child {
  margin-bottom: 0;
}
#tags span {
  display: inline-block;
  margin: -5px 0 0 0;
  font-size: .75em;
  color: #cfcfcf;
}
#tags .docs {
  padding: 0 0 0 20px;
  list-style-type: none;
}
.toggle {
  text-align: right;
  font-size: .75em;
  color: #009036;
  cursor: pointer;
}
.toggle:before {
  content: 'Alle aufklappen';
}
.toggle.open:before {
  content: 'Alle zuklappen';
}
/* ............................................................... Downloads */
#downloadListe {
  padding: 0;
  list-style-type: none;
}
#downloadListe li {
  margin: 0 0 2em 0;
}
#downloadListe .fa {
  font-size: 36px;
  color: #cfcfcf;
}
#downloadListe a:before {
  display: none;
}
#downloadListe a.dlIcon {
  background: none !important;
}
/* ............................................................... Termine */
#terminListe {
  margin: 0 auto;
  max-width: 800px;
  padding: 0;
  list-style-type: none;
}
#terminListe li {
  margin: 0 0 1.8em 0;
  padding: 0 0 0 20px;
}
#terminListe dt {
  margin: 0 0 0 -20px;
  font-size: .75em;
}
#terminListe h3 {
  margin: 0;
  font-weight: 700;
  font-size: 1em;
}
#terminListe div p,
#terminListe dic ul,
#terminListe div ol {
  margin: 0 0 4px 0;
}
#terminListe a {
  background: none;
}
/* ............................................................... Aktuell */
.blogEntries ul {
  margin: 0 auto;
  padding: 0;
  max-width: 800px;
  list-style-type: none;
}
.blogEntries li {
  margin: 0 0 3em 0;
}
.blogEntries small {
  font-size: .75em;
}
.blogEntries h3 {
  margin: 0;
}
.blogEntries p {
  margin: 0;
}
.blogEntries a {
  text-decoration: none;
}
.blogEntries a:hover {
  text-decoration: underline;
  background: none;
}
.blogEntries .readOn a:after {
  display: inline-block;
  padding: 0 0 0 4px;
  content: '\f054';
  font-family: FontAwesome;
  font-size: .625em;
}
/* ............................................................... CookieNotice */
#mCCForm {
  position: fixed;
  box-sizing: border-box;
  top: 0;
  left: 0;
  z-index: 100000;
  padding: 15px 50px;
  width: 100%;
  line-height: 20px;
  font-size: 16px;
  background-color: rgba(0, 0, 0, 0.85);
  color: #fff;
  box-shadow: 0 -2px 3px rgba(0, 0, 0, 0.5);
}
#mCCForm .mCCF__link {
  display: block;
  color: #fcecac;
}
#mCCForm .mCCF__link:before {
  content: '';
  /*display: block;*/
}
#mCCForm #mCCButton {
  float: right;
  font-size: 16px;
  margin: 0 0 0 40px;
  padding: 4px 20px;
  border-radius: 3px;
  background-color: #fecc00;
  color: #333;
  cursor: pointer;
}
#mCCForm #mCCButton .fa {
  margin: 0 0 0 4px;
}
#mCCForm .mCCHide {
  display: block;
  font-size: .8em;
  color: #fcecac;
  cursor: pointer;
}
/* ***********************************************************************
 * *************************************************** Float, Baby, float!
 * ******************************************************************** */
@media screen and (max-width: 1290px) {
  #wrapper {
    padding: 0 10px;
    box-shadow: none;
    border-right: 10px solid #fecc00;
    border-left: 10px solid #fecc00;
  }
}
@media screen and (max-width: 1120px) {
  #logo {
    margin-top: -130px;
    width: 200px;
    height: 200px;
  }
  #logo a {
    height: 200px;
    width: 200px;
  }
  .entry {
    margin-right: 10%;
    width: 62%;
  }
  .entrytags,
  .entrytermine,
  .entrysuche,
  .entryblog,
  .blogentry {
    margin-right: auto;
    float: none;
    width: 100%;
  }
  #sidebar {
    width: 28%;
  }
  #utility {
    width: 95%;
  }
  #mainnav > ul {
    width: 230px;
  }
  #mainnav > ul > li > a {
    font-size: 1.375em;
  }
  #mainnav > ul > li > .subnav {
    right: 230px;
  }
  #toTop {
    bottom: 20px;
    right: 20px;
  }
}
@media screen and (max-width: 780px) {
  #utility {
    position: relative;
    margin: 0 -10px;
    width: auto;
    background-color: #eeeeee;
    z-index: 20;
  }
  #utnav {
    text-align: left;
  }
  #utnav ul {
    padding-left: 10px;
    padding-bottom: 10px;
    text-align: left;
  }
  #utnav li#page1058 {
    display: inline-block;
  }
  #utnav #sForm {
    display: none;
  }
  .scrolled #utnav,
  .scrolled #utility {
    border-bottom: none;
    z-index: 1;
  }
  header {
    margin: 0 -10px 4em -10px;
  }
  #logo,
  .scrolled #logo {
    position: relative;
    margin: 0 auto !important;
    width: 140px;
    height: 140px;
    z-index: 10;
    transition: none;
  }
  #logo a {
    width: 140px;
    height: 140px;
  }
  #mainnav {
    margin-top: -40px;
    z-index: 5;
  }
  #mainnav ul {
    padding-top: 209px;
    width: 100%;
    border-bottom: 2px solid #cfcfcf;
  }
  #mainnav > ul > li:hover .subnav {
    display: none;
  }
  #mainnav > ul > li {
    display: inline-block;
    width: 50%;
  }
  #mainnav > ul > li > a {
    margin: 0;
    padding: 11px 0 0 10px;
    height: 40px;
    font-size: 1.25em;
    text-align: center;
    background-color: #eeeeee;
  }
  #mainnav > ul > li.active > a {
    background-color: #cfcfcf;
  }
  .entry {
    margin-right: 0;
    padding: 0 20px;
    width: 100%;
  }
  .entry .tableinfo {
    display: block;
  }
  .entry .tableinfo:after {
    content: 'Wenn die Tabelle rechts abgeschnitten ist, können Sie den rechten Abschnitt nach rechts/links scrollen.';
    display: block;
    padding: 2px;
    color: #999999;
    background-color: #eeeeee;
    font-family: helvetica, arial, sans-serif;
    font-size: 11px;
    line-height: 13px;
  }
  .entrytags,
  .entrytermine,
  .entrysuche,
  .entryblog,
  .blogentry {
    margin-right: auto;
  }
  #content {
    position: relative;
    padding-top: 3em;
    width: 100%;
    overflow: hidden;
  }
  #sidebar {
    position: absolute;
    top: 0px;
    right: -285px;
    padding: 10px;
    width: 280px;
    background-color: #fff;
    box-shadow: -1px 1px 6px rgba(0, 0, 0, 0.3);
    transition: right .4s;
  }
  #sidebar #subnav h2:after {
    display: none;
  }
  #sidebar #subnav h2:before {
    position: absolute;
    top: 0;
    left: -45px;
    display: inline-block;
    padding: 10px 5px 10px 10px;
    width: 20px;
    content: '\f0c9';
    font-family: FontAwesome;
    color: #009036;
    background-color: #fff;
    box-shadow: -1px 1px 1px rgba(0, 0, 0, 0.3);
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
    font-size: 1.5em;
    cursor: pointer;
  }
  #sidebar.shown {
    right: -17px;
  }
  #sidebar.shown #subnav h2:before {
    content: '\f00d';
    color: #e2001a;
  }
  /* startseite */
  #teaser {
    margin: 0 6% 3em 0;
    padding-top: 4em;
    width: 47%;
  }
  #teaser .teaser {
    width: 100%;
    float: none;
  }
  #teaser .teaser img {
    width: 100%;
    height: auto;
    max-height: none;
  }
  #termine {
    padding-top: 4em;
    width: 47%;
  }
}
@media screen and (max-width: 580px) {
  #teaser {
    margin-right: 0;
    width: 100%;
    float: none;
  }
  #termine {
    width: 100%;
  }
  #termine .hideMe {
    display: none;
  }
  .entry img.align_right,
  .entry figure.align_right,
  .entry img.align_left,
  .entry figure.align_left {
    margin: 0 0 20px 0;
    width: 100%;
    max-width: 100%;
    height: auto;
    float: none;
  }
  .entry figure img {
    display: block;
    margin: 0 auto;
  }
  .entry figure figcaption {
    text-align: center;
  }
}
@media screen and (max-width: 400px) {
  #mainnav > ul > li > a {
    font-size: 1em;
  }
  .entry {
    font-size: 1.125em;
  }
  footer {
    padding-bottom: 100px;
  }
  #cnotice {
    bottom: 0;
    left: 0;
    width: 100%;
    border-radius: 0;
  }
}
@media screen and (max-width: 480px) {
  #gallery img {
    width: 100%;
    height: auto;
  }
}
