@import url("https://fonts.verwaltungsportal.de/import/?family=Work+Sans:300,400,600,700");
body {
   font-family: "Work Sans", sans-serif;
   color: #665a5a;
   background: #ffffff;
   font-weight: 400;
   font-size: 1rem;
   /* 1rem = 16px */
   line-height: 1.5;
}

@media (min-width: 768px) {
   body {
      font-size: 1.15rem;
   }
}

@media (min-width: 992px) {
   body {
      font-size: 1.25rem;
   }
}

a {
   color: #01487a;
}

a:hover,
a:focus {
   color: #01487a;
   text-decoration: underline;
}

b,
strong {
   font-weight: 600;
}

/* ----------------------------------------------- logo ----------------------------------------------- */

#logo {
   display: inline-block;
}

#logo img {
   display: block;
}

@media (max-width: 991px) {
   #logo img {
      max-width: 210px;
      width: 100%;
   }
   #logo {
      padding: 20px;
   }
}

/* --------------------------------------------- quicklinks ---------------------------------------------- */

@media (min-width: 992px) {
   #quickLinks {
      margin-right: 35px;
   }
}

@media (min-width: 1200px) {
   #quickLinks {
      margin-right: 52px;
   }
}

#quickLinks a {
   font-size: 1rem;
   text-transform: uppercase;
   color: #b29d9d;
   text-decoration: none;
   display: inline-block;
}

#quickLinks a[title*="Startseite"]::before,
#quickLinks a[title*="Start"]::before,
#quickLinks a[title*="Home"]::before {
   content: "\2302";
   font-family: "Arial", sans-serif;
   margin-right: 3px;
}

#quickLinks a:hover,
#quickLinks a:focus {
   color: #665a5a;
}

#quickLinks li + li {
   margin-left: 20px;
}

@media (min-width: 1200px) {
   #quickLinks li + li {
      margin-left: 26px;
   }
}

/* --------------------------------------- navigation --------------------------------------- */

/* Navigation Desktop */

@media (min-width: 992px) {
   #burgerButtonInner2,
   #burgerButton:after,
   #burgerButtonInner {
      position: absolute;
      background: #f3ba00;
      width: 30px;
      height: 4px;
      left: 10px;
      -webkit-transition: transform 200ms linear, opacity 200ms linear;
      -moz-transition: transform 200ms linear, opacity 200ms linear;
      -ms-transition: transform 200ms linear, opacity 200ms linear;
      -o-transition: transform 200ms linear, opacity 200ms linear;
      transition: transform 200ms linear, opacity 200ms linear;
   }

   #burgerButton {
      font-size: 0;
      border: none !important;
      position: relative;
      z-index: 1002;
      display: block;
      width: 49px;
      height: 58px;
      cursor: pointer;
      background: #ffffff;
   }

   #burgerButton {
      margin: 0 0 0 20px;
      height: 38px;
   }
   #burgerButton::before {
      content: "MENÜ";
      font-size: 30px;
      position: absolute;
      left: 52px;
      top: 6px;
      color: #01487a;
      font-weight: 700;
      line-height: 1;
   }

   #burgerButton[aria-expanded="true"] #burgerButtonInner2 {
      opacity: 0;
   }

   #burgerButton[aria-expanded="true"] #burgerButtonInner {
      -webkit-transform: rotate(-45deg) translate(-7px, 8px);
      transform: rotate(-45deg) translate(-7px, 8px);
   }

   #burgerButton[aria-expanded="true"]::after {
      -webkit-transform: rotate(45deg) translate(-5px, -6px);
      transform: rotate(45deg) translate(-5px, -6px);
   }

   #burgerButtonInner {
      top: 11px;
   }

   #burgerButtonInner2 {
      top: 20px;
   }

   #burgerButton:after {
      top: 29px;
      content: "";
      display: block;
   }
}

/* burgermenu for tablet */

