/* Reset
------------------------------------------------------------------------- */

/* Based on http://meyerweb.com/eric/tools/css/reset/ */
/* v1.0 | 20080212 */

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, 
blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, 
font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, 
u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, 
caption, tbody, tfoot, thead, tr, th, td { 
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}
 
ol, ul { list-style: none; }

blockquote, q { quotes: none; }

blockquote:before, blockquote:after, 
q:before, q:after {
    content: ''; 
    content: none;
}
 
:focus { outline: 0; }

ins { text-decoration: none; }

del { text-decoration: line-through; }

table {
    border-collapse: collapse;
    border-spacing: 0;
}

a { outline: none; }

/* Generelle Stile
------------------------------------------------------------------------- */

/* Grundlagen */

body {
    background: #fff;
    color: #10222b;
    font-family: "Trebuchet MS", Verdana, Arial, sans-serif;
    font-size: 87.5%; /* 14px */
    line-height: 1.5; /* 21px */
}      

/* Links */

a:link, a:visited {
    color: #fff;
    background: #95ab63;
    text-decoration: none;
    padding: 0 0.2em;
}

a:hover { background: #000; }

h1 a:link, h1 a:visited,
h2 a:link, h2 a:visited,
h3 a:link, h3 a:visited,
h4 a:link, h4 a:visited,
h5 a:link, h5 a:visited,
h6 a:link, h6 a:visited {
    color: #95ab63;
    text-decoration: none;
    background: transparent;
    padding: 0;
}

h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
h5 a:hover,
h6 a:hover {
    color: #000;
}

/* Schriftgrößen */
/* (Skala: 6, 7, 8, 9, 10, 11, 12, 14, 16, 18, 21, 24, 36, 48, 60, 72) */

h1, h2, h3, h4, h5, h6 {
    font-family: Palatino, Georgia serif;
    font-weight: normal;
    color: #95ab63;
    clear: both;
    text-shadow: 0 1px 1px #000;
}

h1 {
    font-size: 1.7143em; /* 24px */ 
    line-height: 0.875;
}

h2 {
    font-size: 1.2857em;  /* 18px */
    line-height: 1.1667;
}

h3 {
    font-size: 1.1429em; /* 16px */
    line-height: 1.3125;
}

h4, h5, h6 {
    font-size: 1.0em; /* 14px */
    line-height: 1.5;
}

/* Abstände */

p, dl, address, table, 
blockquote, pre, fieldset {
    margin: 0 0 1.5em 0;
}

#header p, #subnav p, #subnav ul, #side table {
    margin: 0;
}

p.date {
    color: #999;
    font-size: 0.85em;
    margin-bottom: 0;
}

h1 { margin: 0 0 0.875em 0; }
h2 { margin: 0 0 1.0em 0; }
h3 { margin: 0 0 1.1667em 0; }
h4 { margin: 0 0 1.3125em 0; }
h5, h6 { margin: 0 0 1.5em 0; }

#header h1, #header h2, #header h3, #header h4, #header h5, #header h6 {
    margin-left: 0;
}

#side h1, #side h2, #side h3, #side h4, #side h5, #side h6 {
    margin-left: 0;
    margin-right: 0;
}

ul ul, ol ol, ol ul, ul ol {
    margin-bottom: 0;
    margin-left: 1.5em;
}
 
/* Listen */

ul { list-style-type: square; margin: 0 0 1.5em 30px; }
ol { list-style-type: decimal; margin: 0 0 1.5em 30px; }
dt { font-weight: bold; }
dd { margin-left: 1.5em; }

/* Tabellen */

table { 
    margin-bottom: 1.5em;
    width: 100%;
    border: 1px solid #95ab63;
}

table > thead {
    border-top: 1px solid #10222c;
}

#main table {
    width: 580px;
}

#side table {
    font-size: 0.85em;
}

caption {
    font-weight: bold;
    padding-bottom: 0.5em;
}

thead {
    background: #10222c;
    color: #fff;
    border-left: 1px solid #10222c;
    border-right: 1px solid #10222c;
}

thead th {
    padding: 0.5em;
    text-align: left;
    font-weight: bold;
}

tbody td {
    padding: 0.2em 0.5em;
    text-align: left;
    border-bottom: 1px solid #95ab63;
}

