/* -------------------------------- 
    Style
-------------------------------- */

html, body {
  height: 100%; 
  width: 100%;
  -ms-text-size-adjust: 100%; 
  -webkit-text-size-adjust: 100%; 
}

* { 
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  color: #2a2a2a;
  font-family: 'Open Sans', sans-serif;
  font-size: 16px;
  font-weight: 400;
  font-style: normal;
  line-height: 1.4;
  background-color: #fff;
  background: #4E72A4;
  background: -webkit-repeating-linear-gradient(155deg, #333, #333 1px, #2882D9 1px, #2882D9 50px);
  background: repeating-linear-gradient(140deg, #426493, #426493 1px, #4E72A4 -1px, #4E72A4 50px);  
  background-attachment: fixed;
}

/* -------------------------------- 
    Global
-------------------------------- */

.wrapper {
  padding: 20px 30px;
}

.container {
  max-width: 1250px;
  margin: 0 auto;
  border: 1px solid #426493;
  background: #e0e0e0;
  padding: 20px;
  height: 100%;
  border-radius: 5px;
}

@media (max-width: 769px) {
.wrapper { padding: 5px 10px; }
.container { padding: 10px; }
}

@media (max-width: 471px) {
.wrapper { padding: 2px }
.container { padding: 0; }
}

h1, h2, h3, h4 { 
  font-family: 'Open Sans', sans-serif;
}

.h2main{
  margin: 10px 0 16px 0;
  line-height: 1.1;
  font-weight: 600;
  font-size: 2.3em;
  letter-spacing: -0.01em;
  font-variant: small-caps;
}

.h2main::after {
  content: "";
  display: block;
  width: 80px;
  height: 4px;
  background: #4E72A4;
  margin-top: 5px;
}

h3 {
  font-weight: 300;
  font-size: 1.4em;
  margin-bottom: 10px;
}

/*
h2 span {
  font-weight: 100;
  display: block;
  font-size: 27px;
  margin-top: 5px;
  margin-bottom: 15px;
  font-family: 'Roboto', sans-serif;
}

h2 span::after {
  content: "";
  display: block;
  width: 50px;
  height: 3px;
  background: #4E72A4;
  margin-top: 4px;
}
*/

/* -------------------------------- 
    Gridsystem
-------------------------------- */

/*
xs max 480px,
x  min 471px,
m  min 769px, 
l  min 952px, 
xl min 1200px
*/

.clearfix:before,
.clearfix:after,
.container:before,
.container:after,
.container-fluid:before,
.container-fluid:after,
.row:before,
.row:after {
  content: " ";
  display: table;
}

.clearfix:after,
.container:after,
.container-fluid:after,
.row:after {
  clear: both;
}
.row {
  width: 100%;
}

.col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12, .col-s-1, .col-s-2, .col-s-3, .col-s-4, .ol-s-5, .ol-s-6, .col-s-7, .col-s-8, .col-s-9, .col-s-10, .col-s-11, .col-s-12, .col-m-1, .col-m-2, .col-m-3, .col-m-4, .col-m-5, .col-m-6, .col-m-7, .col-m-8, .col-m-9, .col-m-10, .col-m-11, .col-m-12, .col-l-1, .col-l-2, .col-l-3, .col-l-4, .col-l-5, .col-l-6, .col-l-7, .col-l-8, .col-l-9, .col-l-10, .col-l-11, .col-l-12, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12 { 
  float: left;
  padding: 0;
  margin: 0;
  position: relative;
  min-height: 1px;
  display: block;
}

@media (max-width: 480px) {
  .col-xs-1 { width: 8.33333333%; }
  .col-xs-2 { width: 16.66666667%; }
  .col-xs-3 { width: 25%; }
  .col-xs-4 { width: 33.33333333%; }
  .col-xs-5 { width: 41.66666667%; }
  .col-xs-6 { width: 50%; }
  .col-xs-7 { width: 58.33333333%; }
  .col-xs-8 { width: 66.66666667%; }
  .col-xs-9 { width: 75%; }
  .col-xs-10 { width: 83.33333333%; }
  .col-xs-11 { width: 91.66666667%; }
  .col-xs-12 { width: 100%; }
}

@media (min-width: 481px) {
  .col-s-1 { width: 8.33333333%; }
  .col-s-2 { width: 16.66666667%; }
  .col-s-3 { width: 25%; }
  .col-s-4 { width: 33.33333333%; }
  .col-s-5 { width: 41.66666667%; }
  .col-s-6 { width: 50%; }
  .col-s-7 { width: 58.33333333%; }
  .col-s-8 { width: 66.66666667%; }
  .col-s-9 { width: 75%; }
  .col-s-10 { width: 83.33333333%; }
  .col-s-11 { width: 91.66666667%; }
  .col-s-12 { width: 100%; }
}

@media (min-width: 768px) {
  .col-m-1 { width: 8.33333333%; }
  .col-m-2 { width: 16.66666667%; }
  .col-m-3 { width: 25%; }
  .col-m-4 { width: 33.33333333%; }
  .col-m-5 { width: 41.66666667%; }
  .col-m-6 { width: 50%; }
  .col-m-7 { width: 58.33333333%; }
  .col-m-8 { width: 66.66666667%; }
  .col-m-9 { width: 75%; }
  .col-m-10 { width: 83.33333333%; }
  .col-m-11 { width: 91.66666667%; }
  .col-m-12 { width: 100%; }
}

@media (min-width: 952px) {
  .col-l-1 { width: 8.33333333%; }
  .col-l-2 { width: 16.66666667%; }
  .col-l-3 { width: 25%; }
  .col-l-4 { width: 33.33333333%; }
  .col-l-5 { width: 41.66666667%; }
  .col-l-6 { width: 50%; }
  .col-l-7 { width: 58.33333333%; }
  .col-l-8 { width: 66.66666667%; }
  .col-l-9 { width: 75%; }
  .col-l-10 { width: 83.33333333%; }
  .col-l-11 { width: 91.66666667%; }
  .col-l-12 { width: 100%; }
}

@media (min-width: 1200px) {
  .col-xl-1 { width: 8.33333333%; }
  .col-xl-2 { width: 16.66666667%; }
  .col-xl-3 { width: 25%; }
  .col-xl-4 { width: 33.33333333%; }
  .col-xl-5 { width: 41.66666667%; }
  .col-xl-6 { width: 50%; }
  .col-xl-7 { width: 58.33333333%; }
  .col-xl-8 { width: 66.66666667%; }
  .col-xl-9 { width: 75%; }
  .col-xl-10 { width: 83.33333333%; }
  .col-xl-11 { width: 91.66666667%; }
  .col-xl-12 { width: 100%; }
}

/* Sichtbarkeit */
@media (max-width: 480px) { .hidden-xs { display: none !important; } }
@media (min-width: 481px) and (max-width: 766px) { .hidden-s { display: none !important; } }
@media (min-width: 768px) and (max-width: 951px) { .hidden-m { display: none !important; } }
@media (min-width: 952px) and (max-width: 1199px) { .hidden-l { display: none !important; } }
@media (min-width: 1200px) { .hidden-xl { display: none !important; } }

.pull-right { float: right !important; }
.pull-left { float: left !important; }


/* -------------------------------- 
Top Titel
-------------------------------- */

.display-large { display: block; }
.display-small { display: none; }

@media only screen and (max-width:800px) {
.display-large { display: none; }
.display-small { display: block; }
}

.title-span-small {
  text-transform: uppercase;
  font-weight: 400;
  font-size: 1.3em;
  letter-spacing: -0.01em;
  margin: 0;
  color: #dbdbdb;
  padding: 10px 10px;
  float: left;
  width: 100%;
  text-align: center;
}

.titel-block {
  background: #1B304E;
}

.titel-block h1 {
  text-transform: uppercase;
  font-weight: 400;
  font-size: 36px;
  letter-spacing: -0.01em;
  margin: 7px 0;
  color: #dbdbdb;
  padding-left: 20px;
}

.titel-block span {
  text-transform: uppercase;
  font-weight: 400;
  font-size: 36px;
  letter-spacing: -0.01em;
  margin: 0;
  padding-right: 20px;
  color: #dbdbdb;
  float: right;
}

@media (max-width:1048px) {
  .titel-block h1 {
  font-size: 32px; }
  .titel-block span {
  font-size: 32px; }
}

@media (max-width:945px) {
  .titel-block h1 {
  font-size: 29px; }
  .titel-block span {
  font-size: 29px; }
}

@media (max-width:860px) {
  .titel-block h1 {
  font-size: 27px; }
  .titel-block span {
  font-size: 27px; }
}

.title-span-xs-1 {
  text-transform: uppercase;
  font-weight: 400;
  font-size: 1.7em;
  letter-spacing: -0.01em;
  margin: 0;
  color: #dbdbdb;
  padding-left: 20px;
  float: left;
}

/* -------------------------------- 
    Cookie Popup
-------------------------------- */
.cookiemeldung {
  width: 100%;
  background: #3A5B89;
  box-shadow: 10px 10px 24px 0px rgba(0, 0, 0, 0);
  display: none;
  position: fixed;
  bottom: 0;
  z-index: 99999;
}

.cookiemeldung__container {
  max-width: 1250px;
  margin: 0 auto;
  padding: 10px;
  position: relative;
  display: block;
  color: #dbdbdb;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-box-pack: justify; 
  -ms-flex-pack: justify; 
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.cookiemeldung__container p {
  padding: 15px;
  float: left;
  margin: 0;
  display: inline-block;
}

.cookiemeldung__container a {
  color: #fff;
  text-decoration: none;
}

.cookiemeldung__container a:hover{
  text-decoration: underline;
}

.cookiemeldung__closebutton {
  background: #04b204;
  border: none;
  display: block;
  border-radius: 5px;
  padding: 10px 22px;
  color: #fff;
  border: 1px solid #176c17;
  float: right;
  text-shadow: 1px 1px #176c17;
}

.cookiemeldung__closebutton:hover {
  background: #0cc40c;
  color: #fff;
}

.cookiemeldung__closebutton:hover {
  cursor: pointer;
}

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

.navigation-top{
  padding-bottom: 4px;
  background: #1b304e;
    /*  border-top: 5px solid rgb(255, 228, 13); */
}
.navigation {
    height: 61px;
    background: #1b304e;
    border-bottom: 5px solid #4182DB; 
}

.brand {
  position: absolute;
  padding-left: 20px;
  float: left;
  line-height: 55px;
  font-size: 1em;
  letter-spacing: 0.2px;
  text-transform: uppercase;
}

.brand a{
  color: #ddd;
  text-decoration: none;
}
.brand a:hover {
  color: #fff;
  text-decoration: none;  
}

.nav-container {
  max-width: 1200px;
  margin: 0 auto;
}

.nav-container a {
  text-decoration: none;
}

nav {
  float: right;
}

nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

nav ul li {
  float: left;
  position: relative;
}

nav ul li a,
nav ul li a:visited {
  display: block;
  padding: 0 14px;
  line-height: 55px;
  background: #1b304e;
  color: #dbdbdb;
  text-decoration: none;
  position: relative;
  z-index: 1; 
  font-size: 1em;
  letter-spacing: 0.2px;
  transition : all 0.3s ease-in-out;
  text-transform: uppercase;
   border-bottom: 6px solid transparent;
}

nav ul li a:hover {
  background: transparent;
}


@media only screen and (min-width:767px) and (max-width:991px) {
 nav ul li a,
 nav ul li a:visited {
 padding: 0 10px;
}
 nav ul li:last-child a{
 margin-right: 20px;
}  
}


nav ul li a:hover,
nav ul li a:focus,
nav ul li a:visited:hover {
  text-decoration: none;
  color: #fff;
}

.aktiva {
-webkit-box-shadow: inset 0px -5px 0px 0px #DBDBDB;
-moz-box-shadow: inset 0px -5px 0px 0px #DBDBDB;
box-shadow: inset 0px -5px 0px 0px #DBDBDB;
}

/* -------------------------------- 
Mobile Navigation Menü
-------------------------------- */

.nav-mobile {
  display: none;
  position: absolute;
  top: 0;
  right: 15px;
  background: #1b304e;
  height: 56px;
  width: 56px;
}

@media only screen and (max-width: 800px) {
  .nav-mobile {
    display: block;
  }
  nav {
    width: 100%;
    padding: 60px 0 15px;
  }
  nav ul {
    display: none;      
  }
  nav ul li {
    float: none; 
    z-index: 899;
  }
  nav ul li a {
    padding: 15px;
    line-height: 20px; }
}

@media screen and (min-width: 800px) {
  .nav-list {
    display: block !important;
  }
}
#nav-toggle {
  position: absolute;
  left: 18px;
  top: 22px;
  cursor: pointer;
  padding: 10px 35px 16px 0px;
}
#nav-toggle span,
#nav-toggle span:before,
#nav-toggle span:after {
  cursor: pointer;
  border-radius: 1px;
  height: 2px;
  width: 36px;
  background: #ffffff;
  position: absolute;
  display: block;
  content: '';
  transition: all 240ms ease-in-out;
}
#nav-toggle span:before {
  top: -10px;
}
#nav-toggle span:after {
  bottom: -10px;
}
#nav-toggle.active span {
  background-color: transparent;
}
#nav-toggle.active span:before, #nav-toggle.active span:after {
  top: 0;
}
#nav-toggle.active span:before {
  transform: rotate(45deg);
}
#nav-toggle.active span:after {
  transform: rotate(-45deg);
}

