html, body {
margin: 0 0 0 0;
padding: 0;
text-align: center;
background:#052722;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
width: 100%; float: left;
height: 100%;
}

#wrap {float: left; width: 100%; margin: 0; padding: 0;min-width: 960px; overflow: hidden; box-sizing: border-box; position: relative; }
#wrap2 {float: left; width: 100%; margin: 0; padding:0; min-width: 960px; z-index: 11; text-align: center; background:transparent; position: absolute; }

#topnav {
    float: left; width: 100%; background:#aaaaa8;  border-bottom: 1px solid #d2d3d8;
}

@font-face {
      font-family: 'icons'; font-display: swap;
      src: url('./font/icons.eot?24386022');
      src: url('./font/icons.eot?24386022#iefix') format('embedded-opentype'),
           url('./font/icons.woff?24386022') format('woff'),
           url('./font/icons.ttf?24386022') format('truetype'),
           url('./font/icons.svg?24386022#icons') format('svg');
      font-weight: normal;
      font-style: normal;
    }

.zc {
    margin: 0 auto; max-width: 1360px; width: 100%; padding: 0;
}

header {
width: 100%;
margin: 0;  padding:0;
position: relative;
float: left;
text-align: center; z-index: 9;
}


#logocontainer {
display: block; width:25%;margin:30px 1% 30px 4%; float: left;
overflow: hidden;-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
transition: all 0.5s; text-align: left;
max-width: 300px;
}
#logocontainer img { width: 100%; float: left; }

#navcontainer {
float: right;
margin: 70px 2% 0 0;
padding: 0;
width:65%;-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
transition: all 0.5s;
box-sizing: border-box; padding: 0;
}

#bilder {float: left; width: 100%; position: relative; overflow: hidden;
text-align: left;
margin:0;
background-position: center center;
background-repeat: no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
z-index: 4;
height: 10px;
}
#bilder div#startinfo {
opacity: 0; visibility: hidden ;transform: translate(0, 200px);
 position: absolute; width: 80% !important; text-align: left;
bottom:5%; left:20%;  z-index: 10; height: auto !important;
padding: 0 10px; box-sizing: border-box; -webkit-transition: all 0.3s ease-in;
-moz-transition: all 0.3s ease-in;
transition: all 0.3s ease-in; font-size: 1.3em;
}

#bilder div#startinfo span:first-child {
    width: 25%; float: right;
}

#bilder div#startinfo span:nth-child(2) {
    width: 90%; float: left; text-align: center;
}
#bilder div#startinfo > div a {
    display: inline-block; margin: 10px 15px; font-weight: bold; color: #fff;
}
#bilder div#startinfo > div a:hover {
    text-decoration: underline;
}

#bilder div#startinfo h1 {
color: #fff; -webkit-transition: all 0.3s ease-in;
-moz-transition: all 0.3s ease-in;
transition: all 0.3s ease-in; font-weight: 400; color: #fff;  margin: 10px 0 0; font-size: 2.5em;
text-transform: uppercase; font-size: 6.5em;}

#bilder div#startinfo p {
    color: #fff;
    -webkit-transition: all 0.5s ease-in;
-moz-transition: all 0.5s ease-in;
transition: all 0.5s ease-in;
}

#bilder div#startinfo.aktiv {
    opacity: 1; visibility: visible;transform: translate(0, 0);
}

#bilder div.animationsinfos {
opacity: 0; visibility: hidden ;transform: translate(-200px, 0);
 position: absolute; width: 70% !important;
bottom: 15%; left:15%;  z-index: 10; height: auto !important;
padding: 0 10px; box-sizing: border-box; -webkit-transition: all 0.3s ease-in;
-moz-transition: all 0.3s ease-in;
transition: all 0.3s ease-in; font-size: 1.4em; text-shadow: 2px 2px #000000;
}