@media (max-width: 991px) {
   #burgerButton {
      font-size: 0;
      border: none !important;
      position: fixed;
      z-index: 1002;
      display: block;
      width: 54px;
      height: 45px;
      border-radius: 4px;
      cursor: pointer;
      background-color: #ffffff;
      padding: 3px;
      -webkit-box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.15);
      box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.15);
      right: 15px;
      top: 15px;
   }

   #burgerButton:before,
   #burgerButton:after,
   #burgerButtonInner {
      background-color: #f3ba00;
      border-radius: 2px;
      position: absolute;
      width: 40px;
      height: 3px;
      left: 7px;
      -webkit-transition: transform 200ms linear, opacity 200ms linear;
      -moz-transition: transform 200ms linear, opacity 200ms linear;
      -ms-transition: transform 200ms linear, opacity 200ms linear;
      -o-transition: transform 200ms linear, opacity 200ms linear;
      transition: transform 200ms linear, opacity 200ms linear;
   }

   #burgerButton[aria-expanded="true"] #burgerButtonInner {
      -webkit-transform: rotate(-45deg) translate(-8px, 8px);
      transform: rotate(-45deg) translate(-8px, 8px);
   }
   #burgerButton[aria-expanded="true"]:before {
      opacity: 0;
   }
   #burgerButton[aria-expanded="true"]:after {
      -webkit-transform: rotate(45deg) translate(-6px, -6px);
      transform: rotate(45deg) translate(-6px, -6px);
   }

   #burgerButtonInner {
      top: 11px;
   }
   #burgerButton:before {
      top: 21px;
   }
   #burgerButton:after {
      top: 31px;
   }

   #burgerButton:before,
   #burgerButton:after {
      content: "";
      display: block;
   }
   .navbar-nav {
      margin: 20px 0;
   }

   .navbar-collapse {
      top: 0;
      background: #067ba9;
      position: fixed;
      left: -100%;
      bottom: 0;
      z-index: 100;
      height: auto !important;
      -webkit-box-shadow: 0 0 150px 0 rgba(0, 0, 0, 1);
      box-shadow: 0 0 150px 0 rgba(0, 0, 0, 1);
      opacity: 0;
      pointer-events: none;
      overflow-y: auto;
      -webkit-transition: left 300ms linear, opacity 300ms linear;
      -moz-transition: left 300ms linear, opacity 300ms linear;
      -ms-transition: left 300ms linear, opacity 300ms linear;
      -o-transition: left 300ms linear, opacity 300ms linear;
      transition: left 300ms linear, opacity 300ms linear;
   }
   .navbar-collapse[aria-expanded="true"],
   .navbar-collapse.in {
      left: 0;
      opacity: 1;
      pointer-events: auto;
   }

   .navbar-toggle[aria-expanded="true"]::before {
      opacity: 1;
      width: 90px;
   }
}

@media (min-width: 575px) and (max-width: 991px) {
   .navbar-collapse {
      width: 60%;
   }
   .navbar-collapse.collapse.in:after,
   .navbar-toggle[aria-expanded="true"]::before {
      width: 40%;
   }
}

/* menu desktop */

@media (min-width: 992px) {
   #menu {
      padding-top: 22px;
      padding-bottom: 22px;
   }
   #myNavbar.navbar-collapse {
      background: #ffffff;
      pointer-events: none;
      position: absolute;
      z-index: 1002;
      top: 70px;
      left: 23px;
      opacity: 0;
      width: 580px;
      border-radius: 0;
      height: auto !important;
      overflow: visible !important;
      -webkit-box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.3);
      box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.3);
      -webkit-transition: opacity 300ms linear, top 300ms linear;
      -moz-transition: opacity 300ms linear, top 300ms linear;
      -ms-transition: opacity 300ms linear, top 300ms linear;
      -o-transition: opacity 300ms linear, top 300ms linear;
      transition: opacity 300ms linear, top 300ms linear;
   }

   #burgerButton[aria-expanded="true"] + #myNavbar {
      pointer-events: auto;
      opacity: 1;
      top: 75px;
   }

   #myNavbar:focus-within {
      pointer-events: auto;
      opacity: 1;
      top: 75px;
   }

   #myNavbar.navbar-collapse::before {
      content: "";
      display: block;
      position: absolute;
      left: 25px;
      top: -22px;
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 0 12px 23px 12px;
      border-color: transparent transparent #067ba9 transparent;
   }

   #myNavbar.navbar-collapse > div {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      max-height: 75vh;
      overflow-y: auto;
      position: relative;
      background: #ffffff;
   }
   .navbar-nav {
      padding: 23px 0 25px 0;
      background: #067ba9;
      min-height: 365px;
   }
   .navbar-default .navbar-nav > li > .dropdown-menu {
      padding: 25px 20px;
      position: absolute;
      z-index: 2;
      left: 50%;
      top: 0 !important;
      right: 0;
      bottom: 0;
      overflow-y: auto;
      background: #ffffff;
   }

   .navbar-nav,
   .navbar-default .navbar-nav > li > .dropdown-menu {
      width: 50%;
   }

   .navbar-default .navbar-nav > li > ul {
      display: block !important;
      pointer-events: none;
      opacity: 0;
      -webkit-transition: opacity 300ms linear;
      -moz-transition: opacity 300ms linear;
      -ms-transition: opacity 300ms linear;
      -o-transition: opacity 300ms linear;
      transition: opacity 300ms linear;
   }
   .navbar-default .navbar-nav > li[class$="_over"] > .dropdown-menu,
   .navbar-default .navbar-nav > li:hover > ul {
      pointer-events: auto !important;
      opacity: 1 !important;
   }
   .navbar-default .navbar-nav > li:focus-within > ul {
      pointer-events: auto !important;
      opacity: 1 !important;
   }
   .navbar-default .navbar-nav > li:hover > ul {
      z-index: 3;
   }
   .navbar-default .navbar-nav > li:focus-within > ul {
      z-index: 3;
   }
}

/* ---------------------------------------------- toplevel ---------------------------------------------- */

.navbar-default .navbar-nav > li > a {
   color: #ffffff;
   font-weight: 600;
   text-align: left;
   padding: 10px 10px;
   position: relative;
   font-size: 1.25rem;
   line-height: 1.2;
   text-decoration: none;
}

@media (max-width: 991px) {
   nav .navbar-nav > li > a.dropdown-toggle {
      padding-right: 35px;
   }
}

@media (min-width: 992px) {
   .navbar-default .navbar-nav > li > a {
      padding: 7px 30px;
      text-align: right;
   }
   .navbar-default .navbar-nav > li > a::before {
      content: "";
      position: absolute;
      display: block;
      width: 25px;
      top: 0;
      bottom: 0;
      right: -25px;
   }
}

