@import url("https://fonts.verwaltungsportal.de/import/?family=Montserrat:400,400i,600,600i");

html {
    max-width: 1930px;
    margin-left: auto;
    margin-right: auto;
    background: #ffffff;
    scroll-behavior: smooth;
    scroll-padding-top: 100px;
    scrollbar-color: #00787d #ffffff;
}

body {
    font-family: "Montserrat", sans-serif;
    color: #222222;
    background: linear-gradient(to right, #dff3f4, #dff4df);
    font-size: 1rem;
    /* 1rem = 16px */
    line-height: 1.5;
}

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

a {
    color: #00787d;
}

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

b,
strong {
    font-weight: 600;
}

#over {
    overflow: clip;
    position: relative;
}

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

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

@media (min-width: 992px) {
    #slider {
        max-height: 400px;
    }

    body.intro #slider,
    body.index #slider {
        max-height: 500px;
    }

    #headerpic a.nivo-prevNav {
        left: 65px;
    }

    #headerpic a.nivo-nextNav {
        right: 65px;
    }
}

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

#headerpic::before {
    content: '';
    position: absolute;
    pointer-events: none;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 5px;
    background: linear-gradient(to right, #00787d, #3aaa35);
    z-index: 12;
}

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

.slider-mask {
    display: none;
}

@media (min-width: 992px) {
    .slider-mask {
        display: block;
        background: linear-gradient(to right, transparent, rgba(0, 0, 0, 0.8));
    }
}

/* ----------------------------------------------- bannerOverlay ----------------------------------------------- */

@media (max-width: 991px) {
    #bannerOverlay {
        padding: 10px 0;
        background-color: #f1f1f1;
    }
}

@media (min-width: 992px) {
    #bannerOverlay {
        position: absolute;
        pointer-events: none;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        display: flex;
        align-items: center;
        align-content: center;
        z-index: 12;
    }
}

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

#logo {
    display: inline-block;
    pointer-events: all;
}

#logo img {
    display: block;
}

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

/* -------------------------------------------- @nav4 Navigation ------------------------------------------- */

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

/* burgermenu for tablet */

#burgerButton {
    font-size: 0;
    border: none !important;
    position: relative;
    z-index: 1002;
    display: block;
    width: 48px;
    height: 48px;
    cursor: pointer;
    background: #00787d;
    border-radius: 50%;
    border: 1px solid #ffffff;
}

@media (max-width: 991px) {
    #burgerButton {
        position: fixed;
        right: 15px;
        top: 15px;
    }
}

@media (min-width: 992px) {
    #burgerButton {
        width: 48px;
        height: 48px;
        margin-left: auto;
        margin-right: 30px;
        z-index: 1003;
    }
}

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

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

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

#burgerButtonInner2,
#burgerButton:after,
#burgerButtonInner {
    position: absolute;
    background: #ffffff;
    width: 24px;
    height: 2px;
    left: 12px;
    -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;
}

@media (min-width: 992px) {

    #burgerButtonInner2,
    #burgerButton:after,
    #burgerButtonInner {
        left: 12px;
    }
}

#burgerButtonInner {
    top: 16px;
}

#burgerButtonInner2 {
    top: 23px;
}

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

@media (min-width: 992px) {
    #burgerButtonInner {
        top: 16px;
    }

    #burgerButtonInner2 {
        top: 23px;
    }

    #burgerButton:after {
        top: 30px;
    }
}

/* burgermenu for tablet */