.pdf-link a {
  color: #4E72A4;
  padding: 2px 8px;
  background: #F5F5F5;
  text-decoration: none;
  border-radius: 5px;
  border: 1px solid #cccccc;
}
.pdf-link a:hover {
  color: #4E72A4;
}

/* -------------------------------- 
Navigation Menü Fixed-Top
-------------------------------- */

.navbar-fixtop {
  position: fixed;
  right: 0;
  left: 0;
  top: 0;
  z-index: 1001;   
  -webkit-box-shadow: 0px 5px 5px -5px rgba(0,0,0,0.75);
  -moz-box-shadow: 0px 5px 5px -5px rgba(0,0,0,0.75);
  box-shadow: 0px 5px 5px -5px rgba(0,0,0,0.75);
  border-bottom: 0px;
  opacity: 1.0;
}

.navstyle-fixed{
  height: 50px;
  transition : all 0.5s ease-in-out;
}

.navstyle-fixed nav ul li a{
  padding: 0 15px;
  line-height: 49px;
  border: 0px;
  transition : all 0.5s ease-in-out;
}

.navstyle-fixed nav ul li a:hover{
  color: #7fb1f5;
  transition : all 0.2s ease-in;
}

.navstyle-fixed .brand {
  line-height: 50px;
}

/* -------------------------------- 
    Bild IMG 
-------------------------------- */