/* -------------------------------------------- toplevel-over ------------------------------------------- */

.navbar-nav > li:hover > a,
.navbar-nav > li > a:hover,
.navbar-nav > li > a:focus,
.navbar-nav > li.open > a,
.navbar-nav > li.open > a:hover,
.navbar-nav > li.open > a:focus,
.navbar-nav > li[class$="_over"] > a,
.navbar-nav > li[class$="_over"] > a:hover,
.navbar-nav > li[class$="_over"] > a:focus {
   color: #067ba9;
   background-color: #ffffff;
}

/* -------------------------------------- secondlevel + thirdlevel dropdown-box -------------------------------------- */

@media (max-width: 991px) {
   .navbar-default .navbar-nav > li > .dropdown-menu {
      background: #ffffff;
   }
}

/* --------------------------------------------- secondlevel + thirdlevel -------------------------------------------- */

.navbar-default .navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > a,
.navbar-default .navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li > a {
   color: #444444;
   font-weight: 400;
   text-align: left;
   padding: 8px 35px 8px 25px;
   position: relative;
   font-size: 1.125rem;
   line-height: 1.2;
   text-decoration: none;
}

.navbar-default .navbar-nav > li > .dropdown-menu li[class*="_start"],
.navbar-default .navbar-nav > li > .dropdown-menu li[class*="end"] {
   display: none;
}

@media (max-width: 991px) {
   .navbar-default .navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li > a {
      padding-left: 45px;
   }
}

@media (min-width: 992px) {
   .navbar-default .navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] {
      border-top: 1px dashed rgba(82, 82, 82, 0.4);
   }
   .navbar-default .navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > a {
      padding: 9px 2px;
   }
   .navbar-default .navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li > a {
      padding: 5px 10px 5px 34px;
   }
   .navbar-default .navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li > a::after {
      content: "";
      position: absolute;
      left: 8px;
      top: 50%;
      background: #f3ba00;
      width: 5px;
      height: 5px;
      margin-top: -2px;
      border-radius: 50%;
      opacity: 0;
      transition: all, 300ms;
   }
   .navbar-default .navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu {
      display: block;
   }
}

/* ------------------------------------------ secondlevel + thirdlevel over ------------------------------------------ */

.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"]:hover > a,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > a:hover,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > a:focus,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"].open > a,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"].open > a:hover,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"].open > a:focus,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"][class$="_over"] > a,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"][class$="_over"] > a:hover,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"][class$="_over"] > a:focus {
   background: transparent;
   color: #067ba9;
}

.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li > a:hover,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li > a:focus,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li.open > a,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li.open > a:hover,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li.open > a:focus,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li[class$="_over"] > a,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li[class$="_over"] > a:hover,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li[class$="_over"] > a:focus {
   background: #fef8e5;
   color: #01487a;
}

.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li > a:hover::after,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li > a:focus::after,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li.open > a::after,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li.open > a:hover::after,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li.open > a:focus::after,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li[class$="_over"] > a::after,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li[class$="_over"] > a:hover::after,
.navbar-nav > li > .dropdown-menu li[class*="menue_point_secondlevel"] > .dropdown-menu > li[class$="_over"] > a:focus::after {
   opacity: 1;
}

/*-- contrast + styler --*/

@media (min-width: 992px) {
   #contrast_style {
      line-height: 0;
   }
   #contrast_style button {
      padding: 0;
      border: none;
      background: transparent;
      display: inline-block;
   }
   #contrast_style button + button {
      margin-left: 8px;
   }
   #contrast_style span {
      font-size: 0.9375rem;
      color: #444444;
      margin-right: 10px;
   }
}

@media (min-width: 992px) {
   #style button {
      border: none;
      color: #444444;
      display: inline-block;
      width: 21px;
      height: 21px;
      border-radius: 50%;
      font-weight: 600;
      font-size: 1rem;
      text-align: center;
      background-color: transparent;
      position: relative;
      line-height: 1;
      -webkit-transition: all 0.5s 0s ease;
      -moz-transition: all 0.5s 0s ease;
      -o-transition: all 0.5s 0s ease;
      transition: all 0.5s 0s ease;
      border: 1px solid #444444;
      padding: 0;
   }
   #style span {
      font-size: 0.9375rem;
      color: #444444;
      margin-left: 30px;
   }
   #style button + button {
      margin-left: 1px;
      padding-left: 0;
   }
   #style button:hover {
      color: #0178a7;
   }
}

/* ----------------------------------------------- banner ----------------------------------------------- */

#headerpic {
   margin: 0 auto;
   position: relative;
   width: 100%;
   overflow: hidden;
}

@media (min-width: 992px) {
   #headerpic {
      margin-top: 0;
   }
}

#slider {
   max-height: 300px;
   overflow: hidden;
   position: relative;
}

@media (min-width: 576px) {
   #slider {
      max-height: 400px;
   }
   body.index #slider {
      max-height: 685px;
   }
}

#bannerOverlay {
   padding-top: 25px;
}

#bannerOverlay h1 {
   font-size: 1.4rem;
}