@media (max-width: 991px) {
    .navbar-collapse {
        top: 0;
        background: #ffffff;
        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::before {
        content: "";
        opacity: 0;
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        width: 0;
        z-index: -1;
        display: block;
        -webkit-transition: width 300ms linear, opacity 300ms linear;
        -moz-transition: width 300ms linear, opacity 300ms linear;
        -ms-transition: width 300ms linear, opacity 300ms linear;
        -o-transition: width 300ms linear, opacity 300ms linear;
        transition: width 300ms linear, opacity 300ms linear;
    }

    .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) {
    nav {
        padding-top: 0;
        padding-bottom: 0;
        position: fixed;
        left: 0;
        right: 0;
        top: 0;
        z-index: 1005;
    }

    nav>.row {
        padding-top: 27px;
        padding-bottom: 27px;
    }

    nav>.row,
    nav>.row>div {
        position: static;
    }

    .navbar-default {
        width: auto;
        margin-left: 35px;
    }

    .navbar-default .navbar-nav {
        width: 100%;
        margin: 0;
        display: block;
        padding: 20px;
        overflow-y: auto;
        position: relative;
        -webkit-column-count: 2;
        -moz-column-count: 2;
        column-count: 2;
        -webkit-column-gap: 30px;
        -moz-column-gap: 30px;
        column-gap: 30px;
        max-width: 992px;
        margin-left: auto;
        margin-right: auto;
        background: #ffffff;
        border-radius: 20px;
    }

    .navbar-default li[class*="toplevel"] {
        float: none;
        -webkit-column-break-inside: avoid;
        page-break-inside: avoid;
        break-inside: avoid;
        display: list-item !important;
    }

    .navbar-nav::after,
    .navbar-nav::before {
        display: none;
    }

    #myNavbar {
        max-height: 70vh;
    }

    #myNavbar.navbar-collapse {
        pointer-events: none;
        position: absolute;
        z-index: 1002;
        top: 50%;
        left: 35%;
        opacity: 0;
        width: 870px;
        border-radius: 20px;
        background: #ffffff;
        height: auto !important;
        filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.15));
        -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::before {
        content: "";
        display: block;
        position: absolute;
        pointer-events: none;
        right: 10px;
        bottom: 0;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 0 15px 25px 15px;
        border-color: transparent transparent #ffffff transparent;
        opacity: 0;
        -webkit-transition: opacity 300ms linear, bottom 300ms linear;
        -moz-transition: opacity 300ms linear, bottom 300ms linear;
        -ms-transition: opacity 300ms linear, bottom 300ms linear;
        -o-transition: opacity 300ms linear, bottom 300ms linear;
        transition: opacity 300ms linear, bottom 300ms linear;
    }

    #burgerButton[aria-expanded="true"]::before {
        opacity: 1;
        bottom: -47px;
    }

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

    #myNavbar:focus-within {
        pointer-events: auto;
        opacity: 1;
        top: 120%;
    }

    #myNavbar {
        max-height: 50vh;
        overflow: auto;
        scrollbar-color: #555555 #f1f1f1;
        scrollbar-width: thin;
    }
}

@media (min-width: 1200px) {
    .navbar-default {
        margin-left: 52px;
    }

    .navbar-default .navbar-nav {
        max-width: 1200px;
        padding-top: 30px;
        padding-bottom: 30px;
    }
}

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

.navbar-default li[class*="toplevel"]>a {
    color: #222222;
    font-weight: 600;
    text-align: left;
    padding: 9px 13px;
    position: relative;
    font-size: 1.125rem;
    line-height: 1.2;
    text-decoration: none;
    background: #f9f9f9;
    margin-bottom: 2px;
    border: 2px solid #f9f9f9;
}

@media (max-width: 991px) {
    .navbar-default li[class*="toplevel"]>a {
        padding: 9px 20px;
    }

    .navbar-default li[class*="toplevel"] {
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    }

    nav.horizontally li[class*="toplevel"]>a.dropdown-toggle {
        padding-right: 35px;
    }
}

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

.navbar-default li[class*="toplevel"]:hover>a:after,
.navbar-default li[class*="toplevel"]>a:hover,
.navbar-default li[class*="toplevel"]>a:focus,
.navbar-default li[class*="toplevel"].open>a,
.navbar-default li[class*="toplevel"].open>a:hover,
.navbar-default li[class*="toplevel"].open>a:focus,
.navbar-default li[class*="toplevel"][class$="_over"]>a,
.navbar-default li[class*="toplevel"][class$="_over"]>a:hover,
.navbar-default li[class*="toplevel"][class$="_over"]>a:focus {
    color: #00787d;
    border: 2px solid #3aaa35;
    background: #ffffff;
}

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

@media (max-width: 991px) {
    .navbar-default li[class*="toplevel"]>.dropdown-menu {
        padding: 10px;
    }

    .navbar-default li[class*="toplevel"]>.dropdown-menu,
    .navbar-default li[class*="toplevel"]>.dropdown-menu>li>.dropdown-menu {
        background: rgba(255, 255, 255, 0.5);
    }
}

@media (min-width: 992px) {

    .navbar-default li[class*="toplevel"]>.dropdown-menu,
    .navbar-default li[class*="toplevel"]>.dropdown-menu>li>.dropdown-menu {
        display: block;
    }
}

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

