/*-----------------------------------
    Custom Variables 
------------------------------------*/
:root {
    --cnvs-themecolor: #fff;
    --fai-blue: #D9E8EF;
    --cnvs-owl-nav-color: #fff;
    --cnvs-owl-nav-background: #fff;
    --bs-body-font-size: 20px;
    
    /** Hyper Links **/
    --bs-link-color: #ff0000;
    --bs-link-color-rgb: 255, 0, 0;
    --bs-link-decoration: none;
    --bs-link-hover-color: #000;
    --bs-link-hover-color-rgb: 0, 0, 0;
}


/* Tablet (max-width: 1024px) */
@media (max-width: 1024px) {

}

/* Mobile (max-width: 768px) */
@media (max-width: 768px) {


}

/* Small Mobile (max-width: 480px) */
@media (max-width: 480px) {

}



.pulse-animation {
    animation: customPulse 1s ease-in-out;
}


@keyframes customPulse {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.5);
    }
    100% {
        transform: scale(1);
    }
}

/* ============================= */
/*      Variablen-Deklaration    */
/* ============================= */
:root {

    --section-headline-color: #000;
    
    
    /* Margin Defaults */
    --fai-margin-top: 0;
    --fai-margin-right: 0;
    --fai-margin-bottom: 0;
    --fai-margin-left: 0;

    /* Padding Defaults */
    --fai-padding-top: 0;
    --fai-padding-right: 0;
    --fai-padding-bottom: 0;
    --fai-padding-left: 0;

    /* Font-Size Defaults */
    --fai-font-size: 1rem;

    /* Letter-Spacing Defaults */
    --fai-letter-spacing: normal;

    /* Breakpoint-spezifische Overrides – setze hier nur Werte, wenn du sie anpassen möchtest */
    /* Margin Overrides */
    --fai-margin-top-sm: unset;
    --fai-margin-right-sm: unset;
    --fai-margin-bottom-sm: unset;
    --fai-margin-left-sm: unset;

    --fai-margin-top-md: unset;
    --fai-margin-right-md: unset;
    --fai-margin-bottom-md: unset;
    --fai-margin-left-md: unset;

    --fai-margin-top-lg: unset;
    --fai-margin-right-lg: unset;
    --fai-margin-bottom-lg: unset;
    --fai-margin-left-lg: unset;

    --fai-margin-top-xl: unset;
    --fai-margin-right-xl: unset;
    --fai-margin-bottom-xl: unset;
    --fai-margin-left-xl: unset;

    --fai-margin-top-xxl: unset;
    --fai-margin-right-xxl: unset;
    --fai-margin-bottom-xxl: unset;
    --fai-margin-left-xxl: unset;

    /* Padding Overrides */
    --fai-padding-top-sm: unset;
    --fai-padding-right-sm: unset;
    --fai-padding-bottom-sm: unset;
    --fai-padding-left-sm: unset;

    --fai-padding-top-md: unset;
    --fai-padding-right-md: unset;
    --fai-padding-bottom-md: unset;
    --fai-padding-left-md: unset;

    --fai-padding-top-lg: unset;
    --fai-padding-right-lg: unset;
    --fai-padding-bottom-lg: unset;
    --fai-padding-left-lg: unset;

    --fai-padding-top-xl: unset;
    --fai-padding-right-xl: unset;
    --fai-padding-bottom-xl: unset;
    --fai-padding-left-xl: unset;

    --fai-padding-top-xxl: unset;
    --fai-padding-right-xxl: unset;
    --fai-padding-bottom-xxl: unset;
    --fai-padding-left-xxl: unset;

    /* Font-Size Overrides */
    --fai-font-size-sm: unset;
    --fai-font-size-md: unset;
    --fai-font-size-lg: unset;
    --fai-font-size-xl: unset;
    --fai-font-size-xxl: unset;

    /* Letter-Spacing Overrides */
    --fai-letter-spacing-sm: unset;
    --fai-letter-spacing-md: unset;
    --fai-letter-spacing-lg: unset;
    --fai-letter-spacing-xl: unset;
    --fai-letter-spacing-xxl: unset;
}

/* ============================= */
/*         Basis-Klassen         */
/* ============================= */

/* Margin Klassen */
.fai-margin-top {
    margin-top: var(--fai-margin-top, 0);
}
.fai-margin-right {
    margin-right: var(--fai-margin-right, 0);
}
.fai-margin-bottom {
    margin-bottom: var(--fai-margin-bottom, 0);
}
.fai-margin-left {
    margin-left: var(--fai-margin-left, 0);
}

/* Padding Klassen */
.fai-padding-top {
    padding-top: var(--fai-padding-top, 0);
}
.fai-padding-right {
    padding-right: var(--fai-padding-right, 0);
}
.fai-padding-bottom {
    padding-bottom: var(--fai-padding-bottom, 0);
}
.fai-padding-left {
    padding-left: var(--fai-padding-left, 0);
}

/* Font Size */
.fai-font-size {
    font-size: var(--fai-font-size, 1rem);
}

/* Letter Spacing */
.fai-letter-spacing {
    letter-spacing: var(--fai-letter-spacing, normal);
}

/* ============================= */
/*      Responsive Klassen       */
/* ============================= */

/* sm: min-width 576px */
@media (min-width: 576px) {
    .fai-margin-top    { margin-top:    var(--fai-margin-top-sm,    var(--fai-margin-top, 0)); }
    .fai-margin-right  { margin-right:  var(--fai-margin-right-sm,  var(--fai-margin-right, 0)); }
    .fai-margin-bottom { margin-bottom: var(--fai-margin-bottom-sm, var(--fai-margin-bottom, 0)); }
    .fai-margin-left   { margin-left:   var(--fai-margin-left-sm,   var(--fai-margin-left, 0)); }

    .fai-padding-top    { padding-top:    var(--fai-padding-top-sm,    var(--fai-padding-top, 0)); }
    .fai-padding-right  { padding-right:  var(--fai-padding-right-sm,  var(--fai-padding-right, 0)); }
    .fai-padding-bottom { padding-bottom: var(--fai-padding-bottom-sm, var(--fai-padding-bottom, 0)); }
    .fai-padding-left   { padding-left:   var(--fai-padding-left-sm,   var(--fai-padding-left, 0)); }

    .fai-font-size      { font-size:      var(--fai-font-size-sm,      var(--fai-font-size, 1rem)); }
    .fai-letter-spacing { letter-spacing: var(--fai-letter-spacing-sm, var(--fai-letter-spacing, normal)); }
}

/* md: min-width 768px */
@media (min-width: 768px) {
    .fai-margin-top    { margin-top:    var(--fai-margin-top-md,    var(--fai-margin-top-sm,    var(--fai-margin-top, 0))); }
    .fai-margin-right  { margin-right:  var(--fai-margin-right-md,  var(--fai-margin-right-sm,  var(--fai-margin-right, 0))); }
    .fai-margin-bottom { margin-bottom: var(--fai-margin-bottom-md, var(--fai-margin-bottom-sm, var(--fai-margin-bottom, 0))); }
    .fai-margin-left   { margin-left:   var(--fai-margin-left-md,   var(--fai-margin-left-sm,   var(--fai-margin-left, 0))); }

    .fai-padding-top    { padding-top:    var(--fai-padding-top-md,    var(--fai-padding-top-sm,    var(--fai-padding-top, 0))); }
    .fai-padding-right  { padding-right:  var(--fai-padding-right-md,  var(--fai-padding-right-sm,  var(--fai-padding-right, 0))); }
    .fai-padding-bottom { padding-bottom: var(--fai-padding-bottom-md, var(--fai-padding-bottom-sm, var(--fai-padding-bottom, 0))); }
    .fai-padding-left   { padding-left:   var(--fai-padding-left-md,   var(--fai-padding-left-sm,   var(--fai-padding-left, 0))); }

    .fai-font-size      { font-size:      var(--fai-font-size-md,      var(--fai-font-size-sm,      var(--fai-font-size, 1rem))); }
    .fai-letter-spacing { letter-spacing: var(--fai-letter-spacing-md, var(--fai-letter-spacing-sm, var(--fai-letter-spacing, normal))); }
}

