/*
******************************************************************

Main CSS: Standard-Tags, Canvases

(c) sinntun.codes
 ******************************************************************
*/

:root {
    --pink: #B6327B;
    --purple: #7E4394;
    --lightblue: #EEF0F6;
    --darkblue: #0E3683;
    --white: #FFFFFF;
    --black: #000000;
    --grey: #707070;
    --background-grey: #F3F4F6;
}

.pink {
    background-color: var(--pink);
}

.purple {
    background-color: var(--purple);
}

.lightblue {
    background-color: var(--lightblue);
}

/* Styles normalisieren
*********************************************************** */

* {
    padding: 0;
    margin: 0;
    word-break: break-word;
    box-sizing: border-box;
}

/* gegen Springen der Seite im Browser */

html {
    height: 100%;
    padding: 0 0 0 0;
    box-sizing: border-box;
}

h4,
h5,
h6 {
    font-size: 1rem;
    font-weight: 400;
    text-wrap: balance;
}

h1 {
    font-size: 3.33rem; /*60px*/
    text-wrap: balance;
    margin-bottom: 3.1250rem;
    color: var(--pink);
    font-family: 'caveat', sans-serif;
    font-style: normal;
    font-weight: 600;
}

h2 {
    font-size: 2.22rem; /*40px*/
    font-weight: 400;
    text-wrap: balance;
    margin-bottom: 1.2500rem;
    color: var(--darkblue);
}

h3 {
    font-size: 1.67rem; /*30px*/
    font-weight: 400;
    text-wrap: balance;
}

h4 {
    font-size: 1.5000rem;
    font-weight: 600;
    text-wrap: balance;
}

p {
    font-size: 1.1250rem;
    font-weight: 400;
}

ol,
ul {
    list-style: none;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
    font-style: normal;
    font-weight: 400;
}

table {
    border-collapse: collapse;
}

fieldset,
img {
    border: 0;
}

caption,
th {
    text-align: left;
}

.clear {
    clear: both;
}

input:focus {
    outline: none;
}

@media only screen and (max-width: 56.89rem) {
    /*1024px*/
    h2 {
        margin-bottom: 0.6250rem !important;
        font-size: 1.67rem; /*30px*/
    }

    h1 {
        font-size: 2.78rem; /*50px*/
    }

    h3 {
        font-size: 1.45rem; /*24px*/
    }
}

@media only screen and (max-width: 28.89rem) {
    /*520px*/
    h1 {
        font-size: 2.22rem !important; /*40px*/
        margin-bottom: 1.0000rem;
    }

    h2 {
        font-size: 1.5rem; /*22px*/
    }

    h3 {
        font-size: 1.35rem; /*20px*/
    }

    p {
        /*font-size: 1.0000rem;*/
    }

    * {
        /*font-size: 1.2500rem;*/
    }
}

/*****************************************************************
**** Document
******************************************************************/

html {
    height: 100%;
    scroll-behavior: smooth;
    font-family: 'PT Sans', sans-serif !important;
}

body {
    height: 100%;
    font-size: 1.1250rem;
}

/*****************************************************************
**** Common Selectors
******************************************************************/


li {
    width: auto;
    height: auto;
}

li[data-list='bullet'] {
    list-style: initial;
}

li,
ul,
ol {
    font-size: inherit;
    box-sizing: border-box;
}

a {
    font-size: 1rem;
    line-height: 1.5000rem;
    text-decoration: none;
    z-index: 999;
}

.link-int:hover {
    text-decoration: underline;
}

img {
    width: 100%;
    height: auto;
    display: block;
}


/*
**** colors
******************************************************************/

.background {
    padding: 3.1250rem;
}

.black {
    color: var(--black);
}

.white {
    color: var(--white);
}

.grey {
    background-color: var(--background-grey);
}


/*****************************************************************
**** Commons Elements (PageElement-übergreifend)
******************************************************************/


/*** .content-container
******************************************************************/

@media screen and (max-width: 25.0000rem) {
    .content-container {
        flex-direction: column;
    }
}


/*** .contentbox
allgemeines Content Element
******************************************************************/

.contentbox {
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    position: relative;
    margin-bottom: 6.2500rem;
}

@media only screen and (max-width: 28.89rem) {
    /*520px*/
    .contentbox {
        margin-bottom: 4.3750rem;
    }
}

/*
**** text
******************************************************************/

.text {
    box-sizing: border-box;
}

.image-copyright {
    color: #646464;
    font-size: 0.7500rem;
    text-align: right;
}

.copyright {
    color: #646464;
    font-size: 0.7500rem;
    text-align: right;
}


/*
**** texteditor
******************************************************************/

.texteditor p[linebreak='true'] {
    margin-top: -0.65rem !important;
}

.texteditor p[linebreak='true']:first-child {
    margin-top: 0;
}

.texteditor > :not(:last-child) {
    margin-bottom: 1.1250rem;
}

.texteditor ol,
.texteditor ul {
    margin-left: 0.5625rem;
    margin-top: 0.6250rem;
    margin-bottom: 0.6250rem;
}

.texteditor ol:has(li[data-list ='bullet']) {
    margin-left: 0;
}

.texteditor ol li[data-list ='bullet'] {
    list-style: disc outside;
}

.texteditor a {
    text-decoration: underline;
    font-size: 1.125rem;
}

.texteditor a:focus-visible {
    outline: 0.1875rem solid var(--pink);
}

@media only screen and (max-width: 32.22rem) {
    .texteditor a {
        font-size: 1.2500rem;
    }
}

/*** links
******************************************************************/

ul.linklist {
    list-style: none;
    margin: 0;
    padding: 0;
}

ul.linklist a {
    color: #000000;
}

ul.linklist a:hover {
    color: var(--pink);
}

.link-container.top {
    margin-bottom: 1.2500rem;
}

.link-int::before,
.link-ext::before,
.link-more::before,
.download-link::before,
.phone::before,
.fax::before,
.mobile::before,
.mail::before,
.button-back::before {
    font-family: 'Font Awesome 6 Pro', sans-serif;
    font-weight: 900;
    display: inline-block;
}

.link-int::before,
.link-more::before {
    content: '\f32b';
    width: 1.2500rem;
}

.link-ext::before {
    content: '\f14c';
    width: 1.2500rem;
}


/*** button
******************************************************************/

.button {
    background-color: var(--pink);
    color: #fff;
    border: none;
    border-radius: 0.6250rem;
    padding: 0.6250rem 1.8750rem;
    display: inline-block;
}

.button:focus-visible {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}

.button:hover {
    background: var(--pink-hover);
}

@media only screen and (max-width: 32.22rem) {
    .button {
        font-size: 1.2500rem;
    }
}

/*** back-to-top
******************************************************************/