.navbar-default li[class*="secondlevel"]>a,
.navbar-default li[class*="thirdlevel"]>a {
    color: #222222;
    font-weight: 400;
    text-align: left;
    padding: 8px 35px 8px 15px;
    font-size: 1rem;
    line-height: 1.2;
    text-decoration: none;
    position: relative;
}

@media (max-width: 991px) {
    .navbar-default li[class*="thirdlevel"]>a {
        padding-left: 25px;
    }
}

@media (min-width: 992px) {
    .navbar-default li[class*="secondlevel"]>a {
        padding: 5px 15px 5px 30px;
        font-size: 1.125rem;
    }

    .navbar-default li[class*="thirdlevel"]>a {
        padding: 5px 15px 5px 50px;
        font-size: 1.125rem;
    }

    .navbar-default li[class*="secondlevel"]>a::before,
    .navbar-default li[class*="thirdlevel"]>a::before {
        content: "";
        position: absolute;
        margin-top: -2px;
        top: 50%;
        left: 15px;
        width: 5px;
        height: 5px;
        border-radius: 50%;
        background: #00787d;
        transition: background 150ms linear;
    }

    .navbar-default li[class*="thirdlevel"]>a::before {
        left: 35px;
    }
}

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

.navbar-nav li[class*="secondlevel"]:hover>a,
.navbar-nav li[class*="secondlevel"]>a:hover,
.navbar-nav li[class*="secondlevel"]>a:focus,
.navbar-nav li[class*="secondlevel"].open>a,
.navbar-nav li[class*="secondlevel"].open>a:hover,
.navbar-nav li[class*="secondlevel"].open>a:focus,
.navbar-nav li[class*="secondlevel"][class$="_over"]>a,
.navbar-nav li[class*="secondlevel"][class$="_over"]>a:hover,
.navbar-nav li[class*="secondlevel"][class$="_over"]>a:focus,
.navbar-nav li[class*="thirdlevel"]>a:hover,
.navbar-nav li[class*="thirdlevel"]>a:focus,
.navbar-nav li[class*="thirdlevel"].open>a,
.navbar-nav li[class*="thirdlevel"].open>a:hover,
.navbar-nav li[class*="thirdlevel"].open>a:focus,
.navbar-nav li[class*="thirdlevel"][class$="_over"]>a,
.navbar-nav li[class*="thirdlevel"][class$="_over"]>a:hover,
.navbar-nav li[class*="thirdlevel"][class$="_over"]>a:focus {
    color: #00787d;
}

.navbar-nav li[class*="secondlevel"]:hover>a::before,
.navbar-nav li[class*="secondlevel"]>a:hover::before,
.navbar-nav li[class*="secondlevel"]>a:focus::before,
.navbar-nav li[class*="secondlevel"].open>a::before,
.navbar-nav li[class*="secondlevel"].open>a:hover::before,
.navbar-nav li[class*="secondlevel"].open>a:focus::before,
.navbar-nav li[class*="secondlevel"][class$="_over"]>a::before,
.navbar-nav li[class*="secondlevel"][class$="_over"]>a:hover::before,
.navbar-nav li[class*="secondlevel"][class$="_over"]>a:focus::before,
.navbar-nav li[class*="thirdlevel"]>a:hover::before,
.navbar-nav li[class*="thirdlevel"]>a:focus::before,
.navbar-nav li[class*="thirdlevel"].open>a::before,
.navbar-nav li[class*="thirdlevel"].open>a:hover::before,
.navbar-nav li[class*="thirdlevel"].open>a:focus::before,
.navbar-nav li[class*="thirdlevel"][class$="_over"]>a::before,
.navbar-nav li[class*="thirdlevel"][class$="_over"]>a:hover::before,
.navbar-nav li[class*="thirdlevel"][class$="_over"]>a:focus::before {
    background: #3aaa35;
}

/* ------------------------------------------------ introTabs ----------------------------------------------- */

#introTabs {
    padding-top: clamp(30px, 3vw, 40px);
    padding-bottom: clamp(30px, 4vw, 50px);
}

#introTabs>.row>*:not(:first-child, :nth-child(2), :nth-child(3), :nth-child(4))+* {
    margin-top: 30px;
}