#bilder div.animationsinfos h1 {
color: #fff;text-shadow: 0px 0px 3px #000; -webkit-transition: all 0.3s ease-in;
-moz-transition: all 0.3s ease-in;
transition: all 0.3s ease-in;
font-weight: 600; color: #eee;  margin: 10px 0 0;
}

#bilder div.animationsinfos p {
    color: #fff;
    -webkit-transition: all 0.5s ease-in;
-moz-transition: all 0.5s ease-in;
transition: all 0.5s ease-in;
}

#bilder div.animationsinfos.aktiv {
    opacity: 1; visibility: visible;transform: translate(0, 0);
}

#wrap2.fixiert #logocontainer { width: 30%;  }
#wrap2.fixiert {
 box-shadow: 0px 0px 5px 0px #333;
-moz-box-shadow: 0px 0px 5px 0px #333;
-webkit-box-shadow: 0px 0px 5px 0px #333;
}

@media only screen and (min-width: 1160px) {



}

#content {
margin: 0;
text-align: left;
padding: 0;  position: relative;
float: left; width: 100%; z-index: 2;
background: #052722;
}

.contentseite, .startseite {
    display: flex; flex-wrap: wrap;
}

.contentelement {float: left; width: 98%; padding: 0; margin: 0 1%; position: relative; z-index: 2; }
.halb { width: 48%; margin: 10px 1%; }
.drittel { width: 31.33%; margin: 10px 1%; }
.viertel { width: 23%; margin: 10px 1%; }
.dreiviertel { width:73%; margin: 10px 1%; }
.zweidrittel { width: 64.66%; margin:10px 1%; }
.artikelseite div.contentelement { border-bottom: 1px solid #aaaaa8; margin: 0 0 20px;}

.bildelement .ti, .bildelement .ti h2, .bildelement .ti h3 {
  color: #fff; text-shadow: 0px 0px 3px #000;
}


#inhalt {
float: left; width: 100%;
padding: 30px 0;
position: relative;
min-height: 400px;
}
@media only screen and (min-width: 960px) {
#inhalt.leistung { width: 75%; float: right; }
}

#textfeld {
float: right;
padding: 0 5%;
margin: 0;
width: 90%;
min-height: 100px;
}
#textfeld img, img {max-width: 100%;height: auto !important;}


.balken {margin:60px 1%; padding: 50px 0 !important; position: relative; color:#052722; }
.balken::after {
    background: #A6AEC6;
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    right: -100%;
    top: 0;
    width: 300%;
    z-index: -1;
}



.balkendunkel {margin:0 1%; padding:50px 0 !important; position: relative; color: #fff;}
.balkendunkel::after {
    background: #04274A;
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    right: -100%;
    top: 0;
    width: 300%;
    z-index: -1;
}
.balkendunkel h2, .balkendunkel h3 {
    color: #fff;
}

.balkenr {background: transparent; margin:0 1%; padding: 40px 0 50px 0; position: relative; color: #fff;   }
.balkenr::after {
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    left: -10%;
    top: 0;
    width:300%;
    z-index: -1; background-color: #052722;
}
.balkenl {background: transparent; margin:30px 1%; padding: 50px 0; position: relative; }
.balkenl::before {
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    right: -30%;
    top: 0;
    width:300%;
    z-index: -1;
    border-radius: 30px;
background-color: #daebf4;
}

.balkenbreit {
  display: flex; flex-wrap: wrap;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  margin-bottom: 0 !important;
  width: 100vw;
  max-width: 100vw;
}

.boxblau {
  position: relative;  box-sizing: border-box; padding: 30px;
}
.boxblau::after {
    content:""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #daebf4; z-index: -10;
}
.boxblau {
    margin: 0 !important; padding: 10px 1%; box-sizing: border-box;
}

.boxblau.drittel { width: 33.33% !important; }
.boxblau.zweidrittel { width: 66.66% !important; }
.boxblau.halb { width: 50% !important; }

.bbwrap .bildbalken {
float: left; width: 100vw; background-position: center center;
background-repeat: no-repeat;
margin: 0;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 100%; position: absolute; top: 0; left: 50%; margin: 0 0 0 -50vw;
z-index: -1;
}
.bbwrap {
    width: 100%; position: relative; float: left; margin: 30px 0; z-index: 5; padding: 20px 0; text-align: center;text-shadow: 0px 0px 5px #fff;
}



@media only screen and (min-width: 1160px) { .bbwrap .bildbalken { background-attachment: fixed;} }

#content_2 {
    float: left; width: 92%; margin: 10px 4% 20px; text-align: left;
}

.footcontainer {float: left; width:45%; padding: 10px 1% 10px 4%; text-align: left; position: relative; z-index: 2;  }

#footer {
float: left;
width: 100%;
padding:80px 0 50px;
min-width: 1160px;
background:#00FF6A;
text-align: center;
margin: 0; color: #052722;
box-sizing: border-box;
position: relative; z-index: 10;
}
#footer div.zc {
    display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: flex-end;
}