.img-responsive {
  display: block;
  max-width: 100%;
  height: auto;
}

.img-basic {
  border: 1px solid #fff;
  box-shadow: 0 0 3px #888888;
  margin-bottom: 20px;
}


/* -------------------------------- 
Banner 
-------------------------------- */

.banner {
  margin-bottom: 20px;
  position: relative;  
  -webkit-box-shadow: 0px -10px 7px -12px rgba(0,0,0,0.75), 0px 10px 7px -12px rgba(0,0,0,0.75);
  -moz-box-shadow: 0px -10px 7px -12px rgba(0,0,0,0.75), 0px 10px 7px -12px rgba(0,0,0,0.75);
  box-shadow: 0px -10px 7px -12px rgba(0,0,0,0.75), 0px 10px 7px -12px rgba(0,0,0,0.75);
}
.banner img {
  display: block;
}

.banner span {
  font-family: 'Squada One', cursive;
  position: absolute;
  top: 29%;
  left: 20px;
  line-height: 1.0;
  font-size: 3.4em;
  color: #6a6e75;
  font-style: normal;
  font-variant: normal;
  font-weight: 100;
  width: 100%;
}

.banner p {
  position: absolute;
  display: block;
  top: 52%;
  left: 20px;
}

@media (min-width:952px) {
.banner p { width: 45%; }
}
@media (max-width:952px) {
 .banner p { width: 42%; }
}

@media (min-width:769px) and  (max-width:952px) {
  .banner p { top: 54%;}
}

/* -------------------------------- 
Back 2 top
-------------------------------- */

.cd-top {
display : inline-block;
height : 40px;
width : 40px;
position : fixed;
bottom : 40px;
right : 10px;
overflow : hidden;  
text-indent : 100%;
white-space : nowrap; border-radius: 50%;
background : url(../img/cd-top-arrow.svg) center 50% no-repeat #08172C;
visibility : hidden;
opacity : 0;
filter : alpha(opacity=0);
-webkit-transition : opacity 0.3s 0s, visibility 0s 0.3s;
        transition : opacity 0.3s 0s, visibility 0s 0.3s;
}

.cd-top.cd-is-visible {
visibility : visible;
opacity : 0.3;
filter : alpha(opacity=100);
}

@media only screen and (min-width:768px) {
.cd-top {
right : 20px;
bottom : 20px;
}
}
@media only screen and (min-width:1024px) {
.cd-top {
height : 60px;
width : 60px; 
right : 30px;
bottom : 30px;
}
}

/* -------------------------------- 
    Flexbox 
-------------------------------- */

@media (min-width:769px) {
.flex-container {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
}

/* -------------------------------- 
    Cards X3
-------------------------------- */

.block-card:nth-child(1) { padding: 0 20px 20px 0; }
.block-card:nth-child(2) { padding: 0 10px 20px 10px; }
.block-card:nth-child(3) { padding: 0 0 20px 20px; }

@media (max-width: 952px) {
  .block-card:nth-child(1) { padding: 0 10px 20px 0; }
  .block-card:nth-child(2) { padding: 0 0 20px 10px; }
  .block-card:nth-child(3) { padding: 0 0 20px 0; } 
}

@media (max-width: 769px) {
  .block-card:nth-child(1) { padding: 0 10px 10px 0; }
  .block-card:nth-child(2) { padding: 0 0 10px 10px; }
  .block-card:nth-child(3) { padding: 10px 0 20px 0; }
}

@media (max-width: 480px) {
  .block-card:nth-child(1) { padding: 5px 10px; }
  .block-card:nth-child(2) { padding: 5px 10px; }
  .block-card:nth-child(3) { padding: 5px 10px; }
}



.infocard {
  background-color: #000000;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.15);
  color: #f5f5f5;
  margin: 0;
  overflow: hidden;
  position: relative;
  display: block;
  text-align: left;
  width: 100%;
  border: 1px solid #fff;
  box-shadow: 0 0 3px #888888;
}

.infocard * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 0.25s ease;
  transition: all 0.25s ease;
}

.infocard img {
  opacity: 1;
  position: relative;
  vertical-align: top;
}

.figcaption {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1;
}

.infocard h2 {
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
  background-color: rgb(58, 91, 137);
  top: 0;
  font-weight: 500;
  margin: 0;
  padding: 7px 20px;
  position: absolute;
  width: 100%;
  font-size: 1.1em;
  border: 0;
  text-transform: uppercase;
}