@media (max-width: 991px) {

    #introTabs {
        padding-top: 0;
    }

    #introTabs>.row>* {
        margin-top: 30px;
    }
}

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

#introTabs .tab {
    color: #ffffff;
    border-radius: 30px;
    background: #00787d;
    position: relative;
    overflow: hidden;
    min-height: 100%;
    display: flex;
    align-items: stretch;
    align-content: stretch;
    height: 300px;
}

@media (max-width: 767px) {
    #introTabs .tab {
        height: 200px;
    }
}

#introTabs .template-page,
#introTabs .template-page>.row,
#introTabs .template-page>.row p {
    height: 100%;
}


#introTabs .tab::before {
    content: '';
    position: absolute;
    pointer-events: none;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(to top, rgba(0, 120, 125, 0.9) 0%, rgba(0, 120, 125, 0.5) 40%, rgba(0, 120, 125, 0) 60%, rgba(0, 120, 125, 0) 100%);
    z-index: 1;
}

/* #introTabs .tab a.has-image {
    color: #ffffff;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    font-size: 0;
    line-height: 0;
    min-height: 270px;
    height: 100%;
} */

#introTabs .tab img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

#introTabs .tab .tabHeadline {
    color: #ffffff;
    font-size: 1.375rem;
    margin: 0;
    position: absolute;
    pointer-events: none;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 12;
    padding: 0 10px 20px 10px;
}

/* ------------------------------------------------ @17ev ----------------------------------------------- */

#ev17 {
    padding-top: clamp(30px, 4vw, 50px);
    padding-bottom: clamp(30px, 4vw, 60px);
    background: #ffffff;
}

#ev17 .specialHeadline {
    margin-bottom: 40px;
}

#ev17 .specialHeadline .tabHeadline {
    font-size: clamp(1.75rem, 2vw, 2.125rem);
    margin: 0px;
}

#ev17 .specialHeadline a {
    text-decoration: none;
    display: inline-block;
    position: relative;
    font-weight: 600;
    color: #00787d;
    border-radius: 0 16px 16px 0;
    padding: 3px 17px 2px 30px;
    background: #ffffff;
}

#ev17 .specialHeadline a:hover,
#ev17 .specialHeadline a:focus {
    color: #222222;
}

#ev17 .specialHeadline a::before {
    content: '';
    position: absolute;
    pointer-events: none;
    top: 0;
    left: -30px;
    bottom: 0;
    margin: auto;
    width: 45px;
    height: 45px;
    border-radius: 100%;
    background: url('../img/icon-veranstaltungen.png') bottom right no-repeat, #00787d;
    z-index: 1;
}

#ev17 .specialHeadline a::after {
    content: '';
    position: absolute;
    pointer-events: none;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    border-radius: 0 16px 16px 0;
    border: 2px solid transparent;
    background: linear-gradient(to right, #00787d, #3aaa35) border-box;
    mask:
        linear-gradient(#000 0 0) padding-box,
        linear-gradient(#000 0 0);
    mask-composite: exclude;
}

#ev17 .tab_link_entries {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
}

#ev17 .tab_link_entry {
    width: 100%;
    padding: 35px 25px;
    color: #ffffff;
    background: url('../img/logo-wasserzeichen.png') center no-repeat, #00787d;
    border: unset;
    border-radius: 20px;
    box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.15);
    -webkit-box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.15);
    -moz-box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.15);
}

@media (min-width: 575px) and (max-width: 767px) {
    #ev17 .tab_link_entry {
        max-width: calc(50% - 15px);
    }

    #ev17 .tab_link_entry:last-child {
        max-width: 100%;
    }
}

@media (min-width: 768px) {
    #ev17 .tab_link_entry {
        max-width: calc(33.3333333% - 20px);
    }
}

#ev17 .tab_link_title a {
    font-weight: 600;
    color: #ffffff;
    display: inline-block;
}

#ev17 .tab_link_mandat a {
    color: #ffffff;
}

#ev17 .tab_link_mehr,
#ev17 .tab_spacer,
#ev17 .vorschau {
    display: none;
}

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

#content {
    text-align: left;
    padding-top: clamp(30px, 4vw, 50px);
    padding-bottom: clamp(30px, 4vw, 50px);
    position: relative;
}

#content::before {
    content: '';
    position: absolute;
    pointer-events: none;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 3px;
    background: linear-gradient(to right, #00787d, #3aaa35);
}