#bannerOverlay h1,
#bannerOverlay h2,
#bannerOverlay h3,
#bannerOverlay h4,
#bannerOverlay h5,
#bannerOverlay h6 {
   margin-bottom: 0;
}

@media (min-width: 576px) {
   #bannerOverlay {
      padding-top: 0;
      position: absolute;
      left: 0;
      right: 0;
      bottom: 120px;
      z-index: 60;
      color: #ffffff;
      text-shadow: 0 0 10px rgba(0, 0, 0, 0.4);
      font-weight: 700;
      line-height: 1.1;
      font-size: 1.2rem;
   }
   #bannerOverlay h1,
   #bannerOverlay h2,
   #bannerOverlay h3,
   #bannerOverlay h4,
   #bannerOverlay h5,
   #bannerOverlay h6 {
      color: #ffffff;
   }
   #bannerOverlay h1 {
      font-size: 2.5rem;
   }
}

@media (min-width: 768px) {
   #bannerOverlay {
      font-size: 1.4rem;
   }
   #bannerOverlay h1 {
      font-size: 3rem;
   }
}

@media (min-width: 992px) {
   #bannerOverlay {
      bottom: 140px;
   }
}

@media (min-width: 1200px) {
   #bannerOverlay {
      font-size: 1.875rem;
      bottom: 180px;
   }
   #bannerOverlay h1 {
      font-size: 3.75rem;
   }
}

.slider-wrapper,
#slider {
   height: 100%;
}

.slider-mask {
   display: none;
}

/* ----------------------------------------------- banner arrows ----------------------------------------------- */

.nivo-directionNav {
   height: 40px;
   pointer-events: none;
   width: 100%;
   position: absolute;
   z-index: 51;
   left: 50%;
   bottom: 80px;
   -moz-transform: translateX(-50%);
   -webkit-transform: translateX(-50%);
   -o-transform: translateX(-50%);
   -ms-transform: translateX(-50%);
   transform: translateX(-50%);
}

@media (min-width: 992px) {
   .nivo-directionNav {
      max-width: 992px;
      bottom: 100px;
   }
}

@media (min-width: 1200px) {
   .nivo-directionNav {
      max-width: 1200px;
   }
}

#headerpic .theme-default .nivo-directionNav a {
   pointer-events: auto;
   background: #01487a url("../img/banner-arrows.png") top 10px center / 18px auto no-repeat;
   width: 40px;
   height: 40px;
}

#slider + .nivo-controlNav {
   pointer-events: none;
}

#slider + .nivo-controlNav a {
   pointer-events: auto;
}

.theme-default .nivo-directionNav a.nivo-nextNav {
   -webkit-transform: scale(-1);
   transform: scaleX(-1);
}

/* ----------------------------------------------- banner dots ----------------------------------------------- */

@media (min-width: 576px) {
   .nivo-controlNav {
      bottom: 65px !important;
   }
}

@media (min-width: 992px) {
   .nivo-controlNav {
      bottom: 78px !important;
   }
}

#headerpic .theme-default .nivo-controlNav a {
   background: transparent;
   border-radius: 50%;
   border: 1px solid #ffffff;
   width: 12px;
   height: 12px;
}

#headerpic .theme-default .nivo-controlNav a.active {
   background-color: #ffffff;
}

#headerpic .theme-default .nivo-controlNav a + a {
   margin-left: 8px;
}

/* ----------------------------------------------- search ----------------------------------------------- */

@media (min-width: 576px) {
   #searchArea {
      position: relative;
      z-index: 54;
      margin-top: -50px;
   }
}

@media (min-width: 992px) {
   body.index #searchArea::after {
      content: "";
      position: absolute;
      z-index: -1;
      display: block;
      top: 50px;
      left: 0;
      right: 50%;
      bottom: -1px;
      background: #01487a;
   }
}

@media (max-width: 991px) {
   body:not(.index) #searchArea {
      display: none;
   }
}

#searchBox {
   background: #ffffff;
   padding: 25px 0;
   position: relative;
}

@media (min-width: 576px) {
   #searchBox {
      padding-left: 25px;
      padding-right: 25px;
   }
}

@media (min-width: 992px) {
   #searchBox {
      padding-left: 40px;
      padding-right: 40px;
   }
}

#searchBox::after {
   content: "";
   position: absolute;
   display: block;
   z-index: -1;
   left: 60px;
   right: 60px;
   top: 50%;
   bottom: 0;
   -webkit-box-shadow: 0 20px 40px 0 rgba(0, 0, 0, 0.3);
   box-shadow: 0 20px 40px 0 rgba(0, 0, 0, 0.3);
}

form[id*="search"] {
   display: block;
   position: relative;
}

@media (min-width: 576px) {
   form[id*="search"] {
      height: 50px;
      width: 100%;
   }
}

@media (max-width: 991px) {
   form[id*="search"] {
      margin-bottom: 15px;
   }
   nav form[id*="search"] {
      margin-top: 20px;
      margin-left: 15px;
      margin-right: 15px;
   }
}

@media (min-width: 992px) {
   form[id*="search"] {
      max-width: 370px;
   }
}

input[id*="search_input"] {
   color: #444444;
   background-color: #fef8e5;
   font-size: 16px;
   font-style: normal;
   padding: 0;
   border: 0;
   line-height: 50px;
   padding-left: 10px;
   padding-right: 50px;
   height: 50px;
   width: 100%;
}