/* lg: min-width 992px */
@media (min-width: 992px) {
    .fai-margin-top    { margin-top:    var(--fai-margin-top-lg,    var(--fai-margin-top-md,    var(--fai-margin-top-sm,    var(--fai-margin-top, 0)))); }
    .fai-margin-right  { margin-right:  var(--fai-margin-right-lg,  var(--fai-margin-right-md,  var(--fai-margin-right-sm,  var(--fai-margin-right, 0)))); }
    .fai-margin-bottom { margin-bottom: var(--fai-margin-bottom-lg, var(--fai-margin-bottom-md, var(--fai-margin-bottom-sm, var(--fai-margin-bottom, 0)))); }
    .fai-margin-left   { margin-left:   var(--fai-margin-left-lg,   var(--fai-margin-left-md,   var(--fai-margin-left-sm,   var(--fai-margin-left, 0)))); }

    .fai-padding-top    { padding-top:    var(--fai-padding-top-lg,    var(--fai-padding-top-md,    var(--fai-padding-top-sm,    var(--fai-padding-top, 0)))); }
    .fai-padding-right  { padding-right:  var(--fai-padding-right-lg,  var(--fai-padding-right-md,  var(--fai-padding-right-sm,  var(--fai-padding-right, 0)))); }
    .fai-padding-bottom { padding-bottom: var(--fai-padding-bottom-lg, var(--fai-padding-bottom-md, var(--fai-padding-bottom-sm, var(--fai-padding-bottom, 0)))); }
    .fai-padding-left   { padding-left:   var(--fai-padding-left-lg,   var(--fai-padding-left-md,   var(--fai-padding-left-sm,   var(--fai-padding-left, 0)))); }

    .fai-font-size      { font-size:      var(--fai-font-size-lg,      var(--fai-font-size-md,      var(--fai-font-size-sm,      var(--fai-font-size, 1rem)))); }
    .fai-letter-spacing { letter-spacing: var(--fai-letter-spacing-lg, var(--fai-letter-spacing-md, var(--fai-letter-spacing-sm, var(--fai-letter-spacing, normal)))); }
}

/* xl: min-width 1200px */
@media (min-width: 1200px) {
    .fai-margin-top    { margin-top:    var(--fai-margin-top-xl,    var(--fai-margin-top-lg,    var(--fai-margin-top-md,    var(--fai-margin-top-sm,    var(--fai-margin-top, 0))))); }
    .fai-margin-right  { margin-right:  var(--fai-margin-right-xl,  var(--fai-margin-right-lg,  var(--fai-margin-right-md,  var(--fai-margin-right-sm,  var(--fai-margin-right, 0))))); }
    .fai-margin-bottom { margin-bottom: var(--fai-margin-bottom-xl, var(--fai-margin-bottom-lg, var(--fai-margin-bottom-md, var(--fai-margin-bottom-sm, var(--fai-margin-bottom, 0))))); }
    .fai-margin-left   { margin-left:   var(--fai-margin-left-xl,   var(--fai-margin-left-lg,   var(--fai-margin-left-md,   var(--fai-margin-left-sm,   var(--fai-margin-left, 0))))); }

    .fai-padding-top    { padding-top:    var(--fai-padding-top-xl,    var(--fai-padding-top-lg,    var(--fai-padding-top-md,    var(--fai-padding-top-sm,    var(--fai-padding-top, 0))))); }
    .fai-padding-right  { padding-right:  var(--fai-padding-right-xl,  var(--fai-padding-right-lg,  var(--fai-padding-right-md,  var(--fai-padding-right-sm,  var(--fai-padding-right, 0))))); }
    .fai-padding-bottom { padding-bottom: var(--fai-padding-bottom-xl, var(--fai-padding-bottom-lg, var(--fai-padding-bottom-md, var(--fai-padding-bottom-sm, var(--fai-padding-bottom, 0))))); }
    .fai-padding-left   { padding-left:   var(--fai-padding-left-xl,   var(--fai-padding-left-lg,   var(--fai-padding-left-md,   var(--fai-padding-left-sm,   var(--fai-padding-left, 0))))); }

    .fai-font-size      { font-size:      var(--fai-font-size-xl,      var(--fai-font-size-lg,      var(--fai-font-size-md,      var(--fai-font-size-sm,      var(--fai-font-size, 1rem))))); }
    .fai-letter-spacing { letter-spacing: var(--fai-letter-spacing-xl, var(--fai-letter-spacing-lg, var(--fai-letter-spacing-md, var(--fai-letter-spacing-sm, var(--fai-letter-spacing, normal))))); }
}

/* xxl: min-width 1400px */
@media (min-width: 1400px) {
    .fai-margin-top    { margin-top:    var(--fai-margin-top-xxl,    var(--fai-margin-top-xl,    var(--fai-margin-top-lg,    var(--fai-margin-top-md,    var(--fai-margin-top-sm,    var(--fai-margin-top, 0)))))); }
    .fai-margin-right  { margin-right:  var(--fai-margin-right-xxl,  var(--fai-margin-right-xl,  var(--fai-margin-right-lg,  var(--fai-margin-right-md,  var(--fai-margin-right-sm,  var(--fai-margin-right, 0)))))); }
    .fai-margin-bottom { margin-bottom: var(--fai-margin-bottom-xxl, var(--fai-margin-bottom-xl, var(--fai-margin-bottom-lg, var(--fai-margin-bottom-md, var(--fai-margin-bottom-sm, var(--fai-margin-bottom, 0)))))); }
    .fai-margin-left   { margin-left:   var(--fai-margin-left-xxl,   var(--fai-margin-left-xl,   var(--fai-margin-left-lg,   var(--fai-margin-left-md,   var(--fai-margin-left-sm,   var(--fai-margin-left, 0)))))); }

    .fai-padding-top    { padding-top:    var(--fai-padding-top-xxl,    var(--fai-padding-top-xl,    var(--fai-padding-top-lg,    var(--fai-padding-top-md,    var(--fai-padding-top-sm,    var(--fai-padding-top, 0)))))); }
    .fai-padding-right  { padding-right:  var(--fai-padding-right-xxl,  var(--fai-padding-right-xl,  var(--fai-padding-right-lg,  var(--fai-padding-right-md,  var(--fai-padding-right-sm,  var(--fai-padding-right, 0)))))); }
    .fai-padding-bottom { padding-bottom: var(--fai-padding-bottom-xxl, var(--fai-padding-bottom-xl, var(--fai-padding-bottom-lg, var(--fai-padding-bottom-md, var(--fai-padding-bottom-sm, var(--fai-padding-bottom, 0)))))); }
    .fai-padding-left   { padding-left:   var(--fai-padding-left-xxl,   var(--fai-padding-left-xl,   var(--fai-padding-left-lg,   var(--fai-padding-left-md,   var(--fai-padding-left-sm,   var(--fai-padding-left, 0)))))); }

    .fai-font-size      { font-size:      var(--fai-font-size-xxl,      var(--fai-font-size-xl,      var(--fai-font-size-lg,      var(--fai-font-size-md,      var(--fai-font-size-sm,      var(--fai-font-size, 1rem)))))); }
    .fai-letter-spacing { letter-spacing: var(--fai-letter-spacing-xxl, var(--fai-letter-spacing-xl, var(--fai-letter-spacing-lg, var(--fai-letter-spacing-md, var(--fai-letter-spacing-sm, var(--fai-letter-spacing, normal)))))); }
}


/*-----------------------------------
***
*** Custom Styles
***
 ------------------------------------*/

html, body, * {
    font-family: 'Lato', sans-serif !important;    
}

a{
    text-decoration: none;
}

strong {
    font-weight: 700;
}


.form-check-label {
    font-size: 16px;
}


.form-check-input {
    width: 30px;
    height: 30px;
    border: 1px solid #dee2e6;
}

.form-check-input[type=checkbox] {
    border-radius: 5px;
}

.header-video-height {
    min-height: 90vh;
}

@media (max-width: 1024px) {
    .header-video-height {
        min-height: 75vh;
    }
}

@media (max-width: 992px) {
    .header-video-height {
        min-height: 55vh;
    }
}

@media (max-width: 768px) {
    .header-video-height {
        min-height: 50vh;
    }
}


@media (max-width: 480px) {
    .header-video-height {
        min-height: 40vh;
    }
}

@media (max-width: 424px) {
    .header-video-height {
        min-height: 35vh;
    }
}


.section-video-height {
    min-height: 75vh;
}

@media (max-width: 1024px) {
    .section-video-height {
        min-height: 75vh;
    }
}

@media (max-width: 992px) {
    .section-video-height {
        min-height: 55vh;
    }
}

@media (max-width: 768px) {
    .section-video-height {
        min-height: 50vh;
    }
}


@media (max-width: 480px) {
    .section-video-height {
        min-height: 40vh;
    }
}

@media (max-width: 424px) {
    .section-video-height {
        min-height: 45vh;
    }
}


.top-75 {
    top: 75% !important;
}