.back-to-top {
    position: fixed;
    right: 1.5625rem;
    z-index: 1000;
    bottom: 1.5625rem;
    background: var(--pink);
    padding: 0.5000rem 0.7500rem;
    cursor: pointer;
    color: #fff;
    width: 4.3750rem;
    height: 4.3750rem;
    box-sizing: border-box;
    border-radius: 0.6250rem;
    opacity: 0;
    pointer-events: none;
    transition: opacity 400ms;
}

.back-to-top.show {
    opacity: 1;
    pointer-events: initial;
}

.back-to-top.show:focus-visible {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}



.back-to-top .icon:before {
    content: '\f077';
    font-family: 'Font Awesome 6 Pro', sans-serif;
    color: #fff;
    font-size: 2.22rem;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

@media only screen and (max-width: 75.0000rem) {
    .back-to-top {
        width: 3.6250rem;
        height: 3.6250rem;
    }

    .back-to-top .icon:before {
        font-size: 1.6250rem;
    }
}

@media only screen and (max-width: 64.0000rem) {
    .back-to-top .icon:before {
        font-size: 1.5000rem;
    }
}

@media screen and (max-width: 40.0000rem) {
    .back-to-top {
        width: 2.8125rem;
        height: 2.8125rem;
    }

    .back-to-top .icon:before {
        font-size: 1.2500rem;
    }
}


/*** download-links
******************************************************************/

.download-item {
    display: block;
    clear: both;
}

.download-link {
    box-sizing: border-box;
    display: block;
}

.download-link::before {
    font-family: 'Font Awesome 6 Pro', sans-serif;
    font-weight: 900;
    content: '\f56d';
    width: 1.8750rem;
    display: inline-block;
    font-size: 1.5625rem;
    margin-right: 0.3125rem;
    flex-shrink: 0;
}


/*****************************************************************
*** Grid / Canvases
******************************************************************/

#page-canvas {
    width: 100%;
    height: auto;
    box-sizing: border-box;
    position: relative;
    margin: 0 auto 0;
}

#main-navigation {
    display: inline-block;
    width: 100%;
    overflow: visible;
    margin: auto auto 1.4375rem;
    box-sizing: content-box;
}

#main-navigation nav {
    padding: 2.1875rem 0 0;
    max-width: 77.78rem;
    margin: auto;
    box-sizing: border-box;
}

@media screen and (max-width: 77.78rem) {
    #main-navigation nav {
        padding: 2.1875rem 2.22rem 0;
    }
}

#content-canvas {
    width: 100%;
    height: auto;
    box-sizing: border-box;
    overflow: hidden;
    position: relative;
    /*max-width: 77.78rem;*/
    margin: auto;
    padding-top: 3.5rem;
}

#main-canvas {
    width: 100%;
    height: auto;
    box-sizing: border-box;
    overflow: hidden;
    position: relative;
    float: left;
}

.pageelement-canvas {
    width: 100%;
}

@media only screen and (max-width: 64.0000rem) {

    #info-canvas {
        width: 100%;
        margin: 0 0;
        max-width: 100%;
        padding-left: 0;
    }

    #main-canvas {
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    #meta-navigation {
        display: none !important;
    }

}

@media only screen and (max-width: 56.2500rem) {
    #content-canvas {
        padding-top: 1.3750rem;
    }
}

@media only screen and (max-width: 47.5000rem) {

    #main-canvas {
        width: 100% !important;
        margin-left: 0 !important;
    }

    #info-canvas {
        width: 100%;
        margin: 0 0;
    }

    #aside-canvas {
        width: 100%;
        margin-bottom: 0.6250rem;
    }


    /*****************************************************************
      *********** Header
      ******************************************************************/
    #head-image {
        width: 100%;
        height: 10.3125rem;
    }

    #head-image img {
        height: 12.22rem;
        object-fit: cover;
    }
}


/*
******************************************************************

CSS for navigation

(c) sinntun.codes
******************************************************************
*/

/*****************************************************************
*********** Navigation (Nav1))
******************************************************************/

.nav1 {
    display: flex;
    justify-content: space-between;
    gap: 0.6250rem;
}

.nav1-item.has-subnav {
    position: relative;
}

.nav1-item.has-subnav .nav1-link {
    padding: 0.6250rem 0 0.6250rem 0;
    margin-right: 1.9375rem;
}

.nav1-link {
    padding: 0.6250rem 0;
    display: flex;
    color: var(--darkblue);
    font-size: 1.2500rem;
    font-family: 'PT Sans', sans-serif;
    /*height: 100%;*/
    box-sizing: border-box;
    align-items: center;
}

.nav1-link:focus-visible {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}

.nav1-link span {
    line-height: 1.3125rem;
    color: inherit;
    font-size: 1.2500rem;
    font-weight: 700;
}

.nav1-link.active,
.nav1-link:hover {
    color: var(--pink);
}

.nav1-link-last {
    position: relative;
    z-index: 2000;
}

.nav1-item.has-subnav button {
    position: absolute;
    right: 0.3125rem;
    top: 0.6250rem;
    background: none;
    border: none;
    font-size: 1.1250rem;
    font-weight: 600;
}

.nav1-item.has-subnav button:focus-visible {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}

.nav1-item.has-subnav button span {
    color: var(--darkblue);
}


.nav1-item.has-subnav:hover .nav1-link,
.nav1-item.has-subnav:has(.nav2dropdown:hover) .nav1-link,
.nav1-item.has-subnav:hover button span {
    color: var(--pink);
}


/*****************************************************************
*********** Navigation (Nav1 with Nav2 Dropdown)
******************************************************************/

.nav2dropdown {
    display: none;
    float: none;
    position: absolute;
    padding-top: 0.3125rem;
    z-index: 1000;
    width: 14.375rem;
    min-width: fit-content;
}

.nav1-item:hover .nav2dropdown {
    display: block;
}

.nav2dropdown-item {
    display: flex;
    float: none;
    width: 100%;
    height: auto;
    box-sizing: border-box;
}

.nav2dropdown-item span {
    font-weight: 200;
}

.nav2dropdown-link {
    display: inline-block;
    width: 100%;
    padding: 0.3125rem 0.5000rem;
    color: var(--darkblue);
    background: #F2F2F2;
    font-size: 1.2500rem;
    font-family: 'PT Sans', sans-serif;
}

.nav2dropdown-link.active,
.nav2dropdown-link:hover {
    color: #fff;
    background: var(--pink);
}

.nav2dropdown-link:focus-visible {
    outline: 0.1875rem solid var(--darkblue);
    outline-offset: -3px;
}

.nav2dropdown-link span {
    color: inherit;
    font-weight: 400;
}


/*****************************************************************
*********** Navigation Meta
******************************************************************/

#meta-navigation {
    float: right;
    margin-right: 5.0000rem;
}

#meta-navigation .nav-meta-item {
    display: inline-block;
    margin-right: 0.3125rem;
}

#meta-navigation .nav-meta-item:has(a:focus-visible){
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}