input[id*="search_submit"] {
   height: 100%;
   width: 50px;
   background: url("../img/lupe-icon.png") center / 18px 18px no-repeat;
   padding: 0;
   cursor: pointer;
   line-height: 50px;
   border: none;
   position: absolute;
   bottom: 0;
   right: 0;
   font-size: 0;
   -webkit-transition: background 200ms linear;
   -moz-transition: background 200ms linear;
   -ms-transition: background 200ms linear;
   -o-transition: background 200ms linear;
   transition: background 200ms linear;
}

input[id*="search_submit"]:hover,
input[id*="search_submit"]:focus {
   background-size: 24px 24px;
   background-color: #f7f0ed;
}

input[id*="search_input"]:-ms-input-placeholder {
   color: #888888;
   text-transform: uppercase;
   opacity: 1;
}

input[id*="search_input"]::-ms-input-placeholder {
   color: #888888;
   text-transform: uppercase;
   opacity: 1;
}

input[id*="search_input"]::placeholder {
   color: #888888;
   text-transform: uppercase;
   opacity: 1;
}

@media (min-width: 768px) {
   .importantLinks {
      font-size: 1.125rem;
   }
}

.importantLinks a {
   font-size: 0.8rem;
   border-radius: 2px;
   display: inline-block;
   background: #fef8e5;
   padding: 2px 6px;
   color: #444444;
}

.importantLinks a:hover,
.importantLinks a:focus {
   color: #0178a7;
}

@media (min-width: 768px) {
   .importantLinks a {
      font-size: 1rem;
   }
}

.importantLinks a + a {
   margin-left: 4px;
}

#gal a {
   font-size: 1.8125rem;
   font-weight: bold;
   color: #fff;
   text-decoration: none;
}

#gal a::after {
   content: "→";
   display: block;
   font-weight: 400;
   color: #f3ba00;
   font-size: 3.5rem;
   font-family: "Work Sans";
 }

/* ------------------------------------------------ topInfo ----------------------------------------------- */

#topInfo {
   padding-top: 40px;
   position: relative;
   z-index: 1;
}

#topInfo > .row > .col-xs-12:nth-child(1) b,
#topInfo > .row > .col-xs-12:nth-child(1) strong {
   color: #f3ba00;
}

@media (min-width: 768px) {
   #topInfo {
      padding-top: 60px;
   }
}

@media (min-width: 992px) {
   #topInfo {
      padding-top: 100px;
      background: url("../img/flower1.png") no-repeat right center;
   }
}

@media (max-width: 991px) {
   #topInfo > .row > * + * {
      margin-top: 30px;
   }
}

#topInfo > .row > *:first-child {
   font-weight: 300;
   line-height: 1.3;
}

@media (min-width: 992px) {
   #topInfo > .row > *:first-child {
      padding-top: 50px;
      padding-right: 30px;
      padding-bottom: 110px;
   }
}

#topInfo > .row > *:first-child a {
   color: #ffffff;
   text-decoration: underline;
}

#topInfo > .row > *:first-child a:hover,
#topInfo > .row > *:first-child a:focus {
   color: #523849;
}

#topInfo > .row > *:first-child b,
#topInfo > .row > *:first-child strong {
   font-weight: 700;
   font-size: 1.6rem;
}

@media (min-width: 992px) {
   #topInfo > .row > *:first-child b,
   #topInfo > .row > *:first-child strong {
      font-weight: 700;
      font-size: 2rem;
   }
}

@media (min-width: 1200px) {
   #topInfo > .row > *:first-child b,
   #topInfo > .row > *:first-child strong {
      font-size: 2.5rem;
   }
}

#topInfo > .row > *:first-child,
#topInfo > .row > *:first-child h1,
#topInfo > .row > *:first-child h2,
#topInfo > .row > *:first-child h3,
#topInfo > .row > *:first-child h4,
#topInfo > .row > *:first-child h5,
#topInfo > .row > *:first-child h6 {
   color: #ffffff;
}

#topInfo > .row > *:first-child h1::after {
   content: "-";
   display: block;
   color: #e69ece;
   line-height: 0.5;
   margin-top: 5px;
}

#topInfo::after {
   content: "";
   position: absolute;
   z-index: -1;
   display: block;
   top: 0;
   left: 0;
   right: 0;
   bottom: 50px;
   background: #01487a url("../img/box1.png") no-repeat left bottom;
   border-bottom-right-radius: 500px;
}

@media (min-width: 992px) {
   #topInfo::after {
      right: 50%;
      bottom: 60px;
   }
}

#topInfo .tab {
   background: #fef8e5;
   padding: 35px 30px 30px 30px;
   min-height: 100%;
   height: 100%;
   color: #444444;
   line-height: 1.3;
   position: relative;
}

@media (min-width: 768px) {
   #topInfo .tab {
      font-size: 1.125rem;
   }
   .tab_spacer {
      height: 20px;
   }
}

@media (min-width: 992px) {
   #topInfo .tab {
      padding-bottom: 70px;
   }
}

@media (min-width: 1200px) {
   #topInfo .tab {
      padding: 45px 40px 70px 40px;
   }
}