tbody tr {
    border-left: 1px solid #95ab63;
    border-right: 1px solid #95ab63;
}

tbody tr.odd {
    background: #eaf6cd;
}

tfoot {
    background: #95ab63;
    border-left: 1px solid #95ab63;
    border-right: 1px solid #95ab63;
}

tfoot td {
    padding: 0.5em;
}

/* Zitate */

blockquote {
    background: url(img/quote-bg.png) no-repeat 0 0;
    font-style: italic;
    color: #999;
}

blockquote p {
    margin: 0 0 1.5em 40px;
}

blockquote cite, blockquote em {
    font-size: 0.85em;
    color: #10222b;
    font-style: normal;
    font-weight: bold;
}

/* Formulare */

fieldset {
    border: 1px solid #95ab63;
    background: #eaf6cd;
    padding: 0.5em 0;
}

legend {
    font-weight: bold;
    margin: 0 1.5em;
    padding: 0.25em 0.5em;
    background: #95ab63;
}

label {
    font-weight: bold;
    cursor: pointer;
    margin-right: 1.0em;
}

form .help {
    display: block;
    color: #777;
    font-style: normal;
    font-size: 0.85em;
}

input, textarea, select, button {
    font-family: inherit;
    font-size: 1.0em;
}

textarea, input[type='text'], 
input[type='password'] {
    display: block;
    width: 490px;
}

input[type="submit"] {
    margin: 0.5em 1.5em;
}

#header input[type="submit"] {
    margin: 0;
}

textarea {
    width: 99%;
    display: block;
}

/* Sonstiges */

abbr, dfn {
    border-bottom: 2px dotted #10222b;
    font-style: normal;
    cursor: help;
}

strong { font-weight: bold; }

em  { font-style: italic; }

ins { text-decoration: underline; }

del { text-decoration: line-through; }

img { margin: 0 20px 1.5em 20px; }

.enclosure img { margin: 0 0 -5px 0; }

img.floatleft {
    float: left;
    margin: 0 1.5em 1.5em 0;
}

img.floatright {
    float: right;
    margin: 0 0 1.5em 1.5em;
}

/* Hinweise & Fehler, Allgemeine Klassen */

.error {
    color: #f00;
}

.clear {
    clear: both;
}

.infobox {
    border: 2px solid #95ab63;
    clear: both;
    margin: 0 0 1.5em 0;
    padding: 1.5em;
    background: #eee;
}

.infobox h1, .infobox h2, .infobox h3, .infobox h4, .infobox h5, .infobox h6,
.infobox p {
    margin-left: 0;
    margin-right: 0;
}

.infobox ul, .infobox ol {
    margin-bottom: 0;
}

.block {
    clear: both;
}

.empty {
    margin: 0 0 1.5em 0;
}

#kalender {
    margin-bottom: 1.5em;
}

.ce_hyperlink {
    margin: 0 0 0.5em 0;
}

.ce_hyperlink:last-child {
    margin-bottom: 1.5em;
}

.stundenplan {
    font-size: 0.85em;
    text-align: top;
}

.noborder .image_container img {
    border: none;
}

/* Header
------------------------------------------------------------------------- */

.content {
    width: 960px;
    margin: 0 auto;
}

/* Header */

#headerbar {
    background: #95ab63 url(img/headerbar-bg.png) repeat-x 0 0;
    height: 215px;
    clear: both;
}

#headerbar .content { position: relative; }
#headerbar h1 { margin: 0; }
#headerbar h1 a {
    background: url(img/logo.png) no-repeat 0 0;
    text-indent: -1000em;
    width: 200px;
    height: 185px;
    display: block;
    position: absolute;
    top: 15px;
    left: 22px;
}

#nav a:link, #community a:link, 
#nav a:visited, #community a:visited {
    background: transparent;
}

#navigation a:link, #navigation a:visited {
    padding: 0;
}

#header fieldset {
    background: transparent;
    border: none;
    padding: 0;
    margin: 0;
}

/* Login/Register
------------------------------------------------------------------------- */

#community { background: #e2f0d6; }

#slidepanel {
    height: 20em;
    display: none;
}

#slidepanel p {
    margin-bottom: 1em;
}

#slidepanel form {
    margin: 1.5em 0 0 0;
    font-size: 12px;
}

#slidepanel label {
    width: 100px;
    display: block;
    float: left;
}