#meta-navigation .nav-meta-link:focus-visible{
    outline: none;
}

#meta-navigation .nav-meta-link {
    display: inline-block;
}

#meta-navigation li.nav-meta-item:nth-child(2):after {
    content: '\e463';
    font-family: 'Font Awesome 6 Pro', sans-serif;
}

#meta-navigation li.nav-meta-item:nth-child(1):after {
    content: '\f002';
    font-family: 'Font Awesome 6 Pro', sans-serif;
}

#meta-navigation.contentbox {
    width: initial;
    margin-right: 0;
    margin-bottom: 0;
    padding-top: 10px;
    overflow: visible;
}

.nav-meta {
    display: flex;
    gap: 20px;
}

/*****************************************************************
*********** Navigation Footer
******************************************************************/

.nav-footer {
    width: auto;
    height: auto;
    list-style: none !important;
}

.nav-footer-item {
    width: auto;
    height: auto;
    float: none;
    margin-right: 0;
    font-size: 1.2500rem;
}

.nav-footer-link {
    font-size: 1.1250rem;
    line-height: 1.3750rem;
    color: var(--purple);
}

.nav-footer-link:hover span {
    color: var(--pink);
}

.nav-footer-link span {
    color: var(--purple);
    font-size: 1rem;
    line-height: 1.8125rem;
}

.nav-footer-link:hover span {
    color: var(--pink);
}

/*****************************************************************
*********** Lang-Selector
******************************************************************/

.lang-selector {
    float: right;
    width: 16.8750rem;
}

.lang-selector-item {
    display: block;
    float: right;
}

.lang-selector-link {
    display: inline-block;
    padding: 0.6250rem;
}

.lang-selector-link:hover {
    padding: 0.6250rem;
}

.lang-selector-link.lang-de::before {
    content: ' ';
    display: inline-block;
    position: relative;
    background: url('/_images/flagge-de.png') no-repeat;
    width: 1.5625rem;
    height: 0.9375rem;
    background-size: 100% auto;
    margin-right: 0.4375rem;
    margin-top: 0.1875rem;
}

.lang-selector-link.lang-en::before {
    content: ' ';
    display: inline-block;
    position: relative;
    background: url('/_images/flagge-gb.png') no-repeat;
    width: 1.5625rem;
    height: 0.9375rem;
    background-size: 100% auto;
    margin-right: 0.4375rem;
    margin-top: 0.1875rem;
}

@media only screen and (max-width: 30.0000rem) {
    /*****************************************************************
      *********** Header
      ******************************************************************/
    .lang-selector {
        width: 7.1875rem;
    }

    .lang-selector .lang-text {
        display: none !important;
    }
}

/*
******************************************************************
CSS for mobile/responsive navigation
******************************************************************
*/
.mobile-div {
    position: fixed;
    height: 0;
    width: 100vw;
    overflow: hidden;
    z-index: 99999999;
    top: 5.7500rem;
    left: 0;
    transition: ease-in-out 0.6s;
    background-color: #FFF;
}

.mobile-menu {
    height: auto;
    width: auto;
    text-align: center;
    display: block;
}

.close-page-canvas {
    left: 60% !important;
}


/*** menu-trigger
******************************************************************************* */
.menu-trigger {
    display: none;
    height: 1.8125rem;
    width: 3.1250rem;
    cursor: pointer;
    transition: ease-in 0.3s;
    position: absolute;
    top: 2.6250rem;
    right: 2.22rem;
    background: none;
    border: none;
    padding-top: 0.1875rem;
    z-index: 1000;
}

.menu-trigger:focus-visible {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}

.menu-trigger .menu-line {
    transition: ease-in 0.2s;
    width: 100%;
    height: 0.3125rem;
    margin: 0 auto 0.5625rem;
    background: var(--darkblue);
    line-height: 2.22rem;
}

.menu-trigger:hover .menu-line:nth-child(2) {
    width: 80%;
}

.menu-trigger.open .menu-line:nth-child(1) {
    transform: rotate(45deg);
    position: relative;
    top: 0.3750rem;
}

.menu-trigger.open .menu-line:nth-child(2) {
    display: none;
}

.menu-trigger.open .menu-line:nth-child(3) {
    transform: rotate(-45deg);
    position: relative;
    top: -7px;
}

@media only screen and (max-width: 32.22rem) {
    .menu-trigger {
        width: 1.8750rem;
    }

    .menu-trigger .menu-line {
        height: 0.1875rem;
        margin: 0 auto 0.4375rem;
    }

    .menu-trigger.open .menu-line:nth-child(3) {
        top: -4px;
    }
}

.subnav-nav-trigger::before {
    font-family: 'Font Awesome 6 Pro', sans-serif;
    font-weight: 900;
    content: '\f078';
    color: var(--darkblue);
}

.nav2-mobile-item .subnav-nav-trigger {
    display: none;
}

.nav2-mobile-item .subnav-nav-trigger::before {
    color: #000;
}

.subnav-nav-trigger {
    height: 2.0000rem;
    cursor: pointer;
    font-size: 1.5000rem;
    text-align: center;
    overflow: hidden;
    padding: 0.3125rem;
    transition: ease-in-out 0.3s;
    position: absolute;
    right: 2.1875rem;
    top: 0.1875rem;
    transform: rotate(-90deg);
    background: none;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 0.5625rem;
}

.subnav-nav-trigger:focus-visible {
    outline: 0.1875rem solid var(--pink);
}

.subnav-nav-trigger.active:focus-visible {
    outline: 0.1875rem solid #fff;
}

.subnav-nav-trigger.opened {
    transform: rotate(0deg);
}

.nav1-additional {
    padding: 0.7500rem 2.22rem;
    box-sizing: border-box;
    position: relative;
    background: #E4E4E4;
    color: #000 !important;
    font-weight: 900;
}

.nav1-additional-link::before {
    font-family: 'Font Awesome 6 Pro', sans-serif;
    font-size: 1.1250rem;
    margin-right: 1.5625rem;
}

.nav1-additional-link.search::before {
    content: '\f002';
}

.nav1-additional-link.contact::before {
    content: '\f098';
}

.nav1-additional-link.start::before {
    content: '\f015';
}


.nav1-mobile-div {
    overflow: hidden;
    display: none;
    background-color: #fff;
}

.nav1-mobile {
    width: auto;
    text-align: left;
    box-sizing: border-box;
    height: auto;
    overflow: hidden;
}

.nav1-mobile li {
    width: 100%;
    color: #fff;
}

.nav1-mobile-div.menu-2 .nav1-mobile,
.nav1-mobile-div.menu-2 .nav2-mobile {
    height: auto;
    /*position: relative;*/
    /*   top: 50%;
       left: 6.2500rem;*/
    /*transform: translate(-50%, 0%);*/
    border: none;
    display: flex;
    flex-flow: column;
    gap: 0.3125rem;
    background: #fff;
}

