html, body {
margin: 0 0 0 0;
padding: 0;
text-align: center;
background:#fff;
width: 100%; float: left;
height: 100%;
}

#wrap {float: left; width: 100%; margin: 0; padding: 0; position: relative; min-width: 960px; z-index: 5; overflow: hidden;  }
#wrap2 {float: left; width: 100%; margin: 0; padding:0; min-width: 960px; position: relative; z-index: 102; background:#fff; text-align: center;}

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

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

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

header {
width: 100%;
margin: 0;  padding:0;
float: left;
text-align: center;
}
header #headw {
  position: relative; float: left; width: 100%;
}


#logocontainer {
display: inline-block; width:52%;margin:10px 4% 0;
-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
transition: all 0.5s; text-align: left; float: left; font-size: 1.2em;
}
#logocontainer img { float: left; max-width: 100%; margin: 0 0 5px;}

#logocontainer a {
    color: #231f20;
}


#navcontainer {
float: left;
margin: 0;
padding: 0;
width: 100%;-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
transition: all 0.5s;
background: #315132;
}

#bilder {float: left; width: 100%; position: relative; overflow: hidden;
text-align: left; 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;
background-color: #fff;
margin: 0;z-index: 1;
}
@media only screen and (min-width: 1960px) {
#bilder { }
}
@media only screen and (min-width: 2660px) {
#bilder { }
}


div#startinfo {
    position: absolute; bottom: 10%; left: 10%; width: 80%; text-align: center;  font-size: 1.4em;  z-index: 10; color: #fff;text-shadow: 0px 0px 3px #000000;
}
div#startinfo h1 { color: #fff; }


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

#wrap2.fixiert {
    padding-bottom: 40px;
}

#wrap2.fixiert #navcontainer {position: fixed; top: 0; left: 0; }
}


#bilder div.start {
    position: absolute; bottom: 20%; right: 30%; z-index: 5; color: #fff; font-size: 1.1em;
}
#bilder div.start h1 {
    color: #fff;
}

#content {
margin: 0;
text-align: left;
padding: 0;  position: relative;
float: left; width: 100%;
}

.contentseite, .startseite {
    display: flex; flex-wrap: wrap; float: left; width: 100%;
}

.contentelement, .textfeld {float: left; width: 98%; padding: 0; margin: 0 1%;}
.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%; }
.bildelement {
    color: #fff; font-size: 1.2em;
}
.bildelement h1, .bildelement h2, .bildelement h3 {
    color: #fff;
}

.bildelement .ti {
    width: 70%;
}
#textfeld .bildelement .bildgross {
    width: 106%; left: -3%;
}

.bildelement .bildgross img {
  filter: brightness(70%);
}

#inhalt {
float: left; width: 100%;
padding: 10px 0;
position: relative;
min-height: 700px;
}

#textfeld {
float: left;
padding: 0 3%;
margin: 0;
width: 94%;
min-height: 100px;
}

aside {
float: left; padding: 0 4%;
margin: 0;
width: 92%;
display: none;
}




.balken {background: #ececec; margin: 50px 1%; padding: 20px 0; position: relative;}
.balken::after {
    background: #ececec;
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    right: -100%;
    top: 0;
    width: 100%;
    z-index: 1;
}

.balken::before {
    background: #ececec;
    content: "";
    display: block;
    height: 100%;
    left: -100%;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}


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

footer {
float: left;
width: 100%;
padding: 30px 0;
min-width: 1160px;
background: #315132; text-align: center;
margin: 30px 0 0;
color: #fff;
position: relative;
}
footer .kontakt {
    width:58.66%;
}
footer .kontakt > div {
    float: left; width: 45%; margin: 0 5% 0 0;
}

#footgrafik {
    position: absolute; bottom: 0; left: 10px; width: 90%; max-width: 800px;
}

#copyright {
    float: left; width: 90%; margin: 20px 5%; color:#838383;
}

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

.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 0 30px;
			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: 50%;
                         margin: 0; padding: 0;
                         position: relative; box-sizing: border-box; padding: 8px;
                         z-index: 3;

}
ul.unavseite_menue li a {
    display: block; float: left; width: 100%; box-sizing: border-box; padding: 20px; background: #315132; color: #fff; font-size: 1.1em; border-radius: 10px;
}
ul.unavseite_menue li a:hover {
     background: #333;
}

ul.unavseite_menue li a::before {
    display: inline-block;
    padding: 0 10px 0 0;
    font-family: 'icons';
    text-decoration: none;
    font-size: 18px;
    content: "\e806";
    line-height: 20px;
}

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;
color: #000;
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%;
font-size: 0.9em;
width: 23%;
}