/*-----------------------------------
 Header 
 ------------------------------------*/
.topbar {
    top: 0;
    background: rgba(255, 255, 255, 0.6);
}

.topbar * {
    filter: none;
}

.topbar a {
    color: #000;
    text-decoration: none;
}

.topbar a:hover {
    color: #000;
}

.btn-accessible {
    font-size: 1.5rem;
}


.btn-accessible :hover {
    font-size: 1.8rem;
    color: #000000;
}


.logo img {
    height: 40px;
}

.video-link-wrapper {
    font-size: 20px;
    font-weight: 900;
    color: #ff0000;
    text-decoration: none;
    letter-spacing: 2px;
}

.hero-video-overlay-content {
    width: 700px;
}

.video-link-wrapper > span {
    font-size: 22px;
    font-weight: 400;
    color: #ff0000;
    font-style: italic;
    text-decoration: none;
    display: block;
    letter-spacing: normal;
    text-transform: none;
}


/* Tablet (max-width: 1024px) */
@media (max-width: 1024px) {
    .video-link-wrapper {
        font-size: 18px;
    }

    .video-link-wrapper > span {
        font-size: 20px;
    }
}

/* Mobile (max-width: 768px) */
@media (max-width: 768px) {
    .video-link-wrapper {
        font-size: 16px;
    }

    .video-link-wrapper > span {
        font-size: 18px;
    }

}

/* Small Mobile (max-width: 480px) */
@media (max-width: 480px) {
    .video-link-wrapper {
        font-size: 16px;
    }

    .video-link-wrapper > span {
        font-size: 18px;
    }
}


/*-----------------------------------
 Menu
 ------------------------------------*/
.fai-btn-red {
    --bs-btn-color: #fff;
    --bs-btn-bg: #FF0000;
    --bs-btn-border-color: transparent;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #FF0000;
    --bs-btn-hover-border-color: #FF0000;
    --bs-btn-focus-shadow-rgb: 0, 0, 0;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #FF0000;
    --bs-btn-active-border-color: #FF0000;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #888;
    --bs-btn-disabled-bg: #EDEDED;
    --bs-btn-disabled-border-color: #000;
}

.modal-header .fai-btn-close {
    padding: calc(var(--bs-modal-header-padding-y) * .5) calc(var(--bs-modal-header-padding-x) * .5);
    margin: calc(-.5 * var(--bs-modal-header-padding-y)) calc(-.5 * var(--bs-modal-header-padding-x)) calc(-.5 * var(--bs-modal-header-padding-y)) auto;
} 
/*-----------------------------------
 Custom Icon Box
 ------------------------------------*/
.button-container {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
}

.badge-red {
    width: 40px;
    height: 40px;
    background-color: #ff0000;
    font-size: 20px;
}

.badge-white {
    width: 40px;
    height: 40px;
    background-color: #ffffff;
    font-size: 20px;
}


.badge-download {
    width: 40px;
    height: 40px;
    background-color: #EDEDED;
    font-size: 20px;
}

/*-----------------------------------
 Slider
 ------------------------------------*/
/* Carousel */

.carousel-container {
    width: 100%;
    height: 400px;
    position: relative;
    z-index: 10;
}

.carousel-container .swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 355px;
}


.carousel-container .swiper-pagination {
    position: absolute;
    bottom: 5px;
    text-align: center;
    width: 100%;
}

.carousel-container .swiper-pagination-bullet {
    width: 12px;
    height: 12px;
    background-color: gray;
    opacity: 1;
    margin: 0 5px;
    border-radius: 50%;
    transition: background-color 0.3s ease;
}

.carousel-container .swiper-pagination-bullet-active {
    background-color: var(--fai-blue);
}

.swiper-button-next,
.swiper-button-prev {
    background-color: red;
    background-position: center;
    background-size: 40px;
    background-repeat: no-repeat;
    padding: 8px;
    border-radius: 100%;
    border: none;
    color: white;
    width: 40px;
    height: 40px;
}

.swiper-button-prev {
    background-image: none ;
}

.swiper-button-next {
    background-image: none;
}

.swiper-button-next::after,
.swiper-button-prev::after {
    content: "";
}

.carousel-image-container {
    position: relative;
    display: inline-block;
}


.carousel-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none; 
}

.carousel-overlay-text {
    position: absolute;
    bottom: 0;
    left: 0;
    color: #000;
    padding: 5px 10px;
    pointer-events: auto; 
    font-weight: 900;
    cursor: pointer;
}

.carousel-overlay-play-button {
    width: 40px !important;
    height: 40px !important;
    border-radius: 100%;
    display: flex;
    align-items: center;
}


/*News Slider*/
.swiper {
    width: 100%;
    height: 100%;
}

.swiper-slide {
    text-align: left;
    font-size: 18px;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
}

.swiper-slide img {
    display: block;
    width: 100%;
}


/*-----------------------------------
 Sticky Buttona
 ------------------------------------*/
.sticky-container {
    position: fixed;
    left: 0;
    bottom: 100px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    z-index: 41;
}
.sticky-button {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #ff0000;
    color: white;
    text-decoration: none;
    transition: background 0.3s;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
    background-image: url('../assets/layout-elements/icons/phone-call.svg');
    background-repeat: no-repeat;
    background-position: center;
}
.sticky-button:hover {
    background-color: #ff0000;
}
.accessibility {
    background-color: #fff;
    color: black;
    background-image: url('../assets/layout-elements/icons/accessibility.svg');

}
.accessibility:hover {
    background-color: #fff;
}

/* Tablet (max-width: 1024px) */
@media (max-width: 1024px) {
    .sticky-container {
        bottom: unset;
        top: 150px;
        left: 0;
    }

    .sticky-button {
        width: 50px;
        height: 50px;
    }
}

/* Mobile (max-width: 768px) */
@media (max-width: 768px) {
    .sticky-container {
        background-color: rgba(0, 0, 0, 0.5);
        width: 100%;
        flex-direction: row;
        bottom: unset;
        position: fixed;
        left: 0;
        top: 100px;
        padding: 10px;
        justify-content: end;
    }

    .sticky-button {
        width: 50px;
        height: 50px;
    }
}

/* Small Mobile */
@media (max-width: 480px) {
    .sticky-container {
        background-color: rgba(0, 0, 0, 0.5);
        width: 100%;
        flex-direction: row;
        bottom: unset;
        position: fixed;
        left: 0;
        top: 100px;
        padding: 10px;
        justify-content: end;
    }

    .sticky-button {
        width: 42px;
        height: 42px;
    }
}

@media (max-width: 440px) {
    .sticky-container{
        top: 96px;
    }
}

@media (max-width: 375px) {
    .sticky-container{
        top: 83px;
    }
}

@media (max-width: 320px) {
    .sticky-container{
        top: 68px;
    }
}



/*-----------------------------------
 Footer
 ------------------------------------*/
.fai-footer {
    background-color: #d9eaf4;
    padding: 20px 0;
    text-align: left;
}

.social-links a
{
    color:#000;
    font-size:24px;
}

.social-links a:hover
{
    color:#FF0000;
}

.footer-supporter
{
    background-color: rgba(0,0,0,0.1); 
    padding: 10px 0px 20px 0px;
}

.footer-supporter-image
{
    width: 100%;
    max-width:550px;
}

#defa-logo{
    margin-left: 42px;
}

@media (max-width: 1220px){
    .sticky-button{
        width: 48px;
        height: 48px;
    }
}

/*-----------------------------------
 Home Elements
 ------------------------------------*/

.section-bg-image {

    background-repeat: no-repeat;
    background-position-x: right;
    background-position-y: center;
    
}

.fai-text-container {
    font-size: 1.2rem;   
}
.fai-text-container > p {
    font-size: 20px;
}

.fai-text-container > h3 {
    font-size: 30px;
    font-weight: 700;
}

/*
Video Section
 */
.section-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    object-fit: cover;
}


.video-overlay-content, .video-section-overlay-content {
    position: absolute;
    bottom: 20px;
    left: 128px;
    z-index: 1;
    color: white;
    line-height: 1;
}

.video-section-overlay-content{
    background-color: rgba(0, 0, 0, 0.8);
    opacity: 0.8;
}

.video-overlay-content h1 {
    margin-bottom: 0;
    padding-bottom: 0;
}


.video-overlay-link {
    position: absolute;
    bottom: 20px;
    right: 320px;
    z-index: 1;
    color: white;
    line-height: 1;
}