.nav1-mobile-div.menu-2 .nav1-mobile-item {
    border: none;

}

.nav1-mobile-item.opened .background {
    background: var(--pink);
}

.nav1-mobile-item.opened > a > span,
.nav1-mobile-item.opened > .subnav-nav-trigger:before {
    color: #fff;
}

.nav1-mobile-div.menu-2 .nav1-link-mobile {

}

.nav1-mobile-div.menu-2 .nav1-link:hover {

}


.nav1-mobile-div.menu-1 {
    position: fixed;
    width: 100vw;
    height: calc(100vh - 5.0000rem);
    top: 5.0000rem;
    right: -100vw;
    transition: ease-in-out .4s;
    border-top: 1.5625rem solid #fff;
}

.nav1-mobile-div.menu-2 {
    position: fixed;
    width: 100vw;
    height: calc(-451px + 100vh);
    right: 0;
    transition: ease-in-out .4s;
    z-index: 999;
    overflow: auto;
    padding-bottom: 0;
    border-top: 1.5625rem solid #fff;
}

.nav1-mobile-div.menu-3 {
    position: fixed;
    width: 60vw;
    height: 100vh;
    top: 0;
    right: -60vw;
    transition: ease-in-out .4s;
}

.nav2-mobile {
    background: #fff;
    margin-left: -80px;
    margin-right: -80px;
    padding: 0.3125rem 2.22rem 0 2.22rem;
    transform: translateY(0.7500rem);
    overflow: hidden;
}

.nav3-mobile {
    background: #fff;
    margin-left: -80px;
    margin-right: -80px;
    padding: 0 2.22rem;
    transform: translateY(0.7500rem);
    display: none;
    overflow: hidden;
}


/************************/


.nav1-mobile-link span {
    color: var(--darkblue);
}

.nav2-mobile-link span {
    color: var(--white);
}

.nav1-mobile-link {
    width: 100%;
    display: inline-block;
}

.nav1-mobile-link.subnav {
    width: calc(100% - 2.8125rem);
}


.nav1-mobile > li {
    background: var(--background-grey);
}

.nav1-mobile > li:has(.active),
.nav1-mobile > li:has(.opened) {
    background: var(--purple);
}

.nav1-mobile-link.active span,
.nav1-mobile-link.opened span {
    color: #fff;
    font-weight: 700;
}


.subnav-nav-trigger.active::before {
    color: #fff;
}

.nav1-mobile-link.active,
.nav1-mobile-link:hover {
    /*background-color: #00528C;*/
}

.nav1-mobile-link:focus {
    outline: none;
}


.nav1-mobile-link:focus-visible span {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1250rem;
}

.nav1-mobile-link.active:focus-visible span {
    outline: 0.1875rem solid #fff;
}

.nav1-mobile-link.active span,
.nav1-mobile-link:hover span {
    /*color: #fff;*/
}

.nav1-mobile-link.active span {
    font-weight: 700;
}

.nav1-mobile-item {
    padding: 0.7500rem 2.22rem;
    box-sizing: border-box;
    position: relative;
    background: #E4E4E4;
}

.nav1-mobile-item .background {
    height: 3.0000rem;
    width: 100%;
    position: absolute;
    z-index: -1;
    left: 0;
    top: 0;
    background: #fff;
}

.nav2-mobile-item {
    padding: 0.7500rem 2.22rem;
    box-sizing: border-box;
    position: relative;
    background: var(--pink);
}

.nav2-mobile-link {
    display: inline-block;
    /*width: calc(100% - 1.8750rem);*/
    padding-left: 20px;
}

.nav2-mobile-link:focus {
    outline: none;
}

.nav2-mobile-link:focus-visible span {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}

.nav2-mobile-link.active span,
.nav2-mobile-link:hover span {
    color: var(--darkblue);
}


.nav3-mobile-item {
    padding: 0.6250rem 2.22rem;
    box-sizing: border-box;
    position: relative;
    background: #EEEEEE;
}

.nav3-mobile-item:last-child {
    border-bottom-left-radius: 0.6250rem;
    border-bottom-right-radius: 0.6250rem;
}

.nav3-mobile-link {
    color: #000;
}

.nav3-mobile-link.active span {
    color: #00528C;
}

.nav3-mobile-link span {
    color: #000;
}

.nav3-mobile-link span:before {
    font-family: 'Font Awesome 6 Pro', sans-serif;
    font-weight: 900;
    content: '\f054';
    color: #000;
    margin-right: 0.5000rem;
}

/*****************************************************************
*********** Lang-Selector
******************************************************************/
.lang-selector-mobile {
    display: none;
}


/*****************************************************************
**** Header
******************************************************************/
#head-canvas {
    width: 100%;
    height: auto;
    box-sizing: border-box;
    overflow: visible;
    position: relative;
    margin: auto;
    display: flex;
    justify-content: space-between;
    gap: 0.8125rem;
    flex-flow: column;
}

.head {
    display: flex;
    max-width: 77.78rem;
    width: 100%;
    margin: 0 auto;
    position: relative;
}

@media screen and (max-width: 1000px) {
    .head {
        flex-direction: column;
    }

    #head-image, .head-text {
        max-width: initial !important;
    }

    .head-text {
        margin-left: 0 !important;
    }
}

#head-canvas .topline .container-top .wrapper {
    max-width: 77.78rem;
    margin: auto;
    position: relative;
    /*height: 9.6875rem;*/
    /*padding: 0 2.22rem;*/
    display: flex;
    justify-content: space-between;
}

#head-canvas .topline .container-top .logo-link {
    /*position: absolute;*/
    margin-top: 2.22rem;
}

#head-canvas .topline .container-top .logo-link:focus-visible {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}

#head-canvas .topline .container-top .logo {
    width: 43.7500rem;
    height: auto;
}

@media screen and (max-width: 1250px) {
    #head-canvas .topline-mobile .logo {
        max-height: 70px;
    }
}

#head-canvas .topline .container-top .topline-code {
    font-size: 5.0000rem;
    font-weight: 700;
    margin-left: 11.1875rem;
    color: var(--pink);
}

#head-canvas .topline .container-top .logo-element {
    position: absolute;
    width: 31.5625rem;
    top: -343px;
    right: 0.6250rem;
    overflow: hidden;
    height: 31.1250rem;
}

#head-canvas .topline .container-top .logo-element .logo-element-image {
    width: 31.5625rem;
}


#head-canvas .topline .container-bottom .wrapper {
    max-width: 77.78rem;
    margin: 0.6875rem auto 0;
    padding: 0 2.22rem;
}

#head-canvas .topline .container-bottom .topline-text {
    font-size: 2.22rem;
    text-transform: uppercase;
    margin-left: 11.1875rem;
}

#head-canvas .topline-mobile {
    display: none;
}