.galerie dd {
margin: 0; 
padding: 0;
}


img.gal {
padding: 0;
width: 100%;
box-sizing: border-box;
}



.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: fixed;
top: 10px; right: 10px; z-index:99999;
}
#logoutform input {
    padding: 5px 20px; border-radius: 5px;
}

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

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

.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;}

.formfeld.radio > div {
    float: left; margin: 0 10px;
}
.formfeld.radio > div input {
    width: auto; margin: 10px;
}
.formfeld.radio > div label {
    width: auto;
}
.formfeld.hop {
    display: none !important;
}


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

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

.kontaktformular select {
float: left;

background: #fff;
width: 100%;
margin: 1px 0;
}

input#captcha {
width: 130px;
}

.kontaktformular textarea {
width: 100%;
height: 120px;
background: #fff;
box-sizing: border-box;
}


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

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

form {
margin: 0;
}

input, textarea {
color: #000;
padding: 5px;
}

input.button, input.anfragebutton {
background: #315132; color: #fff; padding: 10px 30px;
font-weight: normal; font-size:1.2em;
cursor: pointer;border: none;
float: left; width: auto; border-radius: 0; box-sizing: content-box;
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
}
input.button:hover, input.anfragebutton:hover {background: #363636; color: #fff;}


a.backlink {
float: right;
padding: 8px 20px; margin: 10px 1%;
color: #fff; background: #315132;
}

a.weiterlink  {
display: inline-block;
text-decoration: none;
font-weight:400; text-align: center;
padding: 8px 20px; margin:10px 0;
font-size: 1.1em; background:#315132; min-width: 100px;
color:#fff;border-radius: 20px;
}


a.backlink:hover {
background:#333; color: #fff;
text-decoration: none;
}

a.weiterlink:hover {
background:#333; color: #fff;
text-decoration: none;
}


ul.liste {
list-style-type: none;
}
ul.liste li {
font-weight: bold;
font-size: 100%;
padding-left: 20px;
margin-bottom: 10px;
} 


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: 10px 0; background:#ececec; padding: 10px 1%;
}
#datenschutzfeld input {
    float: left; width: 6%; margin: 10px 0; padding: 0;
}
#datenschutzfeld label {
    float: right; width: 93%; font-size: 0.9em;
}


.formfeld { width:100%; float: left; padding: 2px 0; box-sizing: border-box; }

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

.formfeld { width: 50%; }
.formfeld:nth-child(2n) {
    padding-right: 2%;
}

}

.ganz { width: 100%; float: left; padding-right:0 !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%;}

.datenschutzelement {
    float:left; min-height: 300px;
}

.phe {
    float: left; width: 100%; padding: 40px 20px; box-sizing: border-box; background: #ececec; text-align: center;
}


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

.checkbox {float: left; width: 100%; padding-top: 10px;}
.kontaktformular div.checkbox label {float: none; }
.kontaktformular div.checkbox 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 #363636; border-top:4px solid #315132; border-radius: 50%; width: 40px; height: 40px; animation: spin 1s linear infinite;z-index: 6;}

@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
/*sudo-Slider -----------------*/
.slider {
    display: block; float: left; width: 100%; height: 100%; margin:0; background: url('images/loader.gif') center center no-repeat #fff; 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;
}


#bilder .filter {
    position: absolute; top: 0; left: 0; z-index: 2; width: 100%; height: 100%; background: rgba(21,124,188,0.4); float: left;
    opacity: 0.3;
    -webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
transition: all 0.5s;
}
#bilder:hover .filter {
   opacity: 0.1;
}