/* ------------------------------------------------ breaker ----------------------------------------------- */

#breaker {
    color: #ffffff;
    padding-top: clamp(30px, 4vw, 60px);
    padding-bottom: clamp(30px, 4vw, 60px);
    background-attachment: scroll, fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    background-color: #010101;
    box-shadow: 0px 0px 11px 0px rgba(0, 0, 0, 0.15);
    -webkit-box-shadow: 0px 0px 11px 0px rgba(0, 0, 0, 0.15);
    -moz-box-shadow: 0px 0px 11px 0px rgba(0, 0, 0, 0.15);
}

#breaker .tabHeadline {
    color: #ffffff;
    font-size: clamp(1.75rem, 2vw, 2.125rem);
}

#breaker .tab a {
    margin-top: 15px;
    text-decoration: none;
    display: inline-block;
    position: relative;
    font-weight: 600;
    color: #00787d;
    border-radius: 0 16px 16px 0;
    padding: 3px 17px 2px 30px;
    background: #ffffff;
}

#breaker .tab a:hover,
#breaker .tab a:focus {
    color: #222222;
}

#breaker .tab a::before {
    content: '';
    position: absolute;
    pointer-events: none;
    top: 0;
    left: -30px;
    bottom: 0;
    margin: auto;
    width: 45px;
    height: 45px;
    border-radius: 100%;
    background: url('../img/icon-termin.png') bottom right no-repeat, #00787d;
    z-index: 1;
}

#breaker .tab a::after {
    content: '';
    position: absolute;
    pointer-events: none;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    border-radius: 0 16px 16px 0;
    border: 2px solid transparent;
    background: linear-gradient(to right, #00787d, #3aaa35) border-box;
    mask:
        linear-gradient(#000 0 0) padding-box,
        linear-gradient(#000 0 0);
    mask-composite: exclude;
}

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

.h4link a:link,
.h4link a:hover,
.h4link a:focus,
.h4link a:visited,
H6,
H5,
H4,
H3,
H2,
H1 {
    color: #00787d;
    font-weight: 600;
    line-height: 1.2;
    font-family: "Montserrat", sans-serif;
}

h1,
.h1,
.legacy_h1 {
    font-size: clamp(1.875rem, 3vw, 2.5rem);
}

h2,
.h2,
.legacy_h2 {
    font-size: clamp(1.75rem, 3vw, 2.1875rem);
}

h3,
.h3,
.legacy_h3 {
    font-size: clamp(1.625rem, 3vw, 1.875rem);
}

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

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

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

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

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

footer {
    color: #222222;
    padding-top: clamp(30px, 2vw, 40px);
    padding-bottom: clamp(30px, 2vw, 40px);
    background-color: #ffffff;
    position: relative;
}

footer::before {
    content: '';
    position: absolute;
    pointer-events: none;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 5px;
    background: linear-gradient(to right, #00787d, #3aaa35);
}

@media (max-width: 767px) {
    footer .row>.col-xs-12:not(:first-child)::before {
        background: #00787d;
        content: " ";
        height: 1px;
        width: 100%;
        display: block;
        margin: 25px 0;
        opacity: 0.2;
    }

    footer .row>.col-xs-12.hidden-xs~.col-xs-12::before,
    footer .row>.col-xs-12.hidden-sm~.col-xs-12::before {
        display: none;
    }
}

footer .tab {
    font-size: 1rem;
}

footer .tab a {
    color: #2d8028;
}

footer .tabHeadline {
    font-size: clamp(1.75rem, 2vw, 2.125rem);
}

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

#innerfooter ul {
    padding: 0;
    line-height: 1.9;
}

#innerfooter li {
    display: block;
}

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

#innerfooter a:hover,
#innerfooter a:focus {
    color: #2d8028;
}

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

#vernetzt {
    text-align: right;
    font-size: clamp(0.875rem, 1vw, 1rem);
    color: #222222;
    line-height: 1.3;
    margin: 0 auto;
    text-decoration: none;
    font-weight: 400;
    display: flex;
    flex-direction: column;
    justify-content: end;
    align-items: end;
    align-content: end;
}

#vernetzt span {
    color: #222222;
}

#vernetzt span span {
    display: block;
}

#vernetzt img {
    margin-bottom: 10px;
}