.infocard:hover h2,
.infocard.hover h2 {
  -webkit-transform: translateY(-100%);
  transform: translateY(-100%);
}

.infocard p {
  position: absolute;
  width: 90%;
  padding: 20px 20px;
  opacity: 0;
  text-align: left;
  -webkit-transform: translateX(-70%);
  transform: translateX(-70%);
  top: 60px;
  left: 5%;
  font-size: 93%;
  border: 1px solid rgba(208, 208, 208, 0.66);
}

.infocard span {
  position: absolute;
  padding: 4px 15px;
  opacity: 0;
  text-align: right;
  bottom: 15px;
  right: 15px;
  font-style: italic;
  border: 1px solid #fff;
  font-size: 14px;
  border-radius: 5px;
}

.infocard:hover span,
.infocard.hover span {
  opacity: 1;
  transition: all 0.25s ease;
  -webkit-transition-delay: 0.8s;
  transition-delay: 0.8s;
}

.infocard:hover p,
.infocard.hover p {
  opacity: 1;
  -webkit-transform: translateX(0%);
  transform: translateX(0%);
  transition: all 0.25s ease;
  -webkit-transition-delay: 0.41s;
  transition-delay: 0.41s;
}

.infocard i {
  position: absolute;
  top: 50%;
  left: 50%;
  font-size: 75px;
  text-shadow: 1px 1px #5d5d5d;
  font-weight: 100;
  -webkit-transform: translate(-50%, -50%) scale(1);
  transform: translate(-50%, -50%) scale(1);
  font-style: normal;
}

.infocard .hover {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  align-items: center;
  background: rgba(58, 91, 137, 0.92);
  display: flex;
  font-size: 65px;
  justify-content: center;
  opacity: 0; 
}

.infocard a {
  left: 0;
  bottom: 0;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
}

.infocard:hover .hover,
.infocard.hover .hover {
  opacity: 1;
}

.infocard h3 {
  -webkit-transform: translateX(-100%);
  transform: translateX(-100%);
  top: 20px;
  margin: 0;
  padding: 7px 15px;
  position: absolute;
  width: 100%;
  border: 0;
  font-size: 1.5em;
  margin-bottom: 10px; 
  font-variant: small-caps;
  font-weight: 500;

}

.infocard:hover h3,
.infocard.hover h3 {
  -webkit-transform: translateX(0%);
  transform: translateX(0%);
  transition: all 0.25s ease;
  -webkit-transition-delay: 0.21s;
  transition-delay: 0.21s;
}

.infocard:hover i,
.infocard.hover i {
  -webkit-transform: translate(-50%, -50%) scale(0.1);
  transform: translate(-50%, -50%) scale(0.1);
  opacity: 0;
}

/* -------------------------------- 
    Normdiv Div-Style
-------------------------------- */

.normdiv {
  background: #fff;
  padding: 20px; 
  margin-bottom: 5px;
  border: 1px solid #d4d4d1;
}

@media (max-width: 480px) {
.normdiv { padding: 10px; }  
}

.normimg {
  border: 1px solid #fff;
  box-shadow: 0 0 3px #888888;
  margin: 20px 0 20px 20px; 
  overflow: hidden;
}

@media (max-width: 952px) {
.normimg { margin: 20px 0 15px 15px; }  
}

@media (max-width: 769px) {
.normimg { margin: 0 0 10px 0; }  
}

@media (max-width: 471px) {
.normimg { margin: 0 0 15px 0; }  
}

.normdiv:hover * {
 transition: all 0.4s ease-in-out;
}

.normimg img:hover {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transform: scale(1.20) rotate(0.5deg); /* Safari and Chrome */
  -moz-transform:scale(1.10) rotate(0.5deg); /* Firefox */
  -ms-transform:scale(1.10) rotate(0.5deg); /* IE 9 */
  -o-transform: scale(1.10) rotate(0.5deg); /* Opera */
  transform: scale(1.10) rotate(0.5deg);
}

.normdiv a {
  color: inherit;
}

/* -------------------------------- 
    Card X4 4er Icon-Cards
-------------------------------- */

.card-container {
  padding: 0;
  margin: 0;
  list-style: none;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-flow: row wrap;
  justify-content: space-between;
}
.card-item {
  background: #fff;
  padding: 20px; 
  width: calc(25% - 5px);
  border: 1px solid #d4d4d1;
  text-align: center;
}

  .card-item:nth-child(1) { margin-right: 5px; }
  .card-item:nth-child(2) { margin-right: 5px; }
  .card-item:nth-child(3) { margin-right: 5px; }

@media only screen and (max-width:980px) { 
  .card-item {  padding: 20px;  width: calc(50% - 5px); }
  .card-item:nth-child(1) { margin: 0 5px 10px 0; }
  .card-item:nth-child(2) { margin: 0 0 10px 5px; }
  .card-item:nth-child(3) { margin: 0 5px 10px 0; }
  .card-item:nth-child(4) { margin: 0 0 10px 5px; }
}

@media only screen and (max-width:680px) { 
  .card-item { padding: 10px; width: 100%; }
  .card-item:nth-child(1) { margin-right: 0; margin-bottom: 5px; }
  .card-item:nth-child(2) { margin-right: 0; margin-bottom: 5px; }
  .card-item:nth-child(3) { margin-right: 0; margin-bottom: 5px; }
  .card-item:nth-child(4) { margin-right: 0; margin-bottom: 5px; }
  .card-item:hover { -webkit-box-shadow: none; -moz-box-shadow: none; box-shadow: none; }
}

@media only screen and (max-width:480px) { 
.card-item p { text-align: left; }
}

.h2icon {
  margin: 0 0 20px 0;
  text-transform: uppercase;
  font-weight: 400;
  font-size: 1.6em;
  letter-spacing: -0.01em;
}

.card-item h2::after {
  content: "";
  display: block;
  width: 30px;
  height: 4px;
  margin: 0 auto;
  background: #4E72A4;
  transition: all 0.3s ease-in-out;
}

.card-item:hover h2::after {
  width: 100px;
}

.card-item:hover {
 box-shadow: 0 0 3px #939393;
}


.icon1 { font-size: 70px!important; }
.icon2 { font-size: 70px!important; }
.icon3 { font-size: 70px!important; }
.icon4 { font-size: 70px!important; line-height: 115px; }