#topInfo .tabHeadline {
   text-transform: uppercase;
   color: #01487a;
   font-weight: 700;
   font-size: 1.25rem;
   margin-bottom: 20px;
}

@media (min-width: 992px) {
   #topInfo .tabHeadline {
      font-size: 1.4rem;
   }
}

@media (min-width: 1200px) {
   #topInfo .tabHeadline {
      font-size: 1.625rem;
   }
}

#topInfo .tabHeadline::before {
   content: "";
   display: block;
   width: 100%;
   height: 60px;
   background-position: center left;
   background-repeat: no-repeat;
   margin-bottom: 15px;
}

#topInfo .tab_link_mehr {
   color: transparent;
   font-size: 0;
}

.teaserText a,
#topInfo .tab_link_mehr a {
   background: #0178a7;
   display: inline-block;
   color: #ffffff;
   font-weight: 700;
   text-transform: uppercase;
   padding: 6px 15px;
   text-decoration: none;
}

#topInfo .tab_link_mehr a {
   position: absolute;
   bottom: 0;
   right: 0;
   font-size: 1rem;
}

@media (min-width: 992px) {
   #topInfo .tab_link_mehr a {
      padding: 15px 34px;
      bottom: -10px;
      right: -10px;
   }
}

.teaserText a:hover,
#topInfo .tab_link_mehr a:hover,
.teaserText a:focus,
#topInfo .tab_link_mehr a:focus {
   background: #0178a7;
}

.teaserText a::after,
#topInfo .tab_link_mehr a::after {
   content: "\2192";
   font-weight: 400;
   position: relative;
   left: 0;
   margin-left: 4px;
   -webkit-transition: left 200ms linear;
   -moz-transition: left 200ms linear;
   -ms-transition: left 200ms linear;
   -o-transition: left 200ms linear;
   transition: left 200ms linear;
}

.teaserText a:hover::after,
#topInfo .tab_link_mehr a:hover:after,
.teaserText a:focus::after,
#topInfo .tab_link_mehr a:focus:after {
   left: 6px;
}

#tab1 .tabHeadline::before {
   background-image: url("../img/kalender-icon.png");
}

#tab2 .tabHeadline::before {
   background-image: url("../img/zeitung-icon.png");
}

.tab_link_title a {
   color: #444444;
   font-weight: 600;
}

.tab_link_mandat a {
   color: #444444;
}

/* ------------------------------------------------ content ----------------------------------------------- */

#content {
   text-align: left;
   padding-top: 40px;
   padding-bottom: 40px;
}

@media (min-width: 768px) {
   #content {
      padding-top: 60px;
      padding-bottom: 60px;
   }
}

@media (min-width: 992px) {
   #content {
      padding-top: 70px;
      padding-bottom: 100px;
   }
}

/* ------------------------------------------ h1 - h6, newslink ----------------------------------------- */

.h4link a:link,
.h4link a:hover,
.h4link a:focus,
.h4link a:visited,
h6,
.h6,
h5,
.h5,
h4,
.h4,
h3,
.h3,
h2,
.h2,
h1,
.h1 {
   font-weight: 700;
   line-height: 1;
   font-family: "Work Sans", serif;
}

h1,
h3,
h5 {
   color: #01487a;
}

h2,
h4,
h6 {
   color: #01487a;
}

h1,
.h1,
.legacy_h1 {
   font-size: 1.7rem;
}

@media (min-width: 576px) {
   h1,
   .h1,
   .legacy_h1 {
      font-size: 2.2rem;
   }
}

@media (min-width: 768px) {
   h1,
   .h1,
   .legacy_h1 {
      font-size: 2.7rem;
   }
}

@media (min-width: 992px) {
   body.index h1,
   body.index .h1,
   body.index .legacy_h1 {
      font-size: 3rem;
   }
}

@media (min-width: 1200px) {
   body.index h1,
   body.index .h1,
   body.index .legacy_h1 {
      font-size: 3.5rem;
   }
}

h2,
.h2,
.legacy_h2 {
   font-size: 1.7rem;
}

@media (min-width: 768px) {
   h2,
   .h2,
   .legacy_h2 {
      font-size: 2.2rem;
   }
   body.index h2,
   body.index .h2,
   body.index .legacy_h2 {
      font-size: 2.5rem;
   }
}

h3,
.h3,
.legacy_h3 {
   font-size: 1.6rem;
}

@media (min-width: 768px) {
   h3,
   .h3,
   .legacy_h3 {
      font-size: 2rem;
   }
}

h4,
.h4,
.h4link a:link,
.h4link a:hover,
.h4link a:focus,
.h4link a:visited,
.legacy_h4 {
   font-size: 1.5rem;
}

@media (min-width: 768px) {
   h4,
   .h4,
   .h4link a:link,
   .h4link a:hover,
   .h4link a:focus,
   .h4link a:visited,
   .legacy_h4 {
      font-size: 1.8rem;
   }
}

h5,
.h5,
.legacy_h5 {
   font-size: 1.4rem;
}

@media (min-width: 768px) {
   h5,
   .h5,
   .legacy_h5 {
      font-size: 1.6rem;
   }
}

h6,
.h6,
.legacy_h6 {
   font-size: 1.3rem;
}

@media (min-width: 768px) {
   h6,
   .h6,
   .legacy_h6 {
      font-size: 1.4rem;
   }
}