#slidepanel input {
    width: 150px;
}

#slidepanel .checkbox {
    margin-right: 5px;
}

#header p.register_submit {
    margin-left: 110px;
}

#slidepanel .submit {
    width: auto;
}

#slidepanel .submit_button {
    margin-left: 110px;
}

#slidepanel-inner {
    background: url(img/slidepanel-bg.png) repeat-y 280px 0;
    float: left;
    margin: 0 10px;
}

#clickpanel {
    height: 5px;
    position: relative;
}

#clip {
    background: #e2f0d6;
    color: #10222b;
    height: 1.5em;
    text-align: center;
    position: absolute;
    left: 10px;
    top: 0;
}

#clip a {
    text-decoration: none;
    padding: 0 13px 6px 13px;
    color: #10222b;
    display: block;
}

#login {
    width: 270px;
    float: left;
}

#login table {
    width: auto;
    border: none;
}

#register {
    width: 620px;
    padding-left: 40px;
    float: left;
}

#register .halb {
    width: 50%;
    float: left;
}

#ctrl_newsletter label, #ctrl_newsletter input {
    width: auto;
    float: left;
}

#slidepanel .error {
    width: 255px;
    font-size: 10px;
    margin: -0.5em 0 1em 0;
}

#slidepanel .forgot-password {
    margin-left: 110px;
}

#slidepanel .forgot-password a {
    color: #000;
    font-size: 12px;
}

#slidepanel .forgot-password a:hover {
    text-decoration: underline;
}

#passwort-vergessen input {
    width: 580px;
}

#passwort-vergessen input.submit {
    width: auto;
}

#passwort-vergessen label {
    display: block;
}

#passwort-vergessen .submit_container {
    margin-bottom: 1.5em;
}

/* Navigation/Subnavigation
------------------------------------------------------------------------- */

#nav {
    background: #10222c url(img/nav-bg.png) repeat-x 0 0;
    height: 2.8em;
}

#nav .content {
    height: 2.8em;
    line-height: 2.8em;
    text-transform: uppercase;
    overflow: hidden;
}

#nav ul {
    float: right;
    color: #95ab63;
    list-style: none;
    margin-right: 90px;
}

#nav ul .trail {
    color: #95ab63;
}

#nav li {
    float: left;
    margin-left: 2.14em;
}

#nav a {
    color: #fff;
    display: block;
    text-decoration: none;
}

#nav a:hover {
    color: #95ab63;
}

#subnav ul {
    list-style: none;
    margin-bottom: 1.5em;
    text-transform: uppercase;
    font-weight: bold;
}

#subnav li {
    height: 2.14em;
    line-height: 2.14em;
}


#subnav li.active {
    background: #96ac64 url(img/subnav-bg.png) repeat-x 0 0;
    padding: 0 10px;
}

#subnav ul .trail {
    background: #96ac64 url(img/subnav-bg.png) repeat-x 0 0;
}

#subnav a {
    display: block;
    color: #000;
    text-decoration: none;
    background: #eee;
    padding: 0 10px;
}

#subnav a:hover { background: #96ac64 url(img/subnav-bg.png) repeat-x 0 0; }

/* Seitenstruktur
------------------------------------------------------------------------- */

#main {
    background: url(img/main-bg.png) no-repeat 0 0;
    width: 700px;
    min-height: 500px;
    float: right;
    margin-top: -180px;
}

#main-inner {
    width: 580px;
    margin: 15px auto 0 auto;
}

#center {
    width: 330px;
    float: left;
}

#right {
    width: 250px;
    float: right;
}

.headerimage img {
    margin: 0 0 25px 0;
}

.image_container img {
    border: 2px solid #95ab63;
}

.image_container .caption {
    margin: -20px 0 0 0;
    font-size: 0.85em;
    color: #999;
}

.image_container a {
    padding: 0;
    background: transparent;
}

#imagebar img {
    border: 0;
    margin: 0;
    margin-bottom: 15px;
}

#homepage #imagebar { height: 350px; margin-bottom: 15px; overflow: hidden; }

.ce_download img {
    margin: 0;
}

#side {
    width: 220px;
    float: left;
    margin-top: 30px;
}

/* Startseite
------------------------------------------------------------------------- */

/* Aktuelle Nachrichten */
.mod_newslist {
    margin-bottom: 1.5em;
}