#footlogo {
    float: left; width: 100%; margin: 10px 0 30px;
}



.kontaktseite {float: right; width: 40%; margin: 30px 0 10px;}
.kontaktformcontainer {float: left; width: 100%; max-width: 650px;}



.unavseite {
    float: left; width: 100%; margin: 10px 0;
}

ul.unavseite_menue { float: left;color: #555464; margin: 0; }

#textfeld ul.unavseite_menue
{
            float: left;
            margin: 0;
            padding: 0;
            list-style-type: none;
            display: flex; flex-wrap: wrap;
            width: 100%; justify-content: left;
}

ul.unavseite_menue li {
                         display: block;
                         float: left; width: 25%;
                         margin: 0; padding: 0;
                         position: relative; box-sizing: border-box; padding: 10px 0.5%;
                         z-index: 3;

}
ul.unavseite_menue li a {
    display: block; float: left; width: 100%; box-sizing: border-box; padding:40px 10px 40px 60px; background: #dceeff; color: #153f49; font-weight: 600; border-radius: 5px; position: relative; font-size: 1.1em;
}
ul.unavseite_menue li a:hover {
     background: #00FF6A;  color: #fff;
}


ul.sitemap li {
margin: 5px 0 10px;
list-style-type: square;
font-weight: normal;
font-size: 1.2em;
}


ul.sitemap_unterpunkt {
list-style-type: square;
color: #555464;
}

ul.sitemap_unterpunkt li {
margin: 5px 0;
list-style-image: none;
font-weight: 300;
font-size: 0.8em;
}

.bildrahmen {
padding: 0;
text-align: center;
font-size: 0.85em;
position: relative;
max-width: 50%;
}

.bildrahmen img {width: 100%;}


.floatrechts {
margin: 0 0 20px 5%;
float: right;
}

.floatlinks {
margin: 0 5% 10px 0;
float: left;
}

.galerie {
float: left;
margin: 10px 0 10px -1%; width: 102%;
}
.galerie > div { display: flex; flex-wrap: wrap;}

.galerie dl {
float: left;
height: auto !important;
text-align: left;
margin: 10px 1% 15px;
font-size: 0.9em;
width: 23%; position: relative;
}
.galerie dt { float: left; width: 100%; height: 100%; }
.galerie dd {
margin: 0;
padding: 0;
}


#textfeld img.gal {
padding: 0;
width: 100% !important;
box-sizing: border-box;
height: 100% !important; float: left; object-fit: cover;
}

.purgal {
    float: left; width: 100%; align-items:center; justify-content: center;
}
.purgal > div {
    float: left; width: 23%; margin: 10px 1%;
}


.dlbox {

margin: 0 0 5px 0;
}

.dlbox p {
margin: 7px 0;
padding-left: 20px;
background: url('images/pfeilr2.gif') 0 4px no-repeat;
font-size: 95%;
}
.dlbox p.pdfdl {
background: url('images/pdf.gif') 0 0 no-repeat;
}