#newslinks,
#newsmandate {
   border: 1px solid #d291bc;
}

/* ------------------------------------------------ facts ----------------------------------------------- */

#facts {
   padding-top: 56px;
   padding-bottom: 56px;
   background: #fef8e5;
}

@media (max-width: 767px) {
   #facts > .row > div + div {
      margin-top: 30px;
   }
}

@media (min-width: 576px) {
   #facts > .row > div + div:not(:last-child) {
      margin-top: 0;
   }
}

#facts a {
   color: #0178a7;
}

#facts b,
#facts strong {
   color: #0178a7;
   font-size: 2.5rem;
   display: block;
   font-weight: 700;
   line-height: 1.1;
}

@media (min-width: 768px) {
   #facts b,
   #facts strong {
      font-size: 3.5rem;
   }
}

#facts > .row > div:last-child a {
   font-size: 1.5625rem;
   font-weight: 700;
   color: #01487a;
   line-height: 1.2;
   text-decoration: none;
}

#facts > .row > div:last-child a::after {
   content: "\2192";
   display: block;
   font-weight: 400;
   color: #01487a;
   font-size: 3.5rem;
}

#facts > .row > div:last-child a:hover,
#facts > .row > div:last-child a:focus {
   color: #01487a;
}

/* ------------------------------------------------ teaser ---------------------------------------------- */

#teaser {
   padding-top: 40px;
   padding-bottom: 40px;
   position: relative;
   z-index: 10;
}

@media (min-width: 768px) {
   #teaser {
      padding-top: 60px;
      padding-bottom: 60px;
   }
}

@media (min-width: 992px) {
   #teaser {
      padding-top: 100px;
      padding-bottom: 100px;
      background: url("../img/flower2.png") no-repeat left bottom;
   }
}

#teaser > .row {
   z-index: 10;
}

#teaserBox > .row {
   margin-left: auto;
   margin-right: auto;
}

#teaser::after {
   content: "";
   position: absolute;
   z-index: -1;
   display: block;
   top: 0;
   left: 0;
   right: 0;
   bottom: 80px;
   background: #0178a7 url("../img/box2.png") no-repeat right bottom;
   border-bottom-left-radius: 500px;
}

@media (min-width: 992px) {
   #teaser::after {
      top: -55px;
      left: 50%;
      bottom: 0;
      border-bottom-left-radius: 0;
      border-top-left-radius: 500px;
   }
}

#teaser .tabHeadline,
.teaserTab .tabHeadline {
   color: #01487a;
   text-transform: uppercase;
   font-weight: 700;
}

#teaser .tabHeadline {
   margin-bottom: 3px;
}

@media (max-width: 991px) {
   #teaser .teaserInfo .tabHeadline,
   #teaser .teaserInfo,
   #teaser .teaserInfo a {
      color: #ffffff;
   }
   #teaser .teaserInfo a {
      text-decoration: underline;
   }
}

.teaserTab .tabHeadline {
   font-size: 26px;
}

.teaserTab .tabHeadline::after {
   content: "-";
   display: block;
   color: #e0cece;
   line-height: 0.2;
   margin-top: 10px;
   margin-bottom: 12px;
}

#teaserBox {
   background: #ffeee8;
   min-height: 100px;
   margin-top: 35px;
   position: relative;
}

#teaserBox::after {
   content: "";
   position: absolute;
   display: block;
   z-index: -1;
   left: 60px;
   right: 60px;
   top: 50%;
   bottom: 2px;
   -webkit-box-shadow: 0 20px 40px 0 rgba(0, 0, 0, 0.3);
   box-shadow: 0 20px 40px 0 rgba(0, 0, 0, 0.3);
}

#teaserBox .teaserText {
   padding: 30px 15px;
   font-weight: 300;
   line-height: 1.4;
}

@media (min-width: 768px) {
   #teaserBox .teaserText {
      font-size: 1.125rem;
   }
}

@media (min-width: 992px) {
   #teaserBox .teaserText {
      padding-top: 55px;
      padding-bottom: 55px;
   }
}

#teaserBox .teaserText a {
   margin-top: 15px;
   font-size: 0.875rem;
}

#teaserBox .bannerImg {
   display: block;
   min-height: 200px;
   background-position: center;
   background-size: cover;
   background-repeat: no-repeat;
   position: relative;
   overflow: hidden;
}

#teaserBox .bannerImg img {
   position: absolute;
   left: 50%;
   top: 50%;
   max-width: 120%;
   min-width: 100%;
   min-height: 100%;
   width: auto;
   height: auto;
   -ms-interpolation-mode: bicubic;
   -moz-transform: translateX(-50%) translateY(-50%);
   -webkit-transform: translateX(-50%) translateY(-50%);
   -o-transform: translateX(-50%) translateY(-50%);
   -ms-transform: translateX(-50%) translateY(-50%);
   transform: translateX(-50%) translateY(-50%);
   -webkit-transition: opacity 300ms linear;
   -moz-transition: opacity 300ms linear;
   -ms-transition: opacity 300ms linear;
   -o-transition: opacity 300ms linear;
   transition: opacity 300ms linear;
}

/* ----------------------------------------------- footer ----------------------------------------------- */

address {
   font-style: normal;
}