.section-headline {
    color: var(--section-headline-color, #000);
    font-weight: 600;
}

h1.section-headline {
    font-size: 40px;
    text-transform: uppercase;
}

h2.section-headline {
    font-size: 30px;
}



.section-headline > span {
    text-transform: none;
    font-weight: normal;
    font-style:italic;
    display: block;
}


@media (min-width: 1025px) and  (max-width: 1399px){

    .header-video-height {
        min-height: 75vh;
    }

    .video-overlay-content {
        bottom:200px;
        left: 60px;
        width: 700px;
        padding: 15px;
    }

    .video-section-overlay-content{
        bottom:100px;
        left: 60px;
        width: 700px;
        background-color: rgba(0, 0, 0, 0.8);
    }

    .video-overlay-link {
        bottom: 20px;
        right: 10px;
        z-index: 1;
        color: white;
        line-height: 1;
    }
}


@media (max-width: 1024px) {

    h1.section-headline {
        font-size: 40px;
        text-transform: uppercase;
    }

    .video-overlay-content {
        bottom: 200px;
        left: 70px;
        width: 700px;
    }

    .video-section-overlay-content {
        bottom: 80px;
        left: 70px;
        width: 700px;
        background-color: rgba(0, 0, 0, 0.8);
        /*padding: 5px;*/
    }

    .video-overlay-link {
        bottom: 50px;
        right: 15px;
        z-index: 1;
        color: white;
        line-height: 1;
    }
}

@media (max-width: 992px) {

    h1.section-headline {
        font-size: 36px;
        text-transform: uppercase;
    }

    .video-overlay-content {
        bottom: 120px;
        left: 50px;
        width: 500px;
    }

    .video-section-overlay-content {
        bottom: 50px;
        left: 50px;
        width: 500px;
        background-color: rgba(0, 0, 0, 0.8);
    }

    .video-overlay-link {
        bottom: 40px;
        right: 15px;
        z-index: 1;
        color: white;
        line-height: 1;
    }

}


@media (max-width: 768px) {

    h1.section-headline {
        font-size: 36px;
        text-transform: uppercase;
    }

    h2.section-headline {
        font-size: 20px;
    }
    
    .video-overlay-content {
        bottom: 100px;
        left: 50px;
        width: 450px;
    }

    .video-section-overlay-content {
        bottom: 20px;
        left: 50px;
        width: 450px;
        background-color: rgba(0, 0, 0, 0.8);
    }

    .video-overlay-link {
        bottom: 20px;
        right: 15px;
        z-index: 1;
        color: white;
        line-height: 1;
    }

}

@media (min-width: 481px) and  (max-width: 767px){

    .header-video-height {
        min-height: 50vh;
    }

    .video-overlay-content {
        bottom:60px;
        left: 0;
        width: 100%;
        padding: 15px;
        background-color: rgba(0, 0, 0, 0.8);
    }

    .video-section-overlay-content {
        bottom:0px;
        left: 0;
        width: 100%;
        background-color: rgba(0, 0, 0, 0.8);
        padding: 15px;
    }

    .video-overlay-link {
        bottom: 0;
        right: 10px;
        z-index: 1;
        color: white;
        line-height: 1;
    }
    
    .section-video-height{
        min-height: 46vh;
    }
}

@media (min-width: 600px) and  (max-width: 685px){
    .section-video-height {
        min-height: 40vh;
    }

    .video-section-overlay-content{
        bottom:0;
    }
}

@media (min-width: 576px) and  (max-width: 599px){
    .section-video-height {
        min-height: 38vh;
    }

    .video-section-overlay-content{
        bottom:0;
    }
}

@media (min-width: 481px) and (max-width: 575px){
    .section-video-height {
        min-height: 32vh;
    }
    
    .video-section-overlay-content{
        bottom:0;
    }
}



@media (max-width: 480px) {

    h1.section-headline {
        font-size: 28px;
        text-transform: uppercase;
    }
    
    .video-overlay-content {
        bottom:95px;
        left: 0;
        width: 100%;
        background-color: rgba(0, 0, 0, 0.8);
        padding: 15px;
    }

    .video-section-overlay-content {
        bottom:0px;
        left: 0;
        width: 100%;
        background-color: rgba(0, 0, 0, 0.8);
        padding: 15px;
    }

    .video-overlay-link {
        bottom: 15px;
        right: 15px;
        z-index: 1;
        color: white;
        line-height: 1;
    }

    .section-video-height {
        min-height: 25vh;
    }

    .video-section-overlay-content{
        bottom:0;
    }
}


@media (max-width: 424px) {

    h1.section-headline {
        font-size: 16px;
        text-transform: uppercase;
    }

    .video-overlay-content {
        bottom:115px;
        left: 0;
        width: 100%;
        background-color: rgba(0, 0, 0, 0.8);
        padding: 15px;
    }

    .video-section-overlay-content {
        bottom:0;
        left: 0;
        width: 100%;
        background-color: rgba(0, 0, 0, 0.8);
        padding: 15px;
    }

    .video-overlay-link {
        bottom: 50px;
        right: 10px;
        z-index: 1;
        color: white;
        line-height: 1;
    }

    .video-section-overlay-content h1 {
        font-size: 17px;
    }
}

@media (max-width: 375px){
    .section-video-height {
        min-height: 22vh;
    }
    
    .video-section-overlay-content h1 {
        font-size: 15px;
    }
}

@media (max-width: 320px) {
    .section-video-height {
        min-height: 21vh;
    }

    .video-section-overlay-content h1 {
        font-size: 14px;
    }
}


/*Your Way Slider */

.support-section {
    position: relative;       
    max-width: 1400px;
    width: 100%;
    margin: 0 auto;
    padding: 2rem 1rem;
    overflow: hidden;   
    height: 100%;
}



.content-wrapper {
    width: 1000px;
    display: flex;
    align-items: stretch;
    justify-content: space-between;
}

.text-block {
    flex: 1;
    margin-right: 2rem;
}

.text-block h2 {
    margin-bottom: 1rem;
    color: #666;
}

.text-block p {
    line-height: 1.5;
}

.image-block {
    flex: 0.8;
    text-align: center;
    margin-right: 100px;
}

.image-block img {
    max-width: 100%;
    height: auto;
    border-radius: 4px;
}


.divider-container {
    position: absolute;
    width: 100%;
    display: flex;
    justify-content: start;
    align-items: center;
    z-index: -1;
    top: 50%;            
    transform: translateY(-50%);
}

.divider {
    width: 95%;
    height: 4px;
    border-top: 4px dotted red;
    position: absolute;
}


.divider::after {
    content: '';
    position: absolute;
    right: -5px;
    top: 50%;
    transform: translateY(-54%);
    border-left: 50px solid red;
    border-top: 30px solid transparent;
    border-bottom: 30px solid transparent;
    display: none;
}



@media only screen and (max-width: 768px) {
    .content-wrapper {
        width: 100%;
        padding: 0 1rem;
    }
    .image-block {
        display: none;
    }
}

@media (max-width: 767px) {
    .divider-container {
        display: none;
    }

}



/* Home FAQ*/

.fai-accordion-title span{
    font-weight: bold;
}

.fai-accordion .accordion-button.collapsed {
    background-color: #ffffff;
}
.fai-accordion .accordion-button {
    background-color: #ffffff;
    font-size: 20px;
    font-style:italic;
    --bs-accordion-active-color:#000;
    line-height:var(--bs-body-line-height);
}


.fai-faq-accordion .accordion-button.collapsed {
    background-color: #ffffff;
}
.fai-faq-accordion .accordion-button {
    background-color: #ffffff;
    font-size: 20px;
    font-style:italic;
    --bs-accordion-active-color:#000;
    line-height:var(--bs-body-line-height);
}


.fai-accordion .accordion-button.collapsed::after {
    background-image: url("/assets/layout-elements/red-arrow-right.svg");
    transform: rotate(90deg);
    
} 

.fai-accordion .accordion-button::after {
    background-image: url("/assets/layout-elements/red-arrow-right.svg");
    transform: rotate(-90deg);
}

.fai-accordion .accordion-body p {
    font-size: 20px;   
}

/*-----------------------------------
 ContentPage
 ------------------------------------*/
.contentpage-wrapper
{
    margin-top:150px;
}

/*-----------------------------------
 FAQ
 ------------------------------------*/

.fai-faq-accordion.accordion-flush>.accordion-item:first-child {
    border-top: 2px solid #000;
}


.fai-faq-accordion.accordion-flush>.accordion-item:last-child {
    border-bottom: 2px solid #000;
}


/*-----------------------------------
 Block Grid
 ------------------------------------*/
.umb-block-grid {
    --umb-block-grid--column-gap: 0;
    --umb-block-grid--row-gap: 0;
    --umb-block-grid--grid-columns: 1;
    --umb-block-grid--area-grid-columns: 1;
    --umb-block-grid--areas-column-gap: 0;
    --umb-block-grid--areas-row-gap: 0;
    --umb-block-grid--area-column-span: 1;
    --umb-block-grid--area-row-span: 1;
    --umb-block-grid--item-column-span: 1;
    --umb-block-grid--item-row-span: 1;
    --spacer-width: 1px;
    --spacer-color: #000;
    --fai-section-background-color: #fff;
    --fai-section-background-image: none;
    --fai-subbject-text-color: #fff;
}

.umb-block-grid__layout-container {
    position: relative;
    display: grid;
    grid-template-columns: repeat(var(--umb-block-grid--grid-columns, 1), minmax(0, 1fr));
    grid-auto-flow: row;
    grid-auto-rows: minmax(50px, min-content);
    -moz-column-gap: var(--umb-block-grid--column-gap, 0);
    column-gap: var(--umb-block-grid--column-gap, 0);
    row-gap: var(--umb-block-grid--row-gap, 0);
}

.umb-block-grid__layout-item {
    position: relative;
    /* For small devices we scale columnSpan by three, to make everything bigger than 1/3 take full width: */
    grid-column-end: span min(calc(var(--umb-block-grid--item-column-span, 1) * 3), var(--umb-block-grid--grid-columns));
    grid-row: span var(--umb-block-grid--item-row-span, 1);
}


.umb-block-grid__area-container, .umb-block-grid__block--view::part(area-container) {
    position: relative;
    display: grid;
    grid-template-columns: repeat(var(--umb-block-grid--area-grid-columns, var(--umb-block-grid--grid-columns, 1)), minmax(0, 1fr));
    grid-auto-flow: row;
    grid-auto-rows: minmax(50px, min-content);
    -moz-column-gap: var(--umb-block-grid--areas-column-gap, 0);
    column-gap: var(--umb-block-grid--areas-column-gap, 0);
    row-gap: var(--umb-block-grid--areas-row-gap, 0);
}

.umb-block-grid__area {
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    /* For small devices we scale columnSpan by three, to make everything bigger than 1/3 take full width: */
    grid-column-end: span min(calc(var(--umb-block-grid--area-column-span, 1) * 3), var(--umb-block-grid--area-grid-columns));
    grid-row: span var(--umb-block-grid--area-row-span, 1);
}


@media (min-width: 992px) {
    .umb-block-grid__layout-item {
        grid-column-end: span min(var(--umb-block-grid--item-column-span, 1), var(--umb-block-grid--grid-columns));
    }

    .umb-block-grid__area {
        grid-column-end: span min(var(--umb-block-grid--area-column-span, 1), var(--umb-block-grid--area-grid-columns));
    }
}

/**********************
Layout Items
*********************/
.umb-block-grid__layout-item {
    background-color: inherit;
}

.bg-grey {
    background-color: #F5F5F5;
}

.img-copyright {
    text-align: right;
    font-size: 14px;
    color: #666;
    padding: 8px 20px;
}

.container .img-copyright {
    padding: 8px 0px;
}

/**********************
Section Wrappers
**********************/
.section-wrapper,
.rich-text-wrapper,
.newsletter-wrapper {
    background-color: var(--fai-section-background-color, #fff);
    background-image: var(--fai-section-background-image, none);
}

.umb-block-grid__layout-item .rich-text-wrapper {
    border-radius: 10px;
}

/**********************
Spacer
**********************/
.umb-block-grid__layout-item[data-content-element-type-alias='spacer'] {
    height: 100%;
}

.grid-spacer {
    height: 100%;
    display: flex;
    justify-content: center;
}

.grid-spacer > div {
    width: var(--spacer-width, 1px);
    background-color: var(--spacer-color);
}

/*** Spacer Visibility ***/
/* d-none */
.umb-block-grid__layout-item:has(> div.d-none:not(.d-md-block, .d-block, .d-md-flex,.d-lg-block, .d-flex, .d-lg-flex)) {
    display: none !important;
}


/* case .d-none, .d-sm-block, .d-sm-flex */
@media (max-width: 767px) {
    .umb-block-grid__layout-item:has(> div.d-none.d-md-block),
    .umb-block-grid__layout-item:has(> div.d-none.d-md-flex) {
        display: none !important;
    }
}

/* d-{displayTypeValue} d-md-none d-lg-{displayTypeValue} */
@media (min-width: 768px) and (max-width: 991px) {
    .umb-block-grid__layout-item:has(> div.d-block.d-md-none.d-lg-block),
    .umb-block-grid__layout-item:has(> div.d-flex.d-md-none.d-lg-flex) {
        display: none !important;
    }
}

/* d-none d-lg-{displayTypeValue} */
@media (max-width: 991px) {
    .umb-block-grid__layout-item:has(> div.d-none.d-lg-block),
    .umb-block-grid__layout-item:has(> div.d-none.d-lg-flex) {
        display: none !important;
    }
}

/* d-{displayTypeValue} d-lg-none */
@media (min-width: 992px) {
    .umb-block-grid__layout-item:has(> div.d-block.d-lg-none),
    .umb-block-grid__layout-item:has(> div.d-flex.d-lg-none) {
        display: none !important;
    }
}

/* d-none d-md-{displayTypeValue} d-lg-none */
@media (min-width: 992px) {
    .umb-block-grid__layout-item:has(> div.d-none.d-md-block.d-lg-block),
    .umb-block-grid__layout-item:has(> div.d-none.d-md-flex.d-lg-flex) {
        display: none !important;
    }
}

@media (max-width: 767px) {
    .umb-block-grid__layout-item:has(> div.d-none.d-md-block.d-lg-block),
    .umb-block-grid__layout-item:has(> div.d-none.d-md-flex.d-lg-flex) {
        display: none !important;
    }
}

/* d-{displayTypeValue} d-md-none */
@media (min-width: 768px) {
    .umb-block-grid__layout-item:has(> div.d-block.d-md-none:not(.d-lg-block)),
    .umb-block-grid__layout-item:has(> div.d-flex.d-md-none:not(.d-lg-flex)) {
        display: none !important;
    }
}

/**************************
Block Grid Items
***************************/

/**************************
/*** Image Video Banner ***
**************************/

.image-video-banner-wrapper
{
    padding:40px 200px 40px 0px;
    background-image:url("/assets/layout-elements/blue-line-bg.svg");
    background-repeat: no-repeat;
    background-position: right bottom;
    background-size: auto 100%;
    display: inline-block;
    width: 100%;
}

.image-video-banner-wrapper img
{
    width: 100%;
    max-width:900px;    
}

/* Tablet (max-width: 1024px) */
@media (max-width: 1024px) {
    .image-video-banner-wrapper
    {
        padding: 35px 125px 35px 0px;
    }
}

/* Mobile (max-width: 768px) */
@media (max-width: 768px) {
    .image-video-banner-wrapper
    {
        padding: 30px 75px 30px 0px;
    }
}

/* Small Mobile (max-width: 480px) */
@media (max-width: 480px) {
    .image-video-banner-wrapper
    {
        padding: 20px 10px 20px 0px;
    }
}

/**************************
/*** Quick Link ***
**************************/

div[data-content-element-type-alias="quickLink"] > div
{
    height: 100%;
    display: flex;
    justify-content: right;
    align-items: end;
    
}

.quick-link-wrapper
{
    background-image:url(/assets/layout-elements/red-arrow-right.svg);
    background-size: 38px 38px;
    background-repeat: no-repeat;
    background-position: top left;
    padding-left: 60px;
    width: 100%;
    max-width: 350px;

}

.quick-link-box h3
{
    font-size: 20px;
    font-weight: 600;
}

.quick-link-box h3 span
{
    font-weight: normal;
    font-style: italic;
}

.quick-link-box ul, .quick-link-box .topics
{
    margin-top:20px;
    margin-left:0px;
    padding-left:0px;
    list-style: none;
}

.quick-link-box .topics
{
    margin:0px;
    padding:0px;
}

.quick-link-box .topics li
{
    font-size:14px;
    padding:2px 0px 2px 20px;
    text-decoration: none;
    display: block;
    color:#000;
    background-image:url(/assets/layout-elements/black-arrow-right.svg);
    background-repeat: no-repeat;
    background-position: center left;
}

.quick-link-box li a
{
    font-size:14px;
    padding:10px 120px 10px 0px;
    text-decoration: none;
    display: block;
    color:#000;
    border-bottom:solid 1px #000;
    background-image:url(/assets/layout-elements/black-arrow-right.svg);
    background-repeat: no-repeat;
    background-position: center right;
}

.quick-link-box li a:hover
{
   background-color: #EDF7F8;
}

.quick-link-box li:first-child a
{    
    border-top:solid 1px #000;
}

.quick-link-box img
{
    max-width:230px;
}

.contact-detail
{
    border-bottom:solid 1px #000;
    padding:15px;
    font-size:16px;
    padding-left:0px;
}

@media (max-width:480px)
{
    .quick-link-box li a {     
        padding: 10px 90px 10px 0px;
    }
}

/**************************
/*** News Card / Aktuelles ***
**************************/
.card-title-curent-news
{
    font-size:20px;
    min-height: 80px;
}

.card-text {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.card-text, .card-footer a
{
    font-size:14px;
}

.swiper-news-wrapper .swiper-button-next
{
    right:0px;
}

.swiper-news-wrapper .swiper-button-prev
{
    left:0px;
}

@media (max-width: 991px)
{
    .swiper-news-wrapper .swiper-button-next
    {
        right:-20px;
    }

    .swiper-news-wrapper .swiper-button-prev
    {
        left:-20px;
    }
}

@media (max-width: 768px) {
    .swiper-news-wrapper .swiper-button-next {
        right: -10px;
    }

    .swiper-news-wrapper .swiper-button-prev {
        left: -10px;
    }
}

@media (max-width: 425px) {
    .swiper-news-wrapper .swiper-button-next {
        right: -10px;
    }

    .swiper-news-wrapper .swiper-button-prev {
        left: -10px;
    }
}

/**************************
/*** Contact Card ***
**************************/


.contact-card
{
    padding:12px 14px 12px 14px;
    background-color:#ffffff;
}

.contact-card img
{
    max-width:100%;
}

.contact-card .contact-detail
{
    border-bottom:solid 0px #000;    
}

/**************************
/*** Seperator ***
**************************/
.seperator
{
    background-color:#FF0000;
    height:5px;
    width:69px;
    margin:30px 0px;
}

/**************************
/*** Highlight Carousel ***
**************************/
.highlight-box
{
    width:300px;
    height:300px;
    background-size:cover;
    background-repeat:no-repeat;
    background-position: center center;
    display: flex;
    justify-content: center;
    align-items: end;
}

.highlight-box .text-container
{
    text-align: center;
    background-color: rgba(255,255,255,0.75);
    color:#000;
    font-size:16px;
    font-weight:600;
    padding:10px 20px;
    width:100%;    min-height: 70px;
    display: flex;
    justify-content: center;
    align-items: center;
}

@media (max-width:1400px)
{
    .highlight-box
    {
        width:230px;
        height:230px;
    }
}

/***************************
/*** Image and Statement ***
***************************/
.image-and-statement-wrapper
{

}

.image-and-statement-wrapper img
{
    width:300px;
    height:300px;
    margin-right: 50px;
    margin-left: -175px;
    position: relative;
}

.image-and-statement-wrapper .statement
{    
    padding:40px 200px 40px 0px;
    background-color: #D9E8EF;    
    display:flex;   
    align-items: center;
    font-size:24px;
    font-style: italic;
}

@media (max-width:1400px)
{
    .image-and-statement-wrapper img
    {
        width:230px;
        height:230px;
        margin-left: -140px;
    }
    .image-and-statement-wrapper .statement
    {        
        padding:30px 150px 30px 0px;
    }

}


/**************************
/*** Life Feed ***
**************************/
.feed-carousel {
    --cnvs-owl-dots-sizes: 11px;
    --cnvs-owl-nav-bg: #333333;
    --owl-item-radius: 10px;
}

.feed-carousel.init {
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
}

.abo-badge {
    padding: 2px 4px;
    border-radius: 5px;
    color: #fff;
    font-size: 12px;
    font-weight: 300;
    background-color: #6C757D;
}

/* === Feed Ad Display === */
#newsfeed-slider {
    --nwb-ad-label-line-height: 24px;
}

.feed-carousel:has(div[id^="adBanner"]) .swiper-wrapper {
    margin-top: var(--nwb-ad-label-line-height);
}

.feed-carousel:has(div[id^="adBanner"]) .swiper-wrapper .swiper-slide:has(.ad-section) .ad-label {
    position: absolute;
    top: 0;
    left: 6px;
    transform: translateY(-100%);
    font-size: 14px;
}

#newsfeed-slider:has(div[id^="adBanner"]) .swipe-navigation {
    transform: translateY(calc(var(--nwb-ad-label-line-height) * -1));
}

.feed-carousel:has(div[id^="adBanner"]) .swiper-wrapper .swiper-slide:has(.ad-section) {
    overflow: visible;
}

/* hide last slide when ad banner is showing */
.feed-carousel:has(div[id^="adBanner"]) .swiper-wrapper .swiper-slide:last-child {
    display: none;
}

/* hide ad slide when no banner is showing */
.feed-carousel:not(:has(div[id^="adBanner"])) .swiper-wrapper .swiper-slide:nth-child(3) {
    display: none;
}

.feed-carousel {
    border: 1px solid transparent;
    margin-bottom: 5px;
}

.feed-carousel .feed-item {
    border: 1px solid #DCDCDC;
    border-radius: var(--owl-item-radius);
}

.feed-item .feed-content {
    padding: 0 20px 20px 20px;
}

.feed-item .image-wrapper {
    aspect-ratio: 630/354;
    border-top-right-radius: var(--owl-item-radius);
    border-top-left-radius: var(--owl-item-radius);
    overflow: hidden;
}

.feed-item .feed-headline h3 {
    font-size: 18px;
    font-weight: 700;
    line-height: 22px;
    margin: 10px 0 15px;
    transition: color 100ms ease-in-out;
}

.feed-item:hover .feed-headline h3 {
    color: var(--fai-blue);
}

.feed-item .feed-categories {
    color: #5C5C5C;
    font-size: 11px;
    line-height: 16px;
    font-weight: 400;
    margin-bottom: 10px;
}

.feed-item .feed-categories .category-text {
    text-transform: uppercase;
}

.feed-item .feed-excerpt {
    font-size: 16px;
    line-height: 24px;
    color: #1d1d1b;
    font-weight: 400;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    overflow: hidden;
    text-overflow: ellipsis;
}

#newsfeed-slider:not(.initialized) {
    visibility: hidden;
    pointer-events: none;
    opacity: 0;
    height: 0;
}