.aktuelle_neuigkeiten {
    border-bottom: 2px dotted #ddd;
    padding: 10px 0;
}

.aktuelle_neuigkeiten p {
    margin: 0;
    color: #999;
    font-size: 0.85em;
}

.aktuelle_neuigkeiten h4 {
    margin: 0;
}

/* Nächste Events */
.mod_upcoming_events {
    margin-bottom: 1.5em;
}

.naechste_events {
    border-bottom: 2px dotted #ddd;
    padding: 10px 0;
}

.naechste_events p {
    margin: 0;
    color: #999;
    font-size: 0.85em;
}

.naechste_events h4 {
    margin: 0;
}

/* Newsletter-Bestellung */
.mod_subscribe {
    margin: 0 0 1.5em 0;
}

.mod_unsubscribe {
    margin: 0 0 1.5em 0;
}

.mod_subscribe input, .mod_unsubscribe input {
    margin: 0 0 15px 0;
}

#newsletter input {
    width: 220px;
    margin-bottom: 0.5em;
}

#newsletter input.checkbox {
    width: auto;
}

#newsletter input.submit {
    width: auto;
    margin: 0 0 1.5em 0;
}

#newsletter .confirm {
    margin: 0 0 1.0em 0;
    font-size: 0.85em;
}

#newsletter .error {
    margin: 0 0 1.0em 0;
    font-size: 0.85em;
}

/* Einführungsvideo */
#einfuehrungsvideos {
    border-bottom: 2px dotted #ddd;
    padding-bottom: 1.5em;
    margin-bottom: 1.5em;
}

#einfuehrungsvideos div {
    margin-bottom: 10px;
}

.ce_download {
    margin-bottom: 1.5em;
}

/* Aktuelles
------------------------------------------------------------------------- */

/* Neuigkeiten */ 
#neuigkeiten-leser {
    position: relative;
}

.article {
    position: relative;
    margin: 0 0 1.5em 0;
}

.separator {
    border-bottom: 2px dotted #ddd;
    margin: 0;
}

.article:last-child .separator {
    border-bottom: none;
}

/* Seminare & Termine */
.minicalendar th {
    text-align: center;
}

.event {
    position: relative;
    margin: 0 0 1.5em 0;
}

.event:last-child .separator {
    border-bottom: none;
}

.recurring {
    margin: 0 0 1.5em 0;
    color: #999;
    font-size: 0.85em;
}

.submit_container{
    margin-bottom: 1.5em;
}

/* Videoliste */

#videoliste object {
    float: left;
    margin-left: 25px;
    margin-bottom: 25px;
}

/* Kontakt
------------------------------------------------------------------------- */

/* Kontaktformular */
.checkbox_container {
    margin: 0 0 1.5em 0;
}

.checkbox_container span {
    display: block;
}

#main .error {
    margin: -1.5em 0 1.5em 0;
}

/* Adresse & Anfahrt */
#googlemap {
    width: 350px;
    height: 230px;
    margin: 0 0 1.5em 0;
    border: 2px solid #95ab63;
    float: right;
}

#googlemap a {
    background: transparent;
}

#adressblock {
    width: 200px;
    float: left;
}

#anfahrt-adresse #adressblock {
    clear: none;
}

/* Bilder-Galerien
------------------------------------------------------------------------- */

.ce_gallery {
    width: 580px;
    margin: 20px 0 1.5em 0;
}

.ce_gallery h1 {
    margin-left: 0;
}

.ce_gallery img {
    margin: 0 17px 10px 17px;
}

.ce_gallery a {
    padding: 0;
    background: transparent;
}

.ce_dfGallery {
    margin: 0 0 1.5em 0;
}

.ce_dfGallery h1  {
    margin-left: 0;
}

.ce_dfGallery div {
    border: 2px solid #95ab63;
    height: 350px;
}

/* Footer
------------------------------------------------------------------------- */

#footer {
    clear: both;
    font-size: 0.85em;
    color: #fff;
    background: #95ab63 url(img/footer-bg.png) repeat-x 0 0;
    text-align: center;
    height: 5.0em;
    padding: 2.0em 0 0.5em 0;
}

#footer p { clear: both; }

#footer a:link, #footer a:visited {
    background: transparent;
    text-decoration: none;
    color: #fff;
}

#footer a:hover {
    color: #000;
}