#head-canvas .topline-mobile .logo-link:focus-visible {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}

#head-canvas .topline-mobile .topline-text {
    font-size: 2.0000rem;
    max-width: 23.5000rem;
    display: inline-block;
    text-transform: uppercase;
}

#head-canvas .topline-mobile .wrapper {
    display: flex;
    gap: 2.1875rem;
    align-items: center;
}


/*Nav Umschalten*/
@media only screen and (max-width: 78.1250rem) {
    #head-canvas {
        padding: 1.5625rem 2.22rem 1.5625rem;
        position: relative;
        min-height: 4.6875rem;
        margin-bottom: 30px;
    }

    #head-canvas .topline {
        display: none;
    }

    #head-canvas .topline-mobile {
        display: block;
    }

    .menu-trigger {
        display: block !important;
    }

    #main-navigation {
        display: none !important;
    }
}

@media only screen and (max-width: 40.0000rem) {
    #head-canvas .topline-mobile .topline-text {
        max-width: 19.3750rem;
    }
}

@media only screen and (max-width: 32.22rem) {
    #head-canvas .topline-mobile .wrapper {
        gap: 0.6250rem;
    }

    #head-canvas .topline-mobile .topline-text {
        font-size: 1.1250rem;
        max-width: 14.6875rem;
    }
}

@media only screen and (max-width: 23.7500rem) {
    #head-canvas .topline-mobile .topline-text {
        max-width: calc(100% - 5.6250rem);
    }
}

@media screen and (max-width: 28.125rem) {
    .menu-trigger {
        position: absolute;
        top: 2.0000rem !important;
    }
}


#logo {
    overflow: hidden;
    display: flex;
    align-items: center;
    min-width: 7.5625rem;
}

#logo img {
    width: 100%;
    height: auto;
}

@media only screen and (max-width: 77.78rem) {
    #logo {
        min-width: 5.5625rem;
        position: absolute;
        width: 5.5625rem;
        top: 0.9375rem;
    }
}

@media only screen and (max-width: 64.0000rem) {
    #logo {
        min-width: 3.7500rem;
        position: relative;
        width: 3.7500rem;
        top: 0;
    }
}


#head-image {
    width: 100%;
    max-width: 43.1250rem;
    height: auto;
    box-sizing: border-box;
    border-radius: 0.6250rem 0.6250rem 0 0.6250rem;
    position: relative !important;
}

#head-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.head .button {
    display: flex;
    padding: 0.9375rem 2.22rem;
    border-radius: 0.6250rem 0.6250rem 0 0.6250rem;
    max-width: 12.22rem;
    width: 100%;
    margin-top: 2.22rem;
    justify-content: center;
}

.head .button-icon {
    margin-left: 0.6250rem;
}

.head .head-text.lightblue .button {
    border: 0.1875rem solid var(--darkblue);
    background-color: var(--lightblue);
}

.head .head-text.lightblue .button:hover {
    background-color: var(--darkblue);
}

.head .head-text.lightblue .button .button-text,
.head .head-text.lightblue .button .button-icon i {
    color: var(--darkblue);
}

.head .head-text.lightblue .button:hover .button-text,
.head .head-text.lightblue .button:hover .button-icon i {
    color: var(--white);
}

.head .head-text.pink .text,
.head .head-text.purple .text,
.head .head-text.purple span,
.head .head-text.pink span {
    color: var(--white);
}

.head .head-text.pink .button {
    border: 0.1875rem solid var(--white);
    background-color: var(--pink);
}

.head .head-text.purple .button {
    border: 0.1875rem solid var(--white);
    background-color: var(--purple);
}


.head .head-text.pink .button:hover,
.head .head-text.purple .button:hover {
    background-color: var(--white);
}

.head .head-text.pink .button .button-text,
.head .head-text.pink .button .button-icon i,
.head .head-text.purple .button .button-text,
.head .head-text.purple .button .button-icon i {
    color: var(--white)
}

.head .head-text.pink .button:hover .button-text,
.head .head-text.pink .button:hover .button-icon i {
    color: var(--pink);
}

.head .head-text.purple .button:hover .button-text,
.head .head-text.purple .button:hover .button-icon i {
    color: var(--purple);
}


.head-text {
    box-sizing: border-box;
    width: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: auto;
    padding: 2.22rem 3.4375rem 2.8125rem 1.8750rem;
    display: flex;
    flex-direction: column;
    max-width: 43.1250rem;
    margin-left: 1.2500rem;
}

.head-text .text {
    font-size: 1.875rem;
}

.head-text a::before {
    /*    padding-left: 0.6250rem;*/
    /*padding-right: 0.3125rem;*/
}

.head-text a {
    color: #00569e;
    display: block;
}

.head-text p,
.head-text a {
    font-size: 1.2500rem;
    line-height: 1.5;
    /*1.8750rem*/
}

.head-text strong {
    font-weight: 800;
    color: #00569e;
}

.head-text h3 {
    color: #669d24;
    font-size: 1.5625rem;
    font-weight: bold;
    padding-bottom: 0.8750rem;
    margin-bottom: 0.6250rem;
}

.head-text span {
    font-family: 'caveat', serif;
    font-weight: 600;
    font-size: 3.1250rem;
}

@media only screen and (max-width: 56.89rem) {
    .head-text span, .pageelement-quote .wrapper .quote {
        font-size: 2.5rem;
    }
}

.head #head-image .ai-mark {
    position: absolute;
    bottom: 5px;
    right: 5px;
}

.head #head-image .ai-mark:before {
    content: '';
    background: url(/_images/ai-mark.svg) no-repeat;
    height: 1.5625rem;
    width: 1.5625rem;
    display: block;
    opacity: .4;
}

#head-right {
    display: flex;
    flex-flow: column;
    gap: 2.22rem;
}

#head-image .text-container {
    position: absolute;
    bottom: 0;
    width: 100%;
    background: rgba(242, 242, 242, 0.7);
}

#head-image .text-container .text {
    color: var(--darkblue);
    max-width: 77.78rem;
    margin: 0.3750rem auto;
    font-size: 2.8125rem;
    font-style: italic;
    padding: 0 2.22rem;
    box-sizing: content-box;
}

@media only screen and (max-width: 77.78rem) {
    #head-right {
        margin-left: auto;
    }

    #head-image .text-container .text {
        font-size: 1.8750rem;
    }
}

@media only screen and (max-width: 56.2500rem) {
    #head-image .text-container {
        display: none;
    }
}

.top-navigation {
    display: inline-block;
    align-self: flex-end;
}

.top-navigation .contact {
    align-items: flex-end;
    display: flex;
    gap: 3.1250rem;
}

.top-navigation .contact .telephone,
.top-navigation .contact .email {
    color: var(--pink);
    display: flex;
    gap: 0.6250rem;
}

.top-navigation .contact .telephone:hover,
.top-navigation .contact .email:hover {
    color: #707070;
}