#newsfeed-slider.initialized {
    visibility: visible;
    pointer-events: auto;
    animation: swiperLoaded;
    animation-duration: 200ms;
}


@keyframes swiperLoaded {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

.carousel-spinner {
    min-height: 400px;
}

/**************************************
Swiper Custom Navigation & Pagination
**************************************/
.custom-swiper-nav {
    --swipe-navigation-icon-color: #000;
    --swipe-navigation-icon-bg-color: #fff;
    --swipe-navigation-border-width: 1px;
    --swipe-navigation-border-color: rgba(0, 0, 0, 0.2);
    --swipe-navigation-border-radius: 50%;
    --swipe-navigation-size: 48px;
}

.custom-swiper-nav .swiper-pagination {
    --cnvs-swiper-dots-position-bottom: 0;
}


.custom-swiper-nav .swiper-pagination-bullet-active {
    opacity: 1;
}

.swipe-navigation {
    color: var(--swipe-navigation-icon-color, #000);
    background-color: var(--swipe-navigation-icon-bg-color, #fff);
    border-width: var(--swipe-navigation-border-width, 1px);
    border-color: var(--swipe-navigation-border-color, #000);
    border-radius: var(--swipe-navigation-border-radius, 50%);
    width: var(--swipe-navigation-size, 48px);
    height: var(--swipe-navigation-size, 48px);
    border-style: solid;
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9;
    cursor: pointer;
    top: 50%;
    transform: translateY(calc(-1 * var(--swipe-navigation-size)));
    transition: all 150ms ease-in-out;
    opacity: 0.3;
    box-shadow: 0px 6px 8px #c9c9c9;
}

@media (max-width: 575px) {
    .swipe-navigation {
        display: none;
    }

}

.custom-swiper-nav:hover .swipe-navigation {
    opacity: 1;
}

.swipe-navigation.swiper-button-disabled {
    display: none;
}

.swipe-next {
    right: calc(-1 * var(--swipe-navigation-size));
    left: auto;
}

.swipe-prev {
    right: auto;
    left: calc(-1 * var(--swipe-navigation-size));
}

/**********************
FAQ
**********************/
.faq-topic-card {
    width: 200px;
    text-align: center;
    padding: 25px 0px;
    display: block;
    border-radius: 15px;
    justify-content: center;
    cursor: pointer;
    margin-bottom: 20px;
}

.faq-topic-card h5 {
    font-size: 16px !important;
}

.faq-topic-img-wrapper {
    background: #fff;
    padding: 25px;
    border-radius: 90px;
    display: inline-block;
}

.faq-topic-card img {
    float: none !important;
    width: 50px !important;
    height: 50px;
    background: #fff;
    display: inline;
    align-self: center;
}

.faq-topic-card.active,
.faq-topic-card:hover {
    background: #fff !important;
    box-shadow: 3px 3px 10px #ccc;
}


.faq-topic-card.active .faq-topic-img-wrapper,
.faq-topic-card.active img,
.faq-topic-card:hover .faq-topic-img-wrapper,
.faq-topic-card:hover img {
    background: var(--cnvs-themecolor) !important;
}

.faq-topic-wrapper .toggle-title {
    padding-top: 20px;
    padding-bottom: 20px;
    border-bottom: solid 1px #ccc;
    font-size: 20px;
    font-weight: 700 !important;
    padding-left: 20px;
}

.faq-topic-wrapper .toggle-icon {
    font-size: 30px;
    padding-top: 16px;
    padding-right: 2rem;
}

.faq-question {
    background-color: #2F4858;
    padding: 25px;
    color: #fff;
    font-size: 20px;
    font-weight: 700 !important;
    width: 65%;
    position: relative;
    border-radius: 15px;
}

.faq-question:after {
    content: '';
    position: absolute;
    border-style: solid;
    border-width: 20px 14px 0;
    border-color: #2F4858 transparent;
    display: block;
    width: 0;
    z-index: 1;
    bottom: -20px;
    left: 20px;
}

.faq-answer {
    margin-top: 25px;
    background-color: #FFFCD1;
    padding: 25px;
    color: #1D1D1B;
    font-size: 16px;
    font-weight: 500 !important;
    width: 65%;
    position: relative;
    border-radius: 15px;
    margin-left: 35%;
    box-shadow: 3px 3px 10px #ccc;
}

.faq-answer:after {
    content: '';
    position: absolute;
    border-style: solid;
    border-width: 0 14px 20px;
    border-color: #FFFCD1 transparent;
    display: block;
    width: 0;
    z-index: 1;
    top: -20px;
    right: 20px;
}

@media (max-width: 767px) {
    .faq-question, .faq-answer {
        width: 80%;
    }

    .faq-answer {
        margin-left: 20%;
    }
}

.accordion-button:focus {
    border: none !important;
    box-shadow: none !important;
}

/**********************
Bilderstrecke / Fancybox
**********************/
.fancybox-infobox {
    position: absolute;
    bottom: 20px;
    left: 20px;
    z-index: 9;
    background: rgba(0, 0, 0, .7);
    color: #fff;
    font-weight: 600;
    font-size: 16px;
    padding: 8px 20px;
    border-radius: 5px;
}

/**********************
Contact-Card
**********************/
.team-title span {
    color: #212545;
    font-family: inherit;
    font-style: normal;
}

.team-title h4, .team-title .h4 {
    text-transform: none;
    letter-spacing: 0px;
    color: #1D1D1B;
}

.contactInfo h3 {
    font-size: 24px;
    font-weight: 700;
}

.contactInfo {
    font-size: 16px;
    font-weight: 500;
}

.contactInfo .team-title h4, .contactInfo .team-title .h4 {
    font-size: 18px;
    font-weight: 700;
}

/**********************
Carousel
**********************/
.block-grid-carousel {
    --cnvs-owl-nav-sizes: 48px;
    --cnvs-owl-dots-sizes: 11px;
    --cnvs-owl-nav-bg: #A7A7A7;
}

.block-grid-carousel .owl-dots .owl-dot {
    margin-top: 15px;
}


.block-grid-carousel .owl-nav .owl-prev {
    left: 5px !important;
    box-shadow: 0px 6px 8px #c9c9c9;
    opacity: 0.3 !important;
}

.block-grid-carousel .owl-nav .owl-next {
    right: 5px !important;
    box-shadow: 0px 6px 8px #c9c9c9;
    opacity: 0.3 !important;
}

.block-grid-carousel .owl-nav [class*=owl-]:hover {
    opacity: 1 !important;
    color: var(--cnvs-owl-nav-color) !important;
    background-color: var(--cnvs-owl-nav-background) !important;
}

.block-grid-carousel .owl-stage-outer {
    padding-top: 20px;
    padding-bottom: 20px;
}

.block-grid-carousel .oc-item {
    border-radius: 10px !important;
}

.block-grid-carousel .oc-item .h-shadow {
    box-shadow: 0px 0px 18px 2px #c9c9c9 !important;
}

.block-grid-carousel .oc-item .h-translate-y-sm {
    transform: translateY(-3px) !important;
}

.carousel-person-position, .carousel-person-name {
    color: #1D1D1B;
    font-size: 11px;
    display: block;
    text-transform: uppercase;
}

.carousel-person-intro {
    color: #1D1D1B;
    font-weight: bolder;
    font-size: 18px;
    --cnvs-line-height-content: 24px;
    margin-bottom: 20px;
}

.carousel-person-text {
    color: #1D1D1B;
    font-weight: normal;
    font-size: 16px;
    --cnvs-line-height-content: 24px;
    margin-bottom: 20px;
}

/**********************
Seminar Card
**********************/
.carousel-person-position, .carousel-person-name {
    color: #1D1D1B;
    font-size: 11px;
    display: block;
    text-transform: uppercase;
}

.carousel-person-intro {
    color: #1D1D1B;
    font-weight: bolder;
    font-size: 18px;
    --cnvs-line-height-content: 24px;
    margin-bottom: 20px;
}

.carousel-person-text {
    color: #1D1D1B;
    font-weight: normal;
    font-size: 16px;
    --cnvs-line-height-content: 24px;
    margin-bottom: 20px;
}

@media (max-width: 991px) {
    .seminarCardWrapper {
        text-align: center;
    }

    .carousel-person-intro {
        margin-top: 20px;
    }
}

/**********************
Image Banner Carousel
**********************/
/* navigation*/
.block-grid-imagebanner-carousel {
    --cnvs-owl-nav-sizes: 68px;
    --cnvs-owl-dots-sizes: 11px;
    --cnvs-owl-nav-bg: #A7A7A7;
}

.block-grid-imagebanner-carousel .owl-dots .owl-dot {
    margin-top: 15px;
}


.block-grid-imagebanner-carousel .owl-nav .owl-prev {
    opacity: 1 !important;
    left: -75px !important;
    box-shadow: 0px 6px 8px #c9c9c9;
    opacity: 0.3 !important;
}

.block-grid-imagebanner-carousel .owl-nav .owl-next {
    opacity: 1 !important;
    right: -75px !important;
    box-shadow: 0px 6px 8px #c9c9c9;
    opacity: 0.3 !important;
}

.block-grid-imagebanner-carousel .owl-nav [class*=owl-]:hover {
    opacity: 1 !important;
    color: var(--cnvs-owl-nav-color) !important;
    background-color: var(--cnvs-owl-nav-background) !important;
}


/**********************
Highlight Banner
**********************/
.highlightBanner-wrapper {
    background-color: var(--fai-section-background-color);
    background-image: var(--fai-section-background-image);
    background-size: cover;
    padding: 40px;
    display: grid;
}

.highlightBanner-box-container {
    --boxBG: rgba(0, 0, 0, 0.8);
    --boxTitleColor: #FFED00;
    --boxSubTitleColor: #f5f5f5;
    --boxTextColor: #fff;

    width: 60%;
    position: relative;
    z-index: 1;
    background: var(--boxBG);
    padding: 20px;
}

.highlightBanner-box-container.top-left {
    margin-top: 0px;
    margin-left: 20px;
    margin-bottom: 100px;
}

.highlightBanner-box-container.bottom-left {
    margin-top: 100px;
    margin-left: 20px;
    margin-bottom: 0px;
}

.highlightBanner-box-container.top-right {
    margin-top: 0px;
    margin-left: 20px;
    margin-bottom: 100px;
    justify-self: end;
}

.highlightBanner-box-container.bottom-right {
    margin-top: 100px;
    margin-left: 20px;
    margin-bottom: 0px;
    justify-self: end;
}

.highlightBanner-box-container .box-subtitle {
    text-transform: uppercase;
    color: var(--boxSubTitleColor);
    font-size: 14px;
    font-weight: 300;
}

.highlightBanner-box-container .box-title {
    color: var(--boxTitleColor);
    font-size: 28px;
    font-weight: 700;
}

.highlightBanner-box-container .box-text {
    color: var(--boxTextColor);
    font-size: 16px;
}

@media (max-width: 767px) {
    .highlightBanner-box-container {
        width: 95%;
        position: relative;
        z-index: 1;
        padding: 20px;
        justify-self: center;
    }

    .highlightBanner-box-container.top-left {
        margin-top: 0px;
        margin-left: 0px;
        margin-bottom: 0px;
    }

    .highlightBanner-box-container.bottom-left {
        margin-top: 0px;
        margin-left: 0px;
        margin-bottom: 0px;
    }

    .highlightBanner-box-container.top-right {
        margin-top: 0px;
        margin-left: 0px;
        margin-bottom: 0px;
        justify-self: center;
    }

    .highlightBanner-box-container.bottom-right {
        margin-top: 0px;
        margin-left: 0px;
        margin-bottom: 0px;
        justify-self: center;
    }

    .highlightBanner-box-container .box-subtitle {
        text-transform: uppercase;
        font-size: 12px;
        font-weight: 300;
    }

    .highlightBanner-box-container .box-title {
        font-size: 22px;
        font-weight: 700;
        margin-bottom: 10px;
    }

    .highlightBanner-box-container .box-text {
        font-size: 11px;
    }

    .box-cta .nwb-btn-common {
        font-size: 11px;
    }
}


/**********************
Bild Text Call-to-Action
**********************/
.bild-text-cta-wrapper h4 {
    font-size: 18px;
    font-weight: 700;
}

.bild-text-cta-wrapper .after-heading {
    font-size: 16px;
    color: #5C5C5C !important;
    font-weight: 700 !important;
}

.bild-text-cta-text {
    color: #1D1D1B;
    font-size: 16px;
}


/**********************
Cookie Call-To-Action
**********************/

.ccm-settings-summoner {
    display: none;
}

/**********************
QUOTE
**********************/
.quote-text-wrapper {
    background: #ffef1f;
    padding: 24px !important;
    padding-left: 80px !important;
    font-size: 24px;
    font-family: "Open Sans", serif;
    font-style: italic;
    font-weight: 400;
}

.quote-text-wrapper .quotationmark {
    position: absolute;
    top: 12px;
    left: 24px;
    font-size: 40px;
}


.quote-text-wrapper .author {
    display: block;
    padding-top: 15px;
    font-size: 12px;
    font-family: "Open Sans", serif;
    font-style: normal;
    text-align: right;
}


/**********************
NWB Database Input
**********************/
.nwb-input-yellow {
    border: solid 10px var(--cnvs-themecolor);
}

.nwb-input-yellow input {
    border: solid 0 var(--cnvs-themecolor);
    font-size: 16px;
}

.nwb-input-yellow input::placeholder {
    color: #999999;
}

.nwb-input-yellow i {
    font-size: 20px
}


/**********************
 **********************/
.fancybox__container {
    --fancybox-bg: rgba(24, 24, 27, 0.85);
}

/**********************
Icon Link List
**********************/
.blockgrid-icon-link-list .link-col {
    border-right: solid 1px #DCDCDC;
}

.blockgrid-icon-link-list .link-col:last-child {
    border-right: solid 0px #ffffff;
}

.blockgrid-icon-link {
    text-align: center;
    padding: 30px 0px;
    display: flex;
    flex-flow: column wrap;
    align-items: center;
    justify-content: center;
}

.blockgrid-icon-link-icon-wrapper {
    background-color: var(--cnvs-themecolor);
    text-align: center;
    width: 100px;
    height: 100px;
    border-radius: 90px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.blockgrid-icon-link-icon-wrapper img {
    max-width: 50px;
    max-height: 50px;
}

/**********************
Newsletter
**********************/
.newsletter-text {
    font-size: 34px;
    --cnvs-line-height-content: 43px;
}

@media (max-width: 991px) {
    .newsletter-text {
        font-size: 24px;
        --cnvs-line-height-content: 34px;
    }
}

/**********************
Products Carousel & Subjects
**********************/
/*** Product Carousel ***/
/* navigation*/
.product-carousel {
    --cnvs-owl-nav-sizes: 68px;
    --cnvs-owl-dots-sizes: 11px;
    --cnvs-owl-nav-bg: #A7A7A7;
}

.product-carousel .owl-dots .owl-dot {
    margin-top: 15px;
}


.product-carousel .owl-nav .owl-prev {
    box-shadow: 0px 6px 8px #c9c9c9;
    opacity: 0.3 !important;
    left: -75px !important;
}

.product-carousel .owl-nav .owl-next {
    box-shadow: 0px 6px 8px #c9c9c9;
    opacity: 0.3 !important;
    right: -75px !important;
}

.product-carousel .owl-nav [class*=owl-]:hover {
    opacity: 1 !important;
    color: var(--cnvs-owl-nav-color) !important;
    background-color: var(--cnvs-owl-nav-background) !important;
}

.product-carousel .owl-item.center {
    text-align: left !important;
}

.owl-item .product-button-wrapper {
    display: none;
}

.owl-item.center .product-button-wrapper {
    display: block;
}

.nwb-product .product-description p {
    margin-bottom: 20px;
}

/* typographies */
.nwb-product .product-name {
    font-size: 24px;
    font-weight: 600;
    line-height: 30px;
}

.nwb-product .product-description,
.nwb-product a {
    color: #000;
    font-size: 16px;
    font-weight: 400;
    --cnvs-line-height-content: 24px;
}

@media (max-width: 1399px) {
    .nwb-product .product-description,
    .nwb-product a {
        font-size: 15px;
        font-weight: 400;
        --cnvs-line-height-content: 22px;
    }
}

@media (max-width: 1199px) {
    .nwb-product .product-description,
    .nwb-product a {
        font-size: 14px;
        font-weight: 400;
        --cnvs-line-height-content: 21px;
    }

    .product-button-wrapper button {
        --nwb-button-fontsize: 16px;
        --nwb-button-padding: 8px 20px;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .nwb-product .product-description,
    .nwb-product a {
        font-size: 12px;
        font-weight: 400;
        --cnvs-line-height-content: 18px;
    }

    .nwb-product .product-description p {
        margin-bottom: 15px;
    }

    .product-button-wrapper button {
        --nwb-button-fontsize: 14px;
        --nwb-button-padding: 6px 20px;
    }
}

@media (max-width: 768px) {
    .nwb-product .product-description,
    .nwb-product a {
        font-size: 16px;
        font-weight: 400;
        --cnvs-line-height-content: 22px;
    }
}

@media (max-width: 575px) {

    .contactInfo h3 {
        font-size: 20px;
    }
}

/* highlighting middle items */
@media (min-width: 768px) {
    .product-carousel .active:nth-child(2 of .active) {
        transform: scale(1);
        opacity: 1;
    }

    .product-carousel .owl-item {
        transform: scale(.8);
        opacity: 0.65;
        transition: transform 250ms ease-out, opacity 200ms ease-in-out;
    }

    .product-carousel .active:nth-child(1 of .active) {
        transform-origin: left;
    }

    .product-carousel .active:nth-child(3 of .active) {
        transform-origin: right;
    }
}


/*** Subject Buttons ***/
.subject-text {
    font-size: 16px;
    --cnvs-line-height-content: 24px;
    font-weight: 400;
}

.subject-wrapper {
    max-width: 800px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    --nwb-subject-fontSize: 12px;
    --nwb-subject-fontWeight: 400;
    --nwb-subject-lineHeight: 1;
    --nwb-subject-y-padding: 4px;
}

.subject {
    background-color: var(--fai-section-background-color, #fff);
    width: fit-content;
    padding: var(--nwb-subject-y-padding) 10px;
    border-radius: 10px;
    display: flex;
    line-height: 0;
    align-items: center;
}

.subject a,
.subject span {
    font-size: var(--nwb-subject-fontSize, 12px);
    color: var(--fai-subbject-text-color, #fff);
    font-weight: var(--nwb-subject-fontWeight, 400);
    line-height: var(--nwb-subject-lineHeight, 1);
}

/**********************
Ad Snippet
**********************/
.umb-block-grid__layout-item:has(div[data-content-element-type-alias="adSnippet"]):not(:has([id^='adBanner'])) {
    display: none;
}

.rich-text-wrapper ul li p {
    margin-bottom: 0;
}