.dlbox h3 {
padding: 0;
margin: 30px 0 20px 0;
font-weight: bold;
}


#logoutform {
position: absolute;
bottom: 100px; right: 60px;
}

#kontaktform {
    float: left; width: 100%; margin: 0; padding: 0;
}

.kontaktformular {
width: 100%; padding: 0; max-width:650px;
}

.fspalte {float: left; width: 47%; padding: 10px 3% 10px 0;}


.kontaktformular p {
width: 100%;
float: left;
}
.kontaktformular p.pflichtf {font-size: 0.9em; padding: 0; width: 100%;}

.kontaktformular legend {  display: none; }

legend {  float: left; width: 100%; font-size: 1.4em; margin: 0 0 20px; }
fieldset {border: none;  padding: 0; margin: 0;}

#bewerbungsform legend {
    display: block;margin: 10px 0; padding: 10px 0; border-top: 1px solid #efefef;
}

.fileinfo, .bildinfo {
    float: left; width: 100%; text-align: center; margin: 10px 0;
}
.formfehler_file {
color: red; font-weight: bold;
}

.kontaktformular .stelleninfo label {
    width: 100% !important;
}
.kontaktformular .stelleninfo textarea {
    height: 60px;
}


.formfeld.radio > div {
    float: left; margin: 0 10px;
}
.formfeld.radio > div input {
    width: auto; margin: 10px;
}
.formfeld.radio > div label {
    width: auto;
}
.kontaktformular h3 {
  float: left; width: 100%; margin: 20px 0 10px 0;
}

.kontaktformular label {
float: left;
width: 35%;
margin:10px 0 5px;
font-size: 100%;
}

.kontaktformular input {
float: left;
width: 100%;
margin: 0; box-sizing: border-box;
}

.kontaktformular select {
float: left;
width: 65%;
}

input#captcha {
width: 130px;
}

.kontaktformular textarea {
width: 100%;
height: 180px;
box-sizing: border-box;
}


div.formfehler {
width: 100%;
float: right;
color: #c00;
text-align: center;
font-size: 100%; padding-top: 5px;
}

input.fehlerfeld {
background: #fcc;
border: 1px solid #f00;
}

form {
margin: 0;
}

input.button, input.anfragebutton {
font-weight: 300; text-align: center;
padding: 12px 20px 10px; margin:0;
font-size: 1.2em; background:#00FF6A;
color:#fff; border: 0; width: 200px; box-sizing: content-box;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none; cursor: pointer;
border: 1px solid #00FF6A;
}
input.button:hover, input.anfragebutton:hover {
background: #052722;
color: #fff;
text-decoration: none;}





ul.nliste {
list-style-type: none;
}
ul.nliste li {
font-size: 85%;
padding-left: 20px;
margin-bottom: 10px;
}

p.captchafehler {
border: 1px solid #c00;
color: #f00;
margin: 10px 0;
padding: 10px;
background: #ffc;
}

.meldung { color: red }

#datenschutzfeld {
float: left; width: 98%; margin: 5px 0;padding: 10px 1%;
}
#datenschutzfeld input {
    float: left; margin-top: 5px;
}
#datenschutzfeld label {
    float: right; width: calc(100% - 35px); font-size: 0.9em;
}
.phe a.weiterlink::before {
  display: inline-block;
  padding: 0 10px 0 0;
  font-family: 'icons';
  text-decoration: none;
  font-size: 1.2em;
  content: "\e80e";
  font-weight: normal;
}

.formfeld { width: 100%; float: left; padding: 5px 0; }
.formfeld.hop { display: none !important;}