.top-navigation .contact .telephone .text,
.top-navigation .contact .email .text {
    color: inherit;
    font-size: 1.1250rem;
}

.top-navigation .contact .telephone:before {
    font-family: 'Font Awesome 6 Pro', sans-serif;
    font-size: 1.1250rem;
    content: '\f095';
}


.top-navigation .contact .email:before {
    font-family: 'Font Awesome 6 Pro', sans-serif;
    font-size: 1.1250rem;
    content: '\f0e0';
}

@media only screen and (max-width: 64.0000rem) {
    .top-navigation {
        position: absolute;
        right: 6.2500rem;
        top: 1.6250rem;
    }
}

@media only screen and (max-width: 40.6250rem) {

    .top-navigation .contact {
        gap: 2.1875rem;
    }

    .top-navigation .contact .telephone .text,
    .top-navigation .contact .email .text {
        display: none;
    }

    .top-navigation .contact .telephone:before {
        content: '\f098';
        font-size: 2.0000rem;
    }

    .top-navigation .contact .email:before {
        content: '\f199';
        font-size: 2.0000rem;
    }
}

.head-text {
    box-sizing: border-box;
    display: block;
}

#head-image {
    display: flex;
    flex-direction: column;
}

#head-image .copyright {
    font-size: 0.7500rem;
    padding: 0.3125rem 0.3125rem 0 0.3125rem;
    z-index: 5;
    position: absolute;
    right: 0;
    bottom: -15px;
}

/*****************************************************************
**** Footer
******************************************************************/

.banner {
    top: 7.3750rem;
    position: fixed;
    background: var(--pink);
    color: #fff;
    border-top-left-radius: 0.6250rem;
    border-bottom-left-radius: 0.6250rem;
    height: 5.0000rem;
    width: 5.6250rem;
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    right: 0;
    z-index: 1401;
    box-sizing: border-box;
    padding-left: 0.1875rem;
    border: 0.1250rem solid #fff;
}

.banner:focus-visible {
    outline: 0.3125rem dotted var(--darkblue);
    border: 0.4375rem double #fff;
}

.banner .label {
    color: #fff;
}

.search-banner {
    top: 27.8125rem;
    flex-flow: row;
    width: 21.5625rem;
    padding-top: 0;
    transition: .25s all ease-in-out;
    right: -200px;
    cursor: pointer;
}

.search-banner .left {
    width: 5.0000rem;
    height: 5.0000rem;
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: center;
}

.search-banner .right input {
    width: 14.3750rem;
    font-size: 1.3750rem;
    padding: 0.1875rem 0.7500rem;
    box-sizing: border-box;
    margin-left: 0.9375rem;
    margin-right: 0.9375rem;
    height: 2.1875rem;
}

.search-banner .right input:focus-visible {
    outline: 0.1875rem solid #fff;
    outline-offset: 0.1250rem;
}

.member-banner {
    top: 33.4375rem;
}

.contact-banner {
    top: 22.1875rem;
}

.search-banner .icon {
    transform: translateY(0.1250rem);
}

.search-banner .icon::before {
    content: '\f002';
    font-family: 'Font Awesome 6 Pro', sans-serif;
    font-weight: 400;
    font-size: 1.3750rem;
    color: #fff;
}

.member-banner .icon::before {
    content: '\f234';
    font-family: 'Font Awesome 6 Pro', sans-serif;
    font-weight: 400;
    font-size: 1.3750rem;
    color: #fff;
}

.contact-banner .icon::before {
    content: '\f007';
    font-family: 'Font Awesome 6 Pro', sans-serif;
    font-weight: 400;
    font-size: 1.3750rem;
    color: #fff;
}

.search-banner .label,
.member-banner .label,
.contact-banner .label {
    font-size: 1.2500rem;
    margin-top: 0.4375rem;
    font-weight: 400;
}

.member-banner .label {
    line-height: 1.0625rem;
    text-align: center;
    margin-top: 0.3750rem;
}

.search-banner .label {
    margin-top: 0.0625rem;
}

@media only screen and (max-width: 100.0000rem) {
    .contact-banner {
        top: 19.6875rem;
    }

    .search-banner {
        top: 25.3125rem;
    }

    .member-banner {
        top: 30.9375rem;
    }
}

@media only screen and (max-width: 56.2500rem) {
    .banner {
        display: none;
    }
}


/* Footer Social-Media */

#footer-socialmedia .heading-container {
    max-width: 77.78rem;
    display: block;
    margin: 0 auto 1.2500rem;
    padding: 0 2.22rem;
    box-sizing: content-box;
}

#footer-socialmedia h3 {
    font-family: 'caveat', sans-serif;
    font-size: 3.1250rem;
    color: var(--darkblue);
    font-weight: 600;
}

@media screen and (max-width: 31.25rem) {
    #footer-socialmedia h3 {
        font-size: 1.875rem;
    }

    #footer-socialmedia .content-container p,
    #footer-socialmedia .content-container a {
        font-size: 1.125rem !important;
    }
}

#footer-socialmedia .wrapper {
    background-color: var(--purple);
    min-height: 6.2500rem;
    margin-bottom: 1.8750rem;
    display: flex;
}

#footer-socialmedia .inner-wrapper {
    display: flex;
    max-width: 77.78rem;
    gap: 3.1250rem;
    width: 100%;
    margin: 0 auto;
    justify-content: space-evenly;
    align-items: center;
}

@media screen and (max-width: 77.778rem) {
    #footer-socialmedia .inner-wrapper {
        padding: 0 2.222rem;
    }

}

#footer-socialmedia .social-media {
    display: flex;
}

#footer-socialmedia .content-container {
    width: 100%;
    gap: 0.6250rem;
    display: flex;
    flex-direction: row;
    padding: 0;
    align-self: center;
    margin: 0;
}

#footer-socialmedia .content-container p,
#footer-socialmedia .content-container a {
    color: var(--white);
    font-size: 1.3750rem;
    padding: 1.2500rem 0;
}

#footer-socialmedia .newsletter {
    padding: 0.9375rem 0;
    width: 45%;
}

#footer-socialmedia .newsletter-label {
    font-size: 1.3750rem;
    font-weight: 500;
    margin-bottom: 0.8125rem;
    display: inline-block;
}

#footer-socialmedia .newsletter-submit {
    width: 8.8750rem;
    height: 2.8125rem;
    background: var(--pink);
    border: none;
    border-radius: 0.6250rem;
    font-size: 1.0000rem;
    color: #fff;
    font-weight: 500;
    cursor: pointer;
    max-width: 25.5000rem;
}

#footer-socialmedia .newsletter-submit:focus-visible {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}

#footer-socialmedia .newsletter-submit:hover {
    background: var(--pink-hover);
}


#footer-socialmedia .newsletter-input {
    display: flex;
    gap: 0.7500rem;
}