.controls a {
    font-family: icons; font-size:2.2em; 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;
}
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: #0b72b5; }
a.nextBtn:hover { opacity: 0.9; color: #fff; text-decoration: none; background: #0b72b5;}

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

.unavseite_ajax {
    float: left; width: 100%; display: flex; flex-wrap: wrap;
}
.umen {
    float: left; width: 31.33%; box-sizing: border-box; background: #eee; min-height:250px; perspective: 1500; margin: 10px 1%; font-weight: 300; cursor: pointer;
}
.umen h2 {
    font-size: 1.3em; text-align: center;
}
.umen h2 img {
    width:70px; height: auto; margin: 20px 0;
}


#suchform {
    float: left; width: 80%; padding: 10px 10%; display: none;
}
#suchform label {
    display: none;
}
#suchform input[type=text] {
    width: 70%; float: left; box-sizing: border-box;
}
#suchform input[type=submit] {
    width: 28%; float: right; background: #315132;border: none; border-radius: 10px; color: #fff; cursor: pointer;  box-sizing: border-box;
}
a.configlink {display: block; font-weight: bold; background: #315132; box-sizing: border-box; padding: 10px 0; width: 100%; margin: 10px 0; text-align: center; border: 1px solid #fff; border-radius: 10px; -moz-border-radius: 10px; -webkit-border-radius: 10px;box-shadow: 0px 0px 3px 0px #666; -moz-box-shadow: 0px 0px 3px 0px #666; -webkit-box-shadow: 0px 0px 3px 0px #666; font-size: 16px; color: #fff;}
a.configlink:hover {color: #fff;  background: #315132; border: 1px solid #000; }


.werbung {
    position: absolute; right: 10px; top: 250px; width:150px;
}
.werbung img {
    height: auto !important;
}
.werbung span {
    font-size: 0.8em; color: #999; display: block; text-align: left;
}

#textfeld img, img {max-width: 100%;height: auto !important;}


#login {
    float: left; width: 100%; max-width: 500px; box-sizing: border-box; padding:10px 20px; background: #eee;
}
#login div {
    float: left; width: 100%; margin: 2px 0;
}
#login label {
   float: left; width: 25%; padding:10px 0; margin-right: 2%;
}
#login input {
    float: left; width: 70%;  box-sizing: border-box;
}
#login input.button {
    padding: 10px 30px !important; max-width:150px; margin-left: 27%;
}



@media only screen and (max-width: 1460px) {
.werbung {
    position: relative; right: auto; top: auto; width:90%; margin: 20px 5%;
}
}


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

#logocontainer { width:40%;margin:55px 0 30px 4%;}
footer {min-width: 960px; }
header > p {
    font-size: 1.0em;
}

#wrap {min-width: 680px;}
header {width: 100%; height: auto; border-bottom: 5px solid #315132; }
#wrap2 {min-width: 680px;padding: 0; position: relative;  }
#content {width: 100%; margin: 0; }
footer {min-width: 680px;}
header > p {  display: none;}

#navcontainer {width: 100%; margin: 0;padding: 0; max-width: 100%; -webkit-transition: none;
-moz-transition: none;
transition: none;}

#bilder { margin: 0; background-size: cover; }

.galerie dl { width: 31.33%; }
.slider div.animationsinfos { bottom: 100px; right: 5%; padding: 10px; font-size: 1.6em; }

#ajpopup { top: 20px; left: 5%; width: 90%; margin: 0;}
}

@media only screen and (max-width: 960px) {
.viertel { width: 48%; }
.dreiviertel {width: 98%}
.umen {width: 48%; }

div#startinfo { font-size: 1.2em;}

footer .kontakt { width:92%;}
}

@media only screen and (max-width: 680px)
{
#wrap {min-width: 320px;}

#logocontainer { width:55%;}
header {width: 100%; min-width: 320px;}
#wrap2 {min-width: 320px; width: 100%; }
#content {min-width: 320px; width: 100%; min-height: 350px;}
#inhalt {width: 100%; padding: 10px 0;}
#textfeld {
float: left;
padding: 0 3%;
width: 94%;
}

.galerie dl { width: 48%;}

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


footer {min-width: 300px; }

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

a.weiterlink:link, a.weiterlink:visited  {font-size: 1.1em;}
a.backlink:link, a.backlink:visited, a.backlink:hover {background-size: 20px auto;}

.halb { width: 98%;}
.drittel { width: 98%; }
.zweidrittel { width: 98%; }
.footcontainer { width:92%; padding: 10px 4%; }

#wkvorschau {margin: 10px;}
#wkvorschau a::before {font-size:1.8em;}
#wkvorschau b { width: 25px; height: 25px; padding: 0; top: -8px; right:-8px;}
ul.unavseite_menue li {width: 100%;}
#login label {width: 100%; padding:10px 0; margin-right: 0;}
#login input { width: 100%;}
#login input.button {margin-left:0;}
#suchform {width: 98%; padding: 10px 1%;}
}
@media only screen and (max-width: 460px) {

#logocontainer { float: left; width:65%;margin:50px 0 30px 4%;}
footer {min-width: 300px; }

.kontaktformular label { width: 100%;}
.kontaktformular p {width: 100%;}


.viertel { width: 98%; }

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

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

div#startinfo { font-size: 1.0em;}

footer .kontakt > div {width: 100%; margin: 0 0 20px;}
.logincontainer #kundenlogin { width: 90%; box-sizing: border-box; }
}

@media only screen and (max-width: 380px)
{ .galerie dl { width: 98%;}  }