.icon {
  width: 100%;
  margin: 0 auto;
  display: block;
  text-align: center;
  overflow: hidden;
  position: relative;
  color: #ededed;
}

.icon i {
  padding: 10px;
  width: 115px;
  height: 115px;
  line-height: 90px;
  text-align: center;
  background: #3A5B89;
  border-radius: 50%;
  margin-bottom: 10px;
  /* transition: all 0.3s ease-in-out; */
}

@media only screen and (max-width:680px) { 
.icon i { 
  border-radius: 0%; 
  margin-bottom: 10px; 
  width: 100%; 
  font-size: 50px!important;
  height: 65px;
  line-height: 45px;
}
}


/* -------------------------------- 
    Suche
-------------------------------- */

.form_plz, .name_plz {
  margin-bottom: 2px; 
  height: 50px;
}

.suchfeld {
  height: 500px;
}

@media (max-width:952px){ .suchfeld { height: auto; } }

label {
  margin-bottom: 30px;
}

.basic img {
  border: 1px solid #fff;
  box-shadow: 0 0 3px #888888;
  margin-bottom: 20px;
}

.suchfeld h2 {
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0 0 20px 0;
}

.suchfeld h2::after {
  content: "";
  display: block;
  width: 80px;
  height: 4px;
  background: #4E72A4;
  margin-top: 5px;
}

.suchfeld input {
  background: #F5F5F5;
  float: right;
  border: 1px solid #acacac!important;
  padding-left: 20px;
  border-top-left-radius: 10px;
  border-bottom-right-radius: 10px;
  font-size: 120%;
  font-weight: 400;
  height: 40px;
  width: 100%;
  margin-top: 5px;
  margin-bottom: 5px;
}


@media (min-width:520px) and (max-width:952px) { 
  .form_plz { width: 48%;  display: inline-block; } 
  .name_plz  { width: 48%; float: right; display: inline-block; } 
  .suche_beschreibung { width: 100%; }
  .suchfeld input { border-radius: 5px; }
}

.suchfeld input:focus {
  box-shadow: 0 0 4px rgba(65, 130, 219, 0.50);
  float: right;
  color: #4182DB;
  border: 1px solid #4182DB;
}
.such-icon-lg {
  font-size: 150%;
  float: left;
  padding: 8px 8px 0 0;
}

.modal {
  width: 60%;
  left: 20%;
  right: 20%;
  background: #F5F5F5;
  box-shadow: 0 0 3px #333;
  z-index: 9999;
  position: fixed;
  top: 10%;
  display: none;
  border-top-right-radius: 15px;
  border-bottom-left-radius: 15px;
  padding: 15px;
  border: 16px solid #4E72A4; 
}

.modal-container {
  background: #fff;
  width: 100%;
  padding: 15px;
  height: 100%;
}
.modal p {
padding: 0 8px;
  display: inline;
}
.blur {
  width: 100%;
  height: 100%;
  background: #222;
  opacity: 0.8;
  position: fixed;
  top: 0;
  left: 0;
  display: none;
}
.modal_close {
  background: #3A5B89;
  padding: 7px 12px;
  color: #fff;
  float: right;
  border: 1px solid #333;
  border-radius: 5px;
}
.modal_close:hover {
  background: #436696;
  cursor: pointer;
}
      
.betrieb {
  border-bottom: dotted 1px rgba(245, 245, 245, 0.80);
  padding: 10px 20px;
  margin: 0;
  transition: all 0.3s;
  cursor: pointer;
  background: red;
}

.betrieb p {
  margin-right: 7px;
  display: inline;
  font-weight: 700;
  color: #555555;
}
.betrieb:hover p {
  border-bottom: 2px solid #4182DB;
}
.betrieb span {
  font-weight: 100;
  color: #505050;
  padding: 0 2px;
}

.betrieb:nth-child(even) {
  background-color: #d8d8d8;
}
.betrieb:nth-child(odd) {
  background-color: #e8e8e8;
}

.ergebnis {
  height: 500px;
  display: block;
  overflow-y: scroll;
  position: relative;
}

.ergebnis-container {
  background-image: url(/img/autowerkstatt-suche.jpg);
  background-size: cover;
  overflow: hidden;
  height: 500px;
  border: 1px solid #d4d4d1;
}