#newsletter-registration {
    width: 25.5000rem;
    max-width: 100%;
    height: 2.8125rem;
    border: 0.0625rem solid var(--pink);
    padding: 0.3125rem 0.9375rem;
    box-sizing: border-box;
    font-size: 1.3750rem;
}

#newsletter-registration:focus-visible {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}


#footer-socialmedia #facebook-link::before,
#footer-socialmedia #instagram-link::before,
#footer-socialmedia #twitter-link::before,
#footer-socialmedia #youtube-link::before,
#footer-socialmedia #xing-link::before,
#footer-socialmedia #linkedin-link::before,
#footer-socialmedia #tiktok-link::before {
    font-size: 2.6875rem;
    font-family: 'Font Awesome 6 Brands', sans-serif;
    display: block;
    width: 6.2500rem;
    vertical-align: middle;
    color: var(--white);
}

#footer-socialmedia .content-container a {
    display: flex;
    align-items: center;
    text-align: center;
}

#footer-socialmedia .content-container a:focus-visible {
    outline: 0.1875rem solid white;
    outline-offset: 3px;
}

#footer-socialmedia #facebook-link::before {
    content: '\f09a';
}

#footer-socialmedia #instagram-link::before {
    content: '\f16d';
}

#footer-socialmedia #twitter-link::before {
    content: '\e61b';
}

#footer-socialmedia #youtube-link::before {
    content: '\f167';
}

#footer-socialmedia #xing-link::before {
    content: '\f168';
}

#footer-socialmedia #linkedin-link::before {
    content: '\f08c';
}

#footer-socialmedia #tiktok-link::before {
    content: '\e07b';
}

#footer-socialmedia .social-media-text {
    overflow-wrap: break-word;
    word-break: break-word;
    word-wrap: break-word;
    font-weight: 500;
    font-size: 1.3750rem;
}

@media only screen and (max-width: 77.78rem) {
    #footer-socialmedia .newsletter {
        width: 100%;
    }

    #footer-socialmedia .inner-wrapper {
        gap: 0;
        justify-content: center;
    }
}


@media (max-width: 77.78rem) {
    #footer-socialmedia .heading-container {
        text-align: center;
    }

    #footer-socialmedia .newsletter-input {
        flex-flow: column;
        align-items: center;
    }

    #footer-socialmedia .newsletter-submit {
        width: 100%;
        text-align: center;
    }

    #footer-socialmedia .newsletter-label {
        width: 100%;
        text-align: center;
    }
}

@media (max-width: 75rem) {
    #footer-socialmedia .content-container {
        flex-flow: column;
        gap: 0;
        margin-bottom: 10px;
    }

    #footer-socialmedia .content-container a {
        padding: 0.6250rem;
        line-height: 1.5;
        display: flex;
        flex-flow: column;
    }
}

/*****************************************************************
**** Footer
******************************************************************/
#footer-canvas {
    height: auto;
    box-sizing: content-box;
    overflow: hidden;
    position: relative;
    padding: 1.8750rem 2.22rem 3.7500rem;
    max-width: 77.78rem;
    margin: auto;
    display: flex;
    justify-content: space-between;
    gap: 1.8750rem;
    flex-wrap: wrap;
}

#footer-canvas .column {
    box-sizing: border-box;
    margin-left: 0;
}

#footer-canvas .column.image {
    width: 5.5000rem;
}

#footer-canvas .column .text {
    line-height: 1.8125rem;
    font-size: 1rem;
}


#footer-bar {
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    position: relative;
    max-width: 77.78rem;
    margin: auto;
    padding: 0 0 0.9375rem;
}

#footer-canvas .copyright {
    margin-top: 0.9375rem;
}

#footer-canvas .social-media-link {
    display: flex;
    align-items: center;
    gap: 0.5000rem;
    color: #fff;
    font-size: 1.1250rem;
}

#footer-canvas .nav-footer,
#footer-canvas .column .text,
#footer-canvas .column .external-links-list,
#footer-canvas .socialmedia-icons {
    display: flex;
    flex-flow: column;
}

#footer-canvas .column .external-links-list .list-item {
    font-size: 1.2500rem;
}

#footer-canvas .column .text {
    gap: 0;
}

#footer-canvas .social-media-link i {
    font-size: 2.0625rem;
    color: #fff;
}

#footer-canvas #youtube-link.social-media-link::before {
    font-family: 'Font Awesome 6 Brands', sans-serif;
    font-size: 1.5000rem;
    content: '\f167';
    width: 1.5625rem;
}

#footer-canvas #twitter-link.social-media-link::before {
    font-family: 'Font Awesome 6 Brands', sans-serif;
    font-size: 1.5000rem;
    content: '\e61b';
    width: 1.5625rem;
}

#footer-canvas #facebook-link.social-media-link::before {
    font-family: 'Font Awesome 6 Brands', sans-serif;
    font-size: 1.5000rem;
    content: '\f09a';
    width: 1.5625rem;
}

#footer-canvas #instagram-link.social-media-link::before {
    font-family: 'Font Awesome 6 Brands', sans-serif;
    font-size: 1.5000rem;
    content: '\f16d';
    width: 1.5625rem;
}

#footer-canvas #xing-link.social-media-link::before {
    font-family: 'Font Awesome 6 Brands', sans-serif;
    font-size: 1.5000rem;
    content: '\f168';
    width: 1.5625rem;
}

#footer-canvas #linkedin-link.social-media-link::before {
    font-family: 'Font Awesome 6 Brands', sans-serif;
    font-size: 1.5000rem;
    content: '\f08c';
    width: 1.5625rem;
}

#footer-canvas #tiktok-link.social-media-link::before {
    font-family: 'Font Awesome 6 Brands', sans-serif;
    font-size: 1.5000rem;
    content: '\e07b';
    width: 1.5625rem;
}

#footer-canvas #x-link.social-media-link::before {
    font-family: 'Font Awesome 6 Brands', sans-serif;
    font-size: 1.5000rem;
    content: '\e61b';
    width: 1.5625rem;
}

#footer-canvas a:hover {
    color: var(--pink);
}

#footer-canvas a:focus-visible {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}

@media only screen and (max-width: 90.6250rem) {
    #footer-bar {
        margin-left: 3.1250rem;
    }

    #footer-canvas {
        padding: 1.5625rem 2.22rem 4.3750rem;
    }
}

@media only screen and (max-width: 76.2500rem) {
    .nav-footer {
        box-sizing: border-box;
    }

    #footer-bar {
        box-sizing: border-box;
        display: block;
        text-align: center;
        margin-left: 0;
    }
}