.sonderinhalt {background: #F9A979; color: #fff; box-sizing: border-box; padding: 20px;}
iframe {max-width: 100%;}



div.formfeldnl {float: left; width: 100%; margin: 5px 0;}
div.formfeldnl input {float: left; width: 10%; margin: 10px 0;}
div.formfeldnl label {float: right; width: 88%; }
div.formfeld.ta label { width: 100%;}


p.beschriftung {
    float: left; width: 100%; margin: 20px 0 10px;
}

.formfeld div.checkelement {
    float: left; width: 50%; padding: 5px 0;}
.kontaktformular div.checkelement label {float: none; }
.kontaktformular div.checkelement input {background: none; border: none; width: 20px; float: left !important; margin: 5px 5px 5px 0;}

.loader { float: left; width: 100%; text-align: center; margin: 20px 0;}
.loader div { display: inline-block; border:4px solid #fff; border-top:3px solid #00FF6A; border-radius: 50%; width: 50px; height: 50px; animation: spin 1s linear infinite;z-index: 6;}
@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }


.contentelement.flexgalerie { position: relative;  }
.contentelement.flexgalerie.flexslider::before{ position: absolute; top: 100px; left: 50%; z-index: 1; margin: 0 0 0 -30px; content:""; display: inline-block; border:4px solid #ccc; border-top:4px solid #666; border-radius: 50%; width: 50px; height: 50px; animation: spin 1s linear infinite;}

@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
/*sudo-Slider -----------------*/
.slider {
    display: block; float: left; width: 100%; height: 100%; min-height: 100%; margin:0; background: url('images/loader.svg') center center no-repeat #052722; z-index: 1;
}
.slider div {
     display: block; float: left; width: 100%;  height: 100%; margin:0;
}

.slider div.wslide {
background-position: center center;
background-repeat: no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
}

ol.numericControls {
    float: left; width: 100%; margin: 0; padding: 0; list-style-type: none; text-align: center;
    position: absolute; left: 0; bottom:20px; z-index: 90;
}
ol.numericControls li {
    display: inline-block; margin:5px; padding: 0;
}
ol.numericControls li a {
display: block; width: 15px; height: 15px; text-indent: -2000px; background: #fff; background: rgba(255,255,255,0.4); border-radius: 10px; -moz-border-radius: 10px; -webkit-border-radius: 10px;
overflow: hidden; float: left; margin: 0 !important; position: static;
}
ol.numericControls li a:hover { background:#fff; background: rgba(255,255,255,0.7); }
ol.numericControls li.current a { background:#052722; }



.controls a {
    font-family: icons; font-size:2.0em; position: absolute; z-index: 50; color: #bebeb8; width:100%; text-align: center; top: 50%; margin: -40px 0 0 0; line-height: 30px;
    border-radius: 5px;
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
}
a.prevBtn { float: left;opacity: 0.5; width:50px;padding: 15px 0; color: #fff; left: 10px; }
a.nextBtn {float: right;opacity: 0.5; width:50px;padding: 15px 0; color: #fff; right: 10px;}
a.prevBtn:hover { opacity: 0.9; color: #fff; text-decoration: none; background: #052722; }
a.nextBtn:hover { opacity: 0.9; color: #fff; text-decoration: none; background: #052722;}

a.prevBtn:hover, a.nextBtn:hover { opacity:1.0;  }


#wrap > a.notdienst {
    display: block; position: absolute; top:5px; right: 10px; z-index: 20; width: 220px; height: auto;
}

@media only screen and (max-height: 800px) {
#bilder div#startinfo h1 { font-size: 4.5em;}
}
@media only screen and (max-width: 1560px) {

#bilder div#startinfo h1 { font-size: 4.5em;}

}

@media only screen and (max-width: 1160px) {
#logocontainer { width:30%;}
#footer {min-width: 680px; }
#wrap {min-width: 680px; }
header {width: 100%; height: auto;}
#wrap2 {min-width: 680px;padding: 0;  }
#content {width: 100%; margin: 0;background-size:280px auto;   }
header > p {  display: none;}
#inhalt { padding: 50px 0;}
#bilder { margin:0; }

#navcontainer {
float: left; position: fixed; top: 0; right: 0;
margin: 0;
width: 100%; background:rgba(0,0,0,0.5);
z-index: 100;
height: 100%; -webkit-transition: none;
-moz-transition: none;
transition: none;
}
#navinner {
float: right; position: fixed; top: 0; right: 0;
margin: 0;
padding: 0;
width: 60%; background:#fff;
z-index: 10;
height: 100%;
box-shadow: 0px 0px 30px 0px #000000;
-moz-box-shadow: 0px 0px 30px 0px #000000;
-webkit-box-shadow: 0px 0px 30px 0px #000000;
overflow-y: auto;
}
#navout {
    float: left; width: 40%; height: 100vh;
}
ul.unavseite_menue li { width: 50%; }

.galerie dl, .purgal > div { width: 31.33%; }

#bilder div#startinfo h1 { font-size: 3.5em;}
}

@media only screen and (max-width: 960px) {
#logocontainer { width:40%;margin-top: 30px;}
.viertel { width: 48%; }
.dreiviertel {width: 98%}
.umen {width: 48%; }
.fspalte {width: 100%; padding: 10px 0;}

#bilder { max-height:600px; }
#bilder div.animationsinfos h2 {font-size: 30px;}

.footcontainer { width:92% !important; padding: 10px 4%;  }
#navinner {width: 70%;}
#navout { width: 30%; }

#bilder div#startinfo { font-size: 0.9em; bottom: 10px;  }

.boxblau.drittel, .boxblau.zweidrittel, .boxblau.halb { width: 100% !important; }


}

@media only screen and (max-width: 680px) {
#wrap {min-width: 280px;}
#logocontainer { width:45%;}
header {width: 100%; min-width: 280px;}
#wrap2 {min-width: 280px; width: 100%; }
#content {min-width: 280px; width: 100%; min-height: 300px;}
#inhalt {width: 100%;}
#textfeld {
float: left;
}
.galerie {margin: 10px 0 10px -1%; width: 102%;}
.galerie dl, .purgal > div { width: 48%; margin: 5px 1%;  }

.kontaktseite, .kontaktformcontainer  {width: 100%; margin: 0;}
.kontaktadresse {  width: 100%; margin: 0;}

#footer {min-width: 300px; }

address {width: 96%; padding: 5px 2% 0; }


.halb { width: 98%;}
.drittel { width: 98%; }
.zweidrittel { width: 98%; }
#bilder div#startinfo {  width: 95% !important;  left:5%; font-size: 0.8em;}
.controls a {display: none;}
#bilder { max-height:450px;}
#bilder div.animationsinfos { bottom: 7%; font-size: 0.9em; height: 60%; width: 80% !important;        }
#bilder div.animationsinfos h2 {font-size: 25px;}

ul.unavseite_menue li {  width: 100%; }

#navinner { width: 90%;}
#navout {width: 10%;}
#footer::after {
  content: "";
  position: absolute;
  right: 10px;
  bottom:105px;
width: 200px;
height: 550px;
}
}
@media only screen and (max-width: 460px) {
#logocontainer { width:50%; margin-top: 30px;}
#logocontainer img { width: 100%; }
#wrap2.fixiert #logocontainer { width: 40%;  }

.formfeld div.checkelement {width: 100%;}
.kontaktformular {width: 100%;}
.kontaktformular label { width: 100%;}
.kontaktformular p {width: 100%;}
.kontaktformular input {width: 100%;}
.kontaktformular textarea {width: 100%;}


.viertel { width: 98%; }

input.button { padding: 5px 0; }

div.formfehler {width: 100%;}
.umen {width: 98%; }

.bildrahmen {
    width: 100%; margin: 0 0 20px 0; max-width: 100%;
}


a.weiterlink {
    font-size: 0.9em;
}
#bilder div#startinfo { width: 90% !important;left:5%; font-size: 0.7em;}
}

@media only screen and (max-width: 350px) {
.galerie dl, .purgal > div { width: 98%;}
#bilder {max-height: 400px }
 }