@media (max-width:952px) { .ergebnis { border: 5px solid #fff; margin-top: 10px; } }

.ergebnis-hover {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  opacity: 0;
  z-index: 1;
  transition : all 0.3s ease-in-out;
  overflow: hidden;
  background: -moz-linear-gradient(top,  rgba(255,255,255,0) 60%, rgba(58,91,137,1) 100%);
  background: -webkit-linear-gradient(top,  rgba(255,255,255,0) 60%,rgba(58,91,137,1) 100%);
  background: linear-gradient(to bottom,  rgba(255,255,255,0) 60%,rgba(58,91,137,1) 100%);
  -webkit-transform: translateY(-20%);
  transform: translateY(-20%);
}

.ergebnis-hover span {
  position: absolute;
  bottom: 10px;
  width: 100%;
  padding: 5px 20px;
  text-align: center;
  text-transform: uppercase;
  font-size: 1.1em;
  color: #fff;
  display: block;
}

.ergebnis:hover .ergebnis-hover {
  opacity: 1;
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
}

.name {
  margin-bottom: 10px;
}

.name::after {
  display: block;
  content: "";
  width: 80px;
  height: 4px;
  background: #4E72A4;
  margin: 2px 0;
}


.adresse-popup {
  background: #fff;
  padding: 15px;
  width: 50%;
}
.beschriftung-popup {
  text-align: right;
}

.lightbox {
	/** Default lightbox to hidden */
	display: none;
	/** Position and style */
	position: fixed;
	z-index: 1002;
	width: 100%;
	height: 100%;
	text-align: center;
	top: 0;
	left: 0;
	background: rgba(0,0,0,0.85);
}

.lightbox img {
  /** Pad the lightbox image */
  max-width: 90%;
  max-height: 80%;
  margin-top: 10%;
  border: 1px solid #efefef;
  box-shadow: 0 0 15px #333;
}
.lightbox:target {
	/** Remove default browser outline */
	outline: none;
	/** Unhide lightbox **/
	display: block;
}


/* -------------------------------- 
    Karten Suche
-------------------------------- */

.basic {
  background: #fff;
  padding: 20px;
  margin-right: 20px;
  overflow: hidden;
  border: 1px solid #d4d4d1;
}

@media (max-width:952px){ .basic {padding: 20px; margin-right: 0;} }

.basic-l {
  background: #fff;
  padding: 20px;
  overflow: hidden;
  margin-top: 20px;
  border: 1px solid #d4d4d1;
}

.basic-r {
  background: #fff;
  padding: 20px;
  overflow: hidden;
  margin-top: 20px;
  overflow: hidden;
  border: 1px solid #d4d4d1;
}

@media (max-width: 952px) { .basic-r { margin-top: 0; } }
@media (max-width: 480px) { .basic, .basic-r, .basic-l { padding: 10px; } }



.karte-col-l {
  margin-top: 20px;
}
.kartensuche {
  overflow: hidden;
}

.kartenlink {
  position: relative;
}
.kartenlink img {
  display: block;
    border: 1px solid #fff;
  box-shadow: 0 0 3px #888888;
}
.kartenlink i {
  position: absolute;
  bottom: 0px;
  left: 0;
  top: 0;
  right: 0;
  color: rgba(255, 255, 255, 0.50);
  text-align: center;
  font-size: 5em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.kartenlink:hover i {
  color: rgba(255, 255, 255, 0.80);
}

/* -------------------------------- 
Google Map
-------------------------------- */

.karte-container {
  margin-top: 20px;  
}

.karte {
  width: 100%;
  /* height: 50vh; */
  height: 500px
}


/* -------------------------------- 
    Video
-------------------------------- */

.responsive-video {
  max-width: 100%;  
  height: auto;  
  margin-top: 20px;
  margin-left: 20px;
  margin-right: 20px;
}

/* -------------------------------- 
    Innung-Aktuell
-------------------------------- */

.news {
  background: #fff;
  padding: 20px;
  margin-right: 20px;
  overflow: hidden;
  border: 1px solid #d4d4d1;
  width: 100%;
}

@media (max-width:952px) { .news { width: 100%; margin-right: 0; margin-bottom: 10px; padding: 10px; } }

.news h2 {
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0 0 20px 0;
}

.news h2::after {
  content: "";
  display: block;
  width: 80px;
  height: 4px;
  background: #4E72A4;
  margin-top: 5px;
}

.news img {
  border: 1px solid #fff;
  box-shadow: 0 0 3px #888888;
  margin-bottom: 20px;
}

.termine {
  border: 2px solid #3A5B89;
  padding: 15px;
  color: #3A5B89;
  margin: 10px 0;
  display: block
}

.termine-neu {
  border: 2px solid #5e835e;
  padding: 15px;
  color: #5e835e;
  background: #f9fff9;
  margin: 10px 0;
  display: block
}

.termine h3,
.termine-neu h3 {
  margin: 0!important;
  letter-spacing: -1px;
  font-weight: 900!important;
}

/* -------------------------------- 
    TabNav Info Innung aktuell
-------------------------------- */

.clear{
    clear:both;
}

.tabs > li{
  float: left; 
  display:inline-block;
  margin-right: 2px;
  cursor:pointer;
  padding: 13px 20px;
  text-transform: uppercase;
  font-size: 1.1em;
  font-weight: 500;
  line-height: 18px;
}

@media (max-width:500px) {
  .tabs > li { width: 100%; line-height: 28px; }
} 
  
.tabs {
  margin: 0;
  background-color: #3A5B89;
}

.tabs > li {
  background: #3A5B89;
  color: #dbdbdb;
  border-left: 1px solid transparent;
  border-right: 1px solid transparent;
}

.tabs > li:hover {
  background: #4E72A4;
}

.tabs > .current,
.tabs > .current:hover {
  color: #dbdbdb;
  cursor: default;
  background-color: #4182DB;
  border-left: 1px solid #ddd;
  border-right: 1px solid #ddd;
}

.box{
  display:none;
  padding: 20px;
}

.box h3{
  text-align: left!important;
}

@media (max-width:471px) { .box { padding: 10px; } }

.box.visible{
  display:block;
}

.section {
  background: #fff;
  overflow: hidden;
  min-height: 500px;
  width: 100%;
  border: 1px solid #d4d4d1;
}

.section h2 {
  font-size: 120%;
  background: #ffffff;
  background: -moz-linear-gradient(top,  #ffffff 0%, #f2f2f2 100%); 
  background: -webkit-linear-gradient(top,  #ffffff 0%,#f2f2f2 100%); 
  background: linear-gradient(to bottom,  #ffffff 0%,#f2f2f2 100%); 
  border: 0;
  display: inline-block;
  width: 100%;
  text-transform: uppercase;
  font-weight: 400;
  padding: 10px 10px 10px 15px;
  margin: 20px 0 8px 0;
  font-variant: normal;
  -webkit-box-shadow: 0px 6px 4px -6px rgba(0,0,0,0.55);
  -moz-box-shadow: 0px 6px 4px -6px rgba(0,0,0,0.55);
  box-shadow: 0px 6px 4px -6px rgba(0,0,0,0.55);
}

.section h2::before {
  content: '\25ba';
  padding-left: 0.5em;
  margin-right: 8px;
  color: #4182DB;
}

@media (max-width:631px) { 
.section h2 { 
  background: #fff; 
  color: #333; 
  font-size: 17px; 
  text-align: center; 
  font-weight: 600; 
  }
.section h2::before { 
  content: ""; 
  margin-right: 0; 
  padding-left: 0; 
  }
}

.section span {
  color: #4182DB;
}

.section span::before {
  content: "|";  
}

@media (max-width:631px) { 
.section span { 
  width: 100%;
  text-align: center;
  display: block; }
.section span::before {
  content: "";  
}
}

.img-vorschau {
  overflow: hidden;
  margin-top: 20px;
  margin-right: 20px;
  margin-bottom: 10px;
  border: 1px solid #fff;
  box-shadow: 0 0 3px #888888;
} 

.img-vorschau * {
  transition: all 0.4s ease-in-out;
}

.img-vorschau:hover img {
  float: left;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transform:scale(1.20) rotate(0.5deg); /* Safari and Chrome */
  -moz-transform:scale(1.10) rotate(0.5deg); /* Firefox */
  -ms-transform:scale(1.10) rotate(0.5deg); /* IE 9 */
  -o-transform: scale(1.10) rotate(0.5deg); /* Opera */
  transform: scale(1.10) rotate(0.5deg);
}


/* -------------------------------- 
    Gala Show / Hide
-------------------------------- */

.hidden { 
  display: none;   
}

.unhidden { 
  display: block; 
  margin-top: 0;   
}

.buttons-anzeige {
  float: right;
  margin-bottom: 20px;
}

.buttons-anzeige a { 
  color: #3A5B89;
  border: 1px solid #3A5B89;
  padding: 5px 10px;
  border-radius: 3px;
  text-decoration: none;
  min-width: 180px;
  text-align: center;
  display: block;
}

.buttons-anzeige a:hover { 
  cursor: pointer;
  text-decoration: none;
  color: #ff3b00;
  border: 1px solid #ff3b00;
}


/* -------------------------------- 
    TabNav Info Lightbox
-------------------------------- */

.lb {
  display: none;
  position: fixed!important;
  z-index: 999;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: rgba(0,0,0,0.8);
  text-align:center; 
}

.lb img {
  max-width: 90%;
  max-height: 80%;
  margin-bottom: 2%;
}

.lb:target {
  outline: none;
  
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

a.lb:hover { cursor:zoom-out; }
.lightbox-item img:hover { cursor:zoom-in; }

.lightbox-gala-con {
  margin: 20px -5px 20px -5px;
  max-height: 250px;
  max-height: 270px;
  overflow-y: scroll;
}

.lightbox-gala-con-ns {
  margin: 20px 0 20px 0;  
  margin: 0 -5px;
}

.lightbox-item {
  padding: 5px;
}

/* -------------------------------- 
    Jobs
-------------------------------- */

.jobslg {
  border: 1px solid #d4d4d1;
  position: relative;
  overflow: hidden;
  background: #ffffff;
}

.jobslg img {
  display: block;
}

.jobslg-hover {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  opacity: 0;
  z-index: 1;
  transition : all 0.3s ease-in-out;
  background: -moz-linear-gradient(top,  rgba(255,255,255,0) 60%, rgba(58,91,137,1) 100%);
  background: -webkit-linear-gradient(top,  rgba(255,255,255,0) 60%,rgba(58,91,137,1) 100%);
  background: linear-gradient(to bottom,  rgba(255,255,255,0) 60%,rgba(58,91,137,1) 100%);
  -webkit-transform: translateY(-20%);
  transform: translateY(-20%);
}

.jobslg-hover span {
  position: absolute;
  bottom: 10px;
  width: 100%;
  padding: 5px 20px;
  text-align: center;
  text-transform: uppercase;
  font-size: 1.1em;
  color: #fff;
  display: block;
}

.jobslg:hover .jobslg-hover {
  opacity: 1;
  -webkit-transform: translateY(1%);
  transform: translateY(1%);
}

.jobssm {
  background: #fff;
  padding: 20px;
  position: relative;
  margin-left: 20px;
  border: 1px solid #d4d4d1;
}

.stellenangebote {
  background: #fff;
  padding: 20px;
  margin-top: 20px;
  border: 1px solid #d4d4d1;
}

@media (max-width:769px)  {
.jobssm { padding: 10px; margin-left: 0; margin-top: 5px; }
.stellenangebote { padding: 10px; }
}

/* -------------------------------- 
    Vorstand
-------------------------------- */

.profil-content {
  background: #fff;
  padding: 20px;
  border: 1px solid #d4d4d1;
  border-radius: 7px;
  border: 2px solid #bababa;
}

@media (max-width:480px) { 
.profil-content { width: 100%; margin: 10px 0; padding: 10px; }
.profil-row { margin: 0; }
}

@media (min-width:481px) { 
.profil-content { width: calc(50% - 10px);  margin: 0 5px 10px 5px; float: left; } 
.profil-row  { margin: -5px; }
.profil-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  }
}

@media (min-width:850px) { 
.profil-content { width: calc(33.3333333% - 20px); padding: 20px; margin: 0 10px 20px 10px; }
.profil-row { margin-right: -10px; margin-left: -10px; }
}

@media (min-width:1150px) { 
.profil-content { width: calc(25% - 20px); margin: 0 10px 20px 10px; }
}

.profil-content:hover {
  box-shadow: 0 0 3px #a5a5a5;
}

.profil-content i {
  margin-right: 8px;
}

.profil-content img {
  width: 100%;
  margin: 0 auto;
  border-radius: 7px;
  border: 1px solid #cbcbcb;
}

.profil-bild-con {
  padding: 0 0px;  
}

.profil-bild {
  position: relative;;
  margin: 0 auto;
}

.img-sw {
  position: absolute;
  top: 0;
  opacity: 0;
}

.profil-content h2 {
  font-size: 1.1em;
  font-weight: 400;
  padding: 0 7px;
  margin: 0 0 15px 0;
  text-align: center;
  text-transform: uppercase;
}

.profil-content  * {
  transition: all 0.3s ease-in-out;
}

.profil-content h2::after {
  content: "";
  display: block;
  width: 33px;
  margin-top: 2px;
  height: 3px;
  margin-left: auto;
  margin-right: auto;
  background: #3A5B89;
  transition: all 0.3s ease-in-out;
}

.profil-content:nth-child(1):hover h2::after{ width: 100px; background: #ff6615; }
.profil-content:nth-child(2):hover h2::after{ width: 100px; background: #ff6615; }
.profil-content:nth-child(3):hover h2::after{ width: 100px; background: #ff6615; }
.profil-content:nth-child(4):hover h2::after{ width: 100px; background: #ff6615; }
.profil-content:nth-child(5):hover h2::after{ width: 100px; background: #ff6615; }
.profil-content:nth-child(6):hover h2::after{ width: 100px; background: #ff6615; }
.profil-content:nth-child(7):hover h2::after{ width: 100px; background: #ff6615; }
.profil-content:nth-child(8):hover h2::after{ width: 100px; background: #ff6615; }
.profil-content:nth-child(9):hover h2::after{ width: 100px; background: #ff6615; }

.profil-content:nth-child(1):hover .img-sw { opacity: 1; z-index: 1; }
.profil-content:nth-child(2):hover .img-sw { opacity: 1; z-index: 1; }
.profil-content:nth-child(3):hover .img-sw { opacity: 1; z-index: 1; }
.profil-content:nth-child(4):hover .img-sw { opacity: 1; z-index: 1; }
.profil-content:nth-child(5):hover .img-sw { opacity: 1; z-index: 1; }
.profil-content:nth-child(6):hover .img-sw { opacity: 1; z-index: 1; }
.profil-content:nth-child(7):hover .img-sw { opacity: 1; z-index: 1; }
.profil-content:nth-child(8):hover .img-sw { opacity: 1; z-index: 1; }
.profil-content:nth-child(9):hover .img-sw { opacity: 1; z-index: 1; }


.profil-kontakt {
  border-top: 1px dotted #ddd;
}

.profil-kontakt a {
  color: #4E72A4;
  text-decoration: none;
}

.profil-kontakt a:hover {
 color: #ff840a;
}

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

.kontaktformular-container  {
  background: #fff;
  padding: 20px;
  border: 1px solid #d4d4d1;
}

@media (max-width:480px) { .kontaktformular-container  { padding: 10px; } }

.kontaktformular-container h2 {
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0 0 20px 0;
}

.kontaktformular-container h2::after {
  content: "";
  display: block;
  width: 80px;
  height: 4px;
  background: #4E72A4;
  margin-top: 5px;
}

.labelx2:nth-child(1) { padding: 5px 10px 5px 0; } /* Label Container */
.labelx2:nth-child(2) { padding: 5px 0 5px 10px; } /* Label Container */

.kontaktformular label {
  color: #333;
  font-size: 90%;
}

#vorname, #nachname, #email, #telefon {  /* Labels */
  background: #fff;
  padding: 7px 20px;
  border-radius: 2px;
  border: 2px solid #d4d4d4;
  box-shadow: none;
  width: 100%;
}

@media (max-width:952px) {
.labelx2:nth-child(1) { padding: 0 10px 0 0; width: 50%; } 
.labelx2:nth-child(2) { padding: 0 10px 0 0; width: 50%; } 
}
@media (max-width:569px) {
.labelx2:nth-child(1) { padding: 0; width: 100%; } 
.labelx2:nth-child(2) { padding: 0; width: 100%; } 
}


#vorname:active, #nachname:active, #email:active, #telefon:focus, #vorname:focus, #nachname:focus, #email:focus, #telefon:focus {
  border: 2px solid rgba(65,129,219,1);
}

.kontaktformular input::-webkit-input-placeholder { /* Chrome/Opera/Safari */
  color: #333; font-style: italic; font-weight: 100; }

.kontaktformular input::-moz-placeholder { /* Firefox 19+ */
  color: #333; font-style: italic; font-weight: 100; }

.kontaktformular input:-ms-input-placeholder { /* IE 10+ */
  color: #333; font-style: italic; font-weight: 100; }

.kontaktformular input:-moz-placeholder { /* Firefox 18- */
  color: #333; font-style: italic; font-weight: 100; }


.kontaktformular textarea {
  background: #fff;
  padding: 7px 20px;
  border-radius: 2px;
  border: 2px solid #d4d4d4;
  box-shadow: none;
  width: 100%;
}

.kontaktformular textarea:active,.kontaktformular textarea:focus {
  border: 2px solid rgba(65,129,219,1);
}

.absenden-hinweis {
  font-size: 80%;
  color: #919191;
}

.bnt_senden {
  width: auto;
  float: right;
  color: #dbdbdb;
  padding: 7px 15px;
  background: #3A5B89;
  border: 1px solid #646464;
}

.bnt_senden:hover {
  cursor: pointer;
  background-color: #4182DB;
  color: #fff;
}

.kontaktformular a {
  color: #3A5B89;
}

.kontakt-daten ul li {
  list-style: none;
}

/* Kontakt-Daten */
.kontakt-daten {
  background: #fff;
  padding: 20px;
  margin-left: 10px;
  width: 100%;
}

@media (max-width:480px) { .kontakt-daten  { padding: 10px;  margin: 10px 0 10px 0; } }
@media (max-width:952px) { .kontakt-daten  { padding: 10px;  margin: 10px 0 10px 0; } }

.kontakt-daten h2 {
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0 0 20px 0;
}

.kontakt-daten h2::after {
  content: "";
  display: block;
  width: 80px;
  height: 4px;
  background: #4E72A4;
  margin-top: 5px;
}


/* -------------------------------- 
    rechtliches
-------------------------------- */

.rechtliches {
  background: #fff;
  padding: 20px;
}

.rechtliches hr { 
  border: 0; 
  height: 1px; 
  background: #e0e0e0; 
  margin: 25px 15px;
}

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

footer {
  padding-top: 4px;
  background-color: #1B304E;
  color: #dbdbdb;
}

footer span {
  font-style: italic;
  font-size: 80%;
}

.footer-container {
  width: 100%;
  min-height: 220px;
  border-top: 5px solid #4182DB;
}

.footer-content  {
  width: 100%;
  text-align: center;
  max-width: 1250px;
  margin: 0 auto;
  padding: 20px;
}

.footer-content a {
  color: #dbdbdb;
  text-decoration: none;
  padding: 5px 10px;
  margin: 0 6px; 
  text-transform: uppercase;
}

@media (max-width: 769px) {
  .footer-content a { margin: 20px 5px; display: block; }
}

.footer-content a:hover {
  text-decoration: underline;
}

footer hr {
  margin: 20px 0;
  border: 0; 
  height: 1px; 
  background: #333; 
  background-image: 
  linear-gradient(to right, #1B304E, #4182DB, #1B304E);
}

/* -------------------------------- 
    Error
-------------------------------- */

.container-error {
  max-width: 1250px;
  margin: 60px auto;
  height: 100%;
}

.error404 {
  width: 100%;
  padding: 20px;
  background: #E0E0E0;
  text-align: center;
}

.error404 div {
  width: 100%;
  padding: 20px;
  background: #ffc2c2;
  border: 1px solid #fff;
}

.error404 span {
  font-size: 50px;
  color: #c63030;
}

.error404 a {
  text-decoration: none;
  padding: 6px 25px 8px 25px;
  background: #4E72A4;
  color: #fff;
  border-radius: 5px;
  margin: 20px auto 20px auto;
  display: block;
  width: 200px;
}

.error404 p {
  color: #C63030;
}

.error404 h1{
  text-transform: uppercase;
  font-weight: 600;
  background: #1B304E;
  padding: 20px 10px; 
  color: #dbdbdb;
  font-size: 25px;
}

.error404 h2{
  margin: 10px 0 16px 0;
  line-height: 1.1;
  font-weight: 600;
  font-size: 2.0em;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: #C63030;
}

.error404 h2::after {
  content: "";
  display: block;
  width: 80px;
  height: 4px;
  margin-left: auto;
  margin-right: auto;
  background: #C63030;
  margin-top: 5px;
}