@media only screen and (max-width: 75.0000rem) {
    #footer-canvas {
        padding: 1.5625rem 2.22rem;
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    #footer-canvas .column {
        margin-bottom: 1.5625rem;
    }

    #footer-canvas .socialmedia-icons {
        display: flex;
        justify-content: start;
        align-items: center;
    }

    #footer-canvas .social-media-link {
        float: none;
    }

    #footer-canvas .column .text {
        display: flex;
        flex-flow: column;
        align-items: center;
    }

}

@media only screen and (max-width: 53.7500rem) {
    #footer-canvas .column {
        width: auto;
        float: none;
        margin: auto;
        text-align: center;
        padding: 0 0 1.5625rem;
    }

    #footer-canvas .column.right-column {
        display: flex;
        justify-content: center;
        flex-direction: column;
    }

    #footer-canvas .socialmedia-icons {
        justify-content: center !important;
    }
}

.footer-end-links {
    display: flex;
    justify-content: center;
    padding: 0.6250rem 0;
    border-top: 0.3125rem solid var(--purple);
}

.footer-end-links a {
    color: var(--purple);
    text-align: center;
    border-left: 0.0625rem solid var(--purple);
    padding: 0 0.5000rem;
    font-size: 1rem;
    font-weight: 400;
}

.footer-end-links a:hover {
    color: var(--pink);
}

.footer-end-links a:focus-visible {
    outline: 0.1875rem solid var(--pink);
    border-color: var(--pink);
}

.footer-end-links a:first-child {
    border-left: unset;
}

@media only screen and (max-width: 32.22rem) {
    .footer-end-links {
        flex-flow: column;
        gap: 0.3125rem;
        align-items: center;
    }

    .footer-end-links a {
        border-left: unset;
        width: fit-content;
    }
}

/* skiplinks */
.skiplink {
    position: absolute;
    top: 0;
    left: 0;
    transform: translateY(-100%);
    background-color: var(--pink);
    color: #fff;
    padding: 1.2500rem 1.8750rem;
    z-index: 1000000;
    font-size: 1.6250rem;
    text-decoration: underline !important;
}

.skiplink:focus-visible {
    transform: translateY(0);
    outline: 0.1250rem solid #fff;
}

/*****************************************************************
**** Slider
******************************************************************/
#slider {
    width: 100%;
    display: block;
    overflow: hidden;
}

.slider-caption {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    margin: 0 auto;
    height: 13.1250rem;
    transform: translate(0, -50%);
}

.slider-caption span {
    display: block;
    text-align: center;
}

@media only screen and (max-width: 56.2500rem) {
    .slider-caption {
        display: none !important;
    }
}

/*** Footer
******************************************************************/
.footer-background {
}

.footer-background h2 {
    color: var(--purple);
    font-size: 1.1250rem;
    font-weight: 700;
    margin-bottom: 0.6250rem;
}

#footer-canvas .text-p {
    font-size: 1rem;
    line-height: 1.8125rem;
}

#footer-canvas .text,
#footer-canvas .text-p,
#footer-canvas .copyright,
#footer-bar-left,
#footer-bar-right {
    color: var(--purple);
}


#footer-canvas .text-p.telephone,
#footer-canvas .text-p.mobile,
#footer-canvas .text-p.email,
#footer-canvas .text-p.website,
#footer-canvas .text-p.fax {
    display: flex;
    gap: 0.5000rem;
    font-size: 1rem;
    line-height: 1.8125rem;
    width: fit-content;
}

#footer-canvas .text-p.mobile {
    gap: 0.8125rem;
}


#footer-canvas .text-p.telephone:before {
    content: '\f095';
    font-family: 'Font Awesome 6 Pro', sans-serif;
    color: var(--purple);
}

#footer-canvas .text-p.mobile:before {
    content: '\f3ce';
    font-family: 'Font Awesome 6 Pro', sans-serif;
    color: var(--purple);
}

#footer-canvas .text-p.email:before {
    content: '\f0e0';
    font-family: 'Font Awesome 6 Pro', sans-serif;
    color: var(--purple);
}

#footer-canvas .text-p.website:before {
    content: "\f0ac";
    font-family: 'Font Awesome 6 Pro', sans-serif;
    color: var(--purple);
}

#footer-canvas .text-p.fax:before {
    content: '\f1ac';
    font-family: 'Font Awesome 6 Pro', sans-serif;
    color: var(--purple);
}

#footer-canvas .text-p.fax {
    color: var(--purple) !important;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -webkit-text-fill-color: var(--purple);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

#footer-canvas .column.external-links .external-links-list .list-item .link:after {
    content: '\e09f';
    font-family: 'Font Awesome 6 Pro', sans-serif;
    margin-left: 0.5000rem;
    color: var(--purple);
}

#footer-canvas .column.external-links .external-links-list .list-item .link.intern:after {
    content: '\f061';
}


/*****************************************************************
**** General
******************************************************************/
.content-container, .page-headline-container {
    margin: 0 auto 3.1230rem;
    display: flex;
    max-width: 77.78rem;
    justify-content: space-between;
    flex-direction: column;
}

.page-headline-container {
    margin: 0 auto 0;
}

.page-headline-container .button-logout {
    background: var(--pink);
    color: #fff;
    width: 16rem;
    height: 4.1rem;
    font-size: 1.5rem;
    font-weight: 700;
    border-radius: 0.6250rem 0.6250rem 0 0.6250rem;
    border: none;
    cursor: pointer;
    margin-bottom: 3.1230rem;
}

.page-headline-container .button-logout:hover {
    background: var(--purple);
}

.page-headline-container .button-logout:focus-visible {
    outline: 0.1875rem solid var(--pink);
    outline-offset: 0.1875rem;
}

@media screen and (max-width: 77.778rem) {
    .content-container, .page-headline-container {
        padding: 0 2.222rem;
    }
}

.ai-mark {
    position: absolute;
    bottom: 1.2500rem;
    right: 0.6250rem;
}

.ai-mark:before {
    content: '';
    background: url(/_images/ai-mark.svg) no-repeat;
    height: 1.5625rem;
    width: 1.5625rem;
    display: block;
    opacity: .4;
}


#textOptOut {
    max-width: 77.78rem;
    width: 100%;
    margin: 0 auto;
}

/* Monats-Gruppierung für Events */
.events-calendarlist .month-section {
    margin-bottom: 3.1250rem;
}

.events-calendarlist .month-header {
    font-family: 'caveat', sans-serif;
    font-size: 3rem;
    font-weight: 600;
    color: var(--pink);
    margin-bottom: 1.8750rem;
    padding-bottom: 0.6250rem;
    border-bottom: 0.1875rem solid var(--background-grey);
}

.events-calendarlist .month-section:last-child {
    margin-bottom: 1.8750rem;
}

@media only screen and (max-width: 56.89rem) {
    .events-calendarlist .month-header {
        font-size: 2.67rem;
    }
}

@media only screen and (max-width: 28.89rem) {
    .events-calendarlist .month-header {
        font-size: 2.22rem;
        margin-bottom: 1.2500rem;
    }
}