#footer {
   background: #ffeee8;
   padding-top: 40px;
   padding-bottom: 40px;
   color: #fff;
   font-size: 1rem;
   background-size: cover;
   background-repeat: no-repeat;
   background-position: center;
}

@media (max-width: 991px) {
   #footer > .row > div + div::before {
      background: rgba(135, 119, 119, 0.15);
      content: " ";
      height: 1px;
      width: 100%;
      display: block;
      margin: 25px 0;
   }
}

@media (min-width: 768px) {
   #footer {
      padding-top: 60px;
      padding-bottom: 60px;
   }
   #footer > .row > div + div:nth-child(2):before {
      display: none;
   }
   #footer > .row > div + div::before {
      margin: 35px 0;
   }
}

@media (min-width: 992px) {
   #footer {
      padding-top: 90px;
      padding-bottom: 90px;
   }
}

#footer > .row > div:last-child > div + div {
   margin-top: 30px;
}

#footer a {
   color: #f3ba00;
   text-decoration: underline;
}

#footer a:hover,
#footer a:focus {
   color: #f3ba00;
}

#footer .footerHeadline {
   color: #f3ba00;
   font-weight: 700;
   margin: 0 0 15px 0;
   font-size: 1.25rem;
   text-transform: uppercase;
}

#footer .footerHeadline.gap {
   margin-top: 30px;
}

@media (min-width: 992px) {
   #footer .footerHeadline.gap {
      margin-top: 40px;
   }
}

#footer iframe,
#footer .iframe-wrapper-manual-enabling {
   width: 100% !important;
   display: block !important;
   min-width: 100% !important;
}

.shadow {
   position: relative;
   display: block;
   z-index: 1;
   margin-left: auto;
   margin-right: auto;
}

.shadow::after {
   content: "";
   position: absolute;
   display: block;
   z-index: -1;
   left: 60px;
   right: 60px;
   top: 80%;
   bottom: 2px;
   -webkit-box-shadow: 0 20px 40px 0 rgba(0, 0, 0, 0.3);
   box-shadow: 0 20px 40px 0 rgba(0, 0, 0, 0.3);
}

.shadowContainer {
   width: 100%;
}

.shadowContainer > .shadow {
   width: auto;
   display: inline-block;
}

/* --------------------------------------------- counter -------------------------------------------- */

#counter {
   width: 100%;
   max-width: 260px;
   text-align: justify;
   text-align-last: justify;
   margin-left: auto;
   margin-right: auto;
}

@media (min-width: 768px) {
   #counter {
      font-size: 1.15rem;
   }
}

@media (min-width: 992px) {
   #counter {
      margin-right: 0;
      font-size: 1.25rem;
   }
}

#counter span {
   padding-left: 26px;
   position: relative;
   font-weight: 700;
   color: #f3ba00;
}

#counter span::before {
   content: "";
   display: block;
   position: absolute;
   left: 0;
   top: 50%;
   margin-top: -8px;
   width: 19px;
   height: 18px;
   background: url("../img/besucher-icon.png") center no-repeat;
}

/* --------------------------------------------- vernetzt -------------------------------------------- */

#footer #vernetzt {
   text-align: right;
   color: #fff;
   line-height: 1.3;
   margin: 30px auto 0 auto;
   font-weight: 400;
   text-decoration: none;
   font-size: 0.875rem;
}

@media (min-width: 992px) {
   #footer #vernetzt {
      margin-right: 0;
      float: right;
   }
}

#vernetzt b {
   color: #f3ba00;
   font-weight: 600;
}

#vernetzt span {
   color: #fff;
}

#vernetzt span span {
   display: block;
}

#vernetzt img {
   margin-left: 12px;
}

/* -------------------------------------------- innerfooter -------------------------------------------- */

#innerfooter {
   color: #b29d9d;
   font-size: 1rem;
   padding-top: 30px;
   padding-bottom: 30px;
   overflow: hidden;
}

@media (min-width: 768px) {
   #innerfooter {
      padding-top: 40px;
      padding-bottom: 40px;
   }
}

.footer_list ul {
   padding: 0;
}

.footer_list li {
   display: inline-block;
}

#innerfooter p {
   display: inline-block;
}

#innerfooter {
   position: relative;
}

#innerfooter::after {
   content: "";
   display: block;
   min-width: 100px;
   background: url("../img/footer-zierlement.png") center no-repeat;
   width: 118px;
   height: 115px;
   position: absolute;
   left: 45%;
   bottom: 0;
}

@media (min-width: 992px) {
   #innerfooter p::after {
      display: inline-block;
      margin: 0;
   }
}

#innerfooter p {
   flex-grow: 1;
}

#innerfooter p span > span {
   text-transform: uppercase;
   color: #01487a;
   font-weight: 600;
}

#innerfooter p span {
   color: #0178a7;
   font-weight: 600;
}

#innerfooter a {
   color: #444444;
   text-decoration: none;
   display: inline-block;
   font-weight: 400;
   text-transform: uppercase;
}

#innerfooter a:hover,
#innerfooter a:focus {
   color: #0178a7;
}

#innerfooter li + li {
   margin-left: 15px;
}

@media (min-width: 1200px) {
   #innerfooter li + li {
      margin-left: 25px;
   }
}
