/* =====================
   Custom Fonts (Be Vietnam Pro)
===================== */
@font-face {
    font-family: 'Be Vietnam Pro';
    src: url('fonts/be-vietnam-pro-v11-latin-100.woff2') format('woff2');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Be Vietnam Pro';
    src: url('fonts/be-vietnam-pro-v11-latin-200.woff2') format('woff2');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Be Vietnam Pro';
    src: url('fonts/be-vietnam-pro-v11-latin-300.woff2') format('woff2');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Be Vietnam Pro';
    src: url('fonts/be-vietnam-pro-v11-latin-400.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Be Vietnam Pro';
    src: url('fonts/be-vietnam-pro-v11-latin-500.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Be Vietnam Pro';
    src: url('fonts/be-vietnam-pro-v11-latin-600.woff2') format('woff2');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Be Vietnam Pro';
    src: url('fonts/be-vietnam-pro-v11-latin-700.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Be Vietnam Pro';
    src: url('fonts/be-vietnam-pro-v11-latin-800.woff2') format('woff2');
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Be Vietnam Pro';
    src: url('fonts/be-vietnam-pro-v11-latin-900.woff2') format('woff2');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

body {
    font-family: var(--bs-font-sans-serif);
    color: #1e1e1e;
    background-color: var(--bs-light);
    scroll-behavior: smooth;
}



:root {
    --bs-primary: #004aad;
    --bs-secondary: #f4f8fb;
    --bs-accent: #fdd835;
    --bs-dark: #1e1e1e;
    --bs-darkblue: #10182B;
    --bs-light: #ffffff;
    --bs-spacer: 1.5rem;
    --bs-font-sans-serif: 'Be Vietnam Pro', sans-serif;
    --bs-lightblue: #87AAC9;
    --bs-blue: #304F8C;
    --bs-sand: #BFAF7F;
}

.card a:not(.btn) {
    color: var(--bs-blue) !important;
}

.card a:not(.btn):hover{
    color: var(--bs-lightblue) !important;
}


.bg-blue {
    background-color: #2B4981 !important;
}

.bg-darkblue {
    background-color: #10182B !important;
}

.bg-sand {
    background-color: #BFAF7F !important;
}

.bg-lightblue {
    background-color: #7FAECB !important;
}

.text-blue {
    color: #2B4981 !important;
}

.text-bs-blue{
    color: var(--bs-blue) !important;
}

.text-sand {
    color: #BFAF7F !important;
}

.text-lightblue {
    color: #7FAECB !important;
}

a:hover {
    opacity: 0.8;
}



/* === Margin === */
.mt-6 {
    margin-top: 4rem !important;
}

.mt-7 {
    margin-top: 5rem !important;
}

.mt-8 {
    margin-top: 6rem !important;
}

.mb-6 {
    margin-bottom: 4rem !important;
}

.mb-7 {
    margin-bottom: 5rem !important;
}

.mb-8 {
    margin-bottom: 6rem !important;
}

.ms-6 {
    margin-left: 4rem !important;
}

.ms-7 {
    margin-left: 5rem !important;
}

.ms-8 {
    margin-left: 6rem !important;
}

.me-6 {
    margin-right: 4rem !important;
}

.me-7 {
    margin-right: 5rem !important;
}

.me-8 {
    margin-right: 6rem !important;
}

.mx-6 {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
}

.mx-7 {
    margin-left: 5rem !important;
    margin-right: 5rem !important;
}

.mx-8 {
    margin-left: 6rem !important;
    margin-right: 6rem !important;
}

.my-6 {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
}

.my-7 {
    margin-top: 5rem !important;
    margin-bottom: 5rem !important;
}

.my-8 {
    margin-top: 6rem !important;
    margin-bottom: 6rem !important;
}

/* === Padding (responsive via vw) === */
.pt-6 {
  padding-top: 3.33vw !important;
}
.pt-7 {
  padding-top: 4.17vw !important;
}
.pt-8 {
  padding-top: 5vw !important;
}

.pb-6 {
  padding-bottom: 3.33vw !important;
}
.pb-7 {
  padding-bottom: 4.17vw !important;
}
.pb-8 {
  padding-bottom: 5vw !important;
}

.ps-6 {
  padding-left: 3.33vw !important;
}
.ps-7 {
  padding-left: 4.17vw !important;
}
.ps-8 {
  padding-left: 5vw !important;
}

.pe-6 {
  padding-right: 3.33vw !important;
}
.pe-7 {
  padding-right: 4.17vw !important;
}
.pe-8 {
  padding-right: 5vw !important;
}

.px-6 {
  padding-left: 3.33vw !important;
  padding-right: 3.33vw !important;
}
.px-7 {
  padding-left: 4.17vw !important;
  padding-right: 4.17vw !important;
}
.px-8 {
  padding-left: 5vw !important;
  padding-right: 5vw !important;
}

.py-6 {
  padding-top: 3.33vw !important;
  padding-bottom: 3.33vw !important;
}
.py-7 {
  padding-top: 4.17vw !important;
  padding-bottom: 4.17vw !important;
}
.py-8 {
  padding-top: 5vw !important;
  padding-bottom: 5vw !important;
}




.screen-reader-text {
  position: absolute; 
  left: -9999px;
  z-index: 999;
  padding: 1em;
  background-color: black;
  color: white;
  opacity: 0;
}

.screen-reader-text:focus {
  left: 50%;
  transform: translateX(-50%);
  opacity: 1;
}




/* STICKY NAVI */

.sticky-circle-nav {
    position: fixed;
    top: 35%;
    right: 1rem;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 1rem;
    z-index: 1050;
}

.circle-link {
    display: grid;
    place-items: center;
    width: 65px;
    height: 65px;
    background-color: #192646;
    border-radius: 50%;
    transition: background-color 0.3s ease, transform 0.2s ease;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.circle-link img {
    width: 30px;
    height: 30px;
    filter: brightness(0) invert(1);
    /* Weißes Icon bei dunklem BG */
}

.circle-link:hover {
    background-color: var(--bs-lightblue);
    transform: scale(1.1);
}

.has-tooltip {
    position: relative;
}

.has-tooltip::after {
    content: attr(data-tooltip);
    position: absolute;
    top: 50%;
    right: 120%;
    transform: translateY(-50%);
    white-space: nowrap;
    font-size: 18px;
    font-weight: 600;
    color: var(--bs-lightblue);
    background: transparent;
    padding: 0;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

.has-tooltip:hover::after {
    opacity: 1;
}


/* END STICKY NAVI */


/* Back to top */

.back-to-top {
    position: fixed;
    bottom: 6rem;
    right: 3rem;
    z-index: 9;
    width: 38px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.back-to-top img {
    width: 38px;
    height: 22px;
}

.back-to-top.show {
    opacity: 1;
    pointer-events: all;
}

/* End Back to top */



.container-fluid {
    padding: 0;
}



h2,
h3,
h4,
h5 {
    font-weight: 700 !important;
    letter-spacing: -0.02em;
    color: var(--bs-blue) !important;

}

h3 {
    padding: 1rem 0;
}

a {
    color: var(--bs-blue);
    text-decoration: none;
}

a:hover {
    color: #79B8DF;
    text-decoration: none;
}


.huge,
.huge-smaller {
    font-size: 12vw;
    line-height: 12vw;
    font-weight: 700;
    opacity: 0.3;
    text-align: right;
}

.huge-smaller {
    font-size: 3vw;
    line-height: 4vw;
}



.btn-primary {
    background-color: var(--bs-darkblue);
    border-color: var(--bs-darkblue);
    border-radius: 50px;
    color: #fff !important;
    padding: 20px 40px;
    font-weight: 500;
}

.btn-primary:hover {
    background-color: #003580;
    border-color: #003580;
}

.btn-outline-primary {
    color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.btn-outline-primary:hover {
    background-color: var(--bs-primary);
    color: white;
}

.card {
    background-color: var(--bs-light);
    border: 1px solid rgba(0, 0, 0, 0.05);
    border-radius: 0.5rem;
}

.section-padding {
    padding-top: var(--bs-spacer);
    padding-bottom: var(--bs-spacer);
}

.main-header {
    background-color: var(--bs-darkblue);
    transition: background-color 0.3s, color 0.3s;
    z-index: 1030;
    height: 145vw;
    max-height: 540px;
    background-position: top center;
    background-repeat: no-repeat;

}

.main-header p.lead.feiern{
    color: #bfaf7f!important;
}

.meta-menu {
    position: absolute;
    top: 50px;
    right: 0;
    margin-right: 5rem;
}
#mainNav {
  padding-top: 50px !important;
}

.meta-menu a {
    padding: 0.2rem 1.4rem 0.1rem 1.4rem;
}


.navbar {
    position: absolute !important;
    transition: all 0.9s cubic-bezier(0.25, 1, 0.5, 1);
}

.navbar .nav-link a,
.navbar .nav-item a,
.meta-menu a:hover {
    color: var(--bs-light) !important;
}

.navbar.scrolled .meta-menu a:not(.buttn):hover {
    color: var(--bs-lightblue) !important;
    opacity: .7;
}

.navbar .nav-item {
    padding: 1rem 1.4rem;
    position: relative;
}


/* Active Zustand Hauptnavi -------------------- */

.navbar-nav .nav-item.active::after {
    content: '';
    position: absolute;
    bottom: -12px;
    left: 50%;
    transform: translateX(-50%);
    width: 20px;
    height: 20px;
    /*background-color: var(--bs-primary);*/
    border-radius: 50%;
}

/* Farbvarianten je nach Position */
/*.navbar-nav .nav-item:nth-child(1).active::after {
    background-color: var(--bs-blue);

}

.navbar-nav .nav-item:nth-child(2).active::after {
    background-color: var(--bs-lightblue, #8ec5e8);

}

.navbar-nav .nav-item:nth-child(3).active::after {
    background-color: var(--bs-sand);

}*/

/* Sticky-Zustand = Kreis kleiner */
.navbar.scrolled .nav-item.active::after {
    width: 6px;
    height: 6px;
    bottom: -6px;
    /* enger unter der Schrift */
}

/* End Active Zustand Hauptnavi -------------------- */


/* Dropdown Hauptnavi -------------------- */

.navbar-nav{
    margin-right: 5rem;
    z-index: 9999;
}

.navbar .nav-item .dropdown-menu {
    border-radius: 0!important;    
}

.navbar .nav-item .dropdown-menu li{
    text-align: center;
}

.navbar-nav .nav-item:nth-child(1).active > a{
    color: var(--bs-blue)!important;
    /* Blau */
}

.navbar-nav .nav-item:nth-child(2).active > a{
    color: var(--bs-lightblue, #8ec5e8)!important;
    /* Sandfarben */
}

.navbar-nav .nav-item:nth-child(3).active > a{
    color: var(--bs-sand)!important;
    /* Hellblau */
}

.navbar .nav-item .dropdown-menu a{
    color: var(--bs-blue)!important;
}

@media (max-width: 992px) {
    #mainNav{
        z-index: 9999;
        /*box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;*/
    }

    #mainNav .nav-item .dropdown-menu {
        border: 0;
        box-shadow: none;
    }

    #mainNav .nav-item .dropdown-menu .menudropdownicon{
        display: none;
    }

    .navbar .nav-item .dropdown-menu li {
        text-align: left;
    }
}

@media (min-width: 992px) {
    .dropdown-menu[data-bs-popper]{
        left: 50%!important;
        transform: translateX(-50%);
    }

    .dropdown-toggle::after {
        display: none!important;
    }
    
}



/* End Dropdown Hauptnavi -------------------- */

.meta-menu a {
    color: var(--bs-lightblue);
}

.meta-menu a.buttn {
    background-color: var(--bs-lightblue);
    border-radius: 50px;
    color: var(--bs-light);
}


.navbar-toggler .navbar-toggler-icon::after, 
.navbar-toggler-icon, .navbar-toggler-icon::before{
    background-color: var(--bs-lightblue);
}

.navbar-collapse .navbar .nav-item a.nav-link {
    /*var(--bs-secondary) !important;*/
}


/* SCROLL-MENU */

.navbar.scrolled #mainNav {
  padding-top: 0px !important;
}


.navbar.scrolled {
    background-color: var(--bs-light);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    z-index: 99999;
    position: sticky !important;
    top: 0;
}

.navbar.scrolled .meta-menu {
    top: 10px;
    z-index: 99999;
}

.navbar.scrolled .nav-link {
    color: var(--bs-darkblue) !important;
}

.navbar.scrolled .navbar-brand img {
    height: 65px;
    width: auto;
}

.navbar.scrolled .nav-item {
    padding: 2rem 1.4rem 0rem;
}


.navbar .logo-scrolled {
    max-height: 40px;
    transition: opacity 0.2s ease;
}

.navbar.scrolled .logo-default {
    display: none !important;
}

.navbar.scrolled .logo-scrolled {
    display: inline-block !important;
}

/* END SCROLL-MENU */



/* Schriftgrössen */

p {
    font-size: 25px;
    line-height: 40px;
    font-weight: 200;
    margin-bottom: 50px;
}

h1 {
    color: var(--bs-light);
    font-size: 40px;
    font-weight: 200;
}

h2 {
    font-size: 40px;
    font-weight: 900;
    margin-bottom: 4rem;
}

h3 {
    font-size: 25px;
    line-height: 35px;
}

p.lead {
    color: var(--bs-lightblue);
    font-size: 18px;
    font-weight: 300;
}

.lead.eyebrow {
    text-transform: uppercase;
    font-weight: 400;
    margin-bottom: 0;
}

p.small,
.small-text p,
.small-text ul li {
    font-size: 20px;
    line-height: 30px;
}

small strong {
    font-weight: 500 !important;
}

/* END Schriftgrössen */


/* KREISE */

.circles {
    margin-top: -140px;
    margin-bottom: -140px;
    z-index: 2;
    position: absolute;
    left: 0;
    right: 0;
}

.circle-hover-switch,
.circle-switch {
    width: 95px;
    height: 95px;
    background-color: var(--bs-primary);
    border-radius: 50%;
    position: relative;
    overflow: hidden;
    display: grid;
    place-items: center;
    cursor: pointer;
    transition: background-color 0.3s ease;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
}

body:not(.pagelevel-0) .circle-hover-switch, 
body:not(.pagelevel-0) .circle-switch {
    background-color: transparent !important;
}

.circle-hover-switch .circle-content {
    position: absolute;
    color: white;
    font-weight: 500;
    text-align: center;
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.circle-hover-switch .circle-content.default {
    opacity: 1;
    transform: scale(1);
    z-index: 1;
}

.circle-hover-switch .circle-content.hover {
    opacity: 0;
    transform: scale(0.9);
    z-index: 2;
    font-size: 20px;
    font-weight: 500;
    padding-top: 20%
}

.circle-hover-switch:hover .circle-content.default {
    opacity: 0;
    transform: scale(1.1);
}

.circle-hover-switch:hover .circle-content.hover {
    opacity: 1;
    transform: scale(1);
}

/* END KREISE */

/* KI NOTICE */
.kinotice{
    backdrop-filter: blur(3px);
}

/* END KI NOTICE */


/* HOVER BILDER */
.img-overlay-box {
    position: relative;
    overflow: hidden;
    cursor: pointer;
}

.img-overlay-box img {
    transition: transform 0.3s ease;
    display: block;
    width: 100%;
    height: auto;
}

.img-overlay-box::before {
    content: "";
    position: absolute;
    inset: 0;
    background-color: #10182B;
    opacity: 0;
    transition: opacity 0.8s ease;
    z-index: 1;
}

.overlay-text,
.overlay-text:hover {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-weight: 200;
    opacity: 0;
    z-index: 2;
    transition: opacity 0.3s ease;
    text-align: center;
    padding: 0 1rem;
    font-size: 40px;
    line-height: 50px;
    color: #BFAF7F;
    width: 90%;
}

.img-overlay-box:hover::before {
    opacity: 0.9;
}

.img-overlay-box:hover .overlay-text {
    opacity: 1;
}

/* End HOVER BILDER */


/* Icon-Links */

.icon-links {
    padding: 1rem 20%;
}

.icon-links .icon-img {
    width: auto;
    height: 130px;
}

.icon-label {
    font-size: 30px;
    font-weight: 300;
    margin: 1.25rem 0 1.25rem 0;
}

.icon-arrow {
    font-size: 1.5rem;
    line-height: 1;
    font-weight: 400;
}

/* END Icon-Links */





/* Intro Unterseite */






.breadcrumb {
    background: none;
    padding: 0;
    font-size: 0.9rem;
    margin-bottom: 80px;
    z-index: 9;
    position: relative;
}

.breadcrumb-item a {
    color: var(--bs-primary);
    text-decoration: underline;
}

.breadcrumb-item.active {
    color: #888;
}

.custom-check-list {
    list-style: none;
    padding-left: 0;
    margin-top: 3rem;
}

.custom-check-list li {
    position: relative;
    padding-left: 4rem;
    margin-bottom: 1rem;
    color: var(--bs-primary);
    font-weight: 500;
}

.custom-check-list li::before {
    content: url('../icons/check.svg');
    /* Häkchen-Icon */
    position: absolute;
    left: 0;
    top: 0.1rem;
    width: 1rem;
    height: 1rem;
}





.icon-blue path {
    color: var(--bs-primary);
}


/* End Intro Unterseite */




/* NEWS */
.news-teaser,
.event-teaser {
    position: relative;
    margin: 3rem 0;
}

.news-teaser .badge {
    font-size: 20px;
    padding: 0.9rem 2.3rem;
    letter-spacing: 0.03em;
    position: absolute;
    top: -15px;
    left: 0px;
    border-radius: 0px;
    font-weight: 300;
}

.news-teaser h3 {
    color: #10182B !important;
}

.news.news-single h1{
    color: #10182B !important;
}

.news.news-single a.btn{
    background-color: var(--bs-darkblue);
    border-color: var(--bs-darkblue);
    color: #fff !important;
    padding: 10px 20px;
    font-weight: 500;
    margin-bottom: 2rem;
}




/* END NEWS */


/* CIRCLE BGs */
.circle-left,
.circle-right {
    background-image: url(../Images/circle-left.svg);
    background-repeat: no-repeat;
    background-position: bottom left;
    min-height: 534px;
    display: flex;
    align-items: end;
    justify-content: end;
}

.circle-right {
    background-image: url(../Images/circle-right.svg);
    background-position: bottom right;
}

/* End CIRCLE BGs */





/* SLIDER STARTSEITE */

#mmiCarousel .slider-circle-wrapper {
    margin-bottom: 1rem;
}

.slider-circle-content {
    /*! position: absolute; */
    /*! top: 50%; */
    width: 90%;
    max-width: 95vw;
    background-color: #10182B;
    padding: 2.5rem 1rem;
    border-radius: 50%;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    /*! aspect-ratio: 1/1; */
    transform: translate(5%, -20%);

}


.slider-circle-content p {
    font-size: 16px;
    line-height: 30px;
    color: white;

}

.carousel-indicators [data-bs-target] {
    width: 12px;
    height: 12px;
    margin: 10px 5px 5px 5px;
    background-color: #BFAF7F;
    opacity: 1;
}

.carousel-item {
    transition: opacity 1s ease-in-out;
}


    
    .slider-circle-content {
        border-radius: 0;
        transform: inherit;
        position: inherit;
        width: 100%;
        max-width: inherit;
    }



@media (min-width: 992px) {
    .slider-circle-content {
        width: 90%;
        max-width: 95vw;
        background-color: #10182B;
        padding: 2.5rem 1rem;
        border-radius: 50%;
        z-index: 2;
        display: flex;
        align-items: center;
        justify-content: space-between;
        /*! aspect-ratio: 1/1; */
        transform: translate(5%, -20%);
        
        
        width: 675px;
        
        transform: translate(0%, -45%);
        aspect-ratio: 1/1;
        left: 20%;
    }

    .slider-circle-content p {
        font-size: 18px;
        line-height: 30px;
        color: white;

    }

    .carousel-indicators [data-bs-target] {
        width: 19px!important;
        height: 19px!important;
        margin: 20px 10px 5px 10px!important;
        background-color: #BFAF7F!important;
        opacity: 1!important;
    }
}



@media (min-width:1800px) {
    .slider-circle-wrapper{
        height: 200px!important;
    }
    
    .slider-circle-content {
        width: 675px;
        transform: translate(5%, -75%);
    }

    .slider-circle-content p {
        font-size: 20px;
        line-height: 35px;
        color: white;
    }
}


.slider-text {
    flex: 1;
    padding: 0 1rem;
    text-align: center;
}

.slider-circle-content h3 {

    color: var(--bs-lightblue);
    font-size: 30px;
    line-height: 55px;
}



.circle-nav {
    background: none;
    border: none;
    padding: 0;
    width: 40px;
    height: 40px;
    cursor: pointer;
    display: grid;
    place-items: center;
}

.circle-nav img {
    width: 40px;
    height: 40px;
}

.carousel-indicators {
    display: flex;
    justify-content: center;
    margin-top: 1rem;
}

.carousel-indicators button {
    width: 12px!important;
    height: 12px!important;
    border-radius: 50%!important;
    margin: 0 4px!important;
    opacity: 1!important;
    border: none!important;
}

.carousel-indicators .active {
    opacity: 1!important;
}


.carousel-indicators .active {
    background-color: lightblue!important;
}

/* END SLIDER STARTSEITE */





@media (max-width: 1024px) {

}



.footer {
    position: relative;
    background-color: var(--bs-darkblue);
    overflow: hidden;
}

.footer a {
    color: #7FAECB;
    text-decoration: none;
    line-height: 2.3rem;
}

.footer .small-space a{
    line-height: 1.5rem;
}

.footer .white-txt a {
    color: #fff;
}

.footer a:hover {
    text-decoration: none;
    opacity: 0.8;
}

.footer-contact img,
.footer-links .bullet {
    width: 30px;
    height: 30px;
    vertical-align: middle;
    margin-right: 0.5rem;
}

.footer-links li {
    margin-bottom: 1rem;
}

.footer-contact img {
    float: left;
    margin-right: 20px !important;
    margin-bottom: 7px;
    clear: left;
}

footer p {
    margin-left: 50px;
    margin-bottom: 0px;
    font-size: 20px;
}

.footer-contact a {
    font-size: 18px;
}

.bullet {
    display: inline-block;
    border-radius: 50%;
}

.bullet-blue {
    background-color: #2d4c94;
}

.bullet-gold {
    background-color: #d3c08f;
}

.bullet-lightblue {
    background-color: #8ec5e8;
}

/* Dekorativer Kreis rechts oben */
.footer-gradient {
    position: absolute;
    top: -100px;
    right: -150px;
    width: 500px;
    height: 500px;
    background: radial-gradient(ellipse at center, rgba(31, 45, 82, 0.8) 0%, transparent 80%);
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}



/* SECTION JOBLIST ------------------ */


/* Gradient-Hintergrund */
.section-gradient {
    background-image: url(../Images/circle-left.svg), linear-gradient(to bottom, #E4EEF4 0%, #ffffff 40%, #ffffff 60%, #E4EEF4 100%);
    background-repeat: no-repeat, no-repeat;
    background-position: top 20% left, center center;
    background-size: auto, cover;
    /* erster für Verlauf, zweiter für SVG */
}

.section-gradient.white {
    background-image: url(../Images/circle-left.svg);
}

/* Filter Buttons */

.filter {
    justify-content: center;
}

.filter-btn,
.btn.btn-dark.rounded-pill {
    background-color: var(--bs-primary);
    color: white !important;
    font-weight: 500;
    padding: 0.5rem 1.75rem;
    border-radius: 999px;
    border: none;
    transition: all 0.3s ease;
}

.filter-btn:hover,
.filter-btn.active,
.btn.btn-dark.rounded-pill:hover,
.btn.btn-dark.rounded-pill.active {
    background-color: var(--bs-lightblue);
}

/* Seminar-Eintrag */
.seminar-item {
    position: relative;
    border-top: 1px solid var(--bs-lightblue);
}

.seminar-item:last-child {
    border-bottom: 1px solid var(--bs-lightblue);
}

.seminar-item a {
    color: var(--bs-sand);
    font-weight: 500;
    transition: all 0.2s ease;
}

.seminar-item a:hover {
    text-decoration: underline;
}

/* END SECTION JOBLIST ------------------ */




/* Kontaktformular */


:root {
    --bs-primary: #1e3f8f;
    --bs-lightblue: #7cb6dd;
}

body {
    font-family: 'Be Vietnam Pro', sans-serif;
}

.text-lightblue {
    color: var(--bs-lightblue) !important;
}

.text-mediumblue {
    color: #869db4!important;
}

.text-primary {
    color: var(--bs-primary) !important;
}

.border-bottom-only {
    border: none;
    border-bottom: 1px solid #7cb6dd;
    border-radius: 0;
    background-color: transparent;
    box-shadow: none !important;
    box-shadow: none !important;
}

.border-bottom-only:focus {
    border-color: #1e3f8f;
    outline: none;
    box-shadow: none;
}

input.icon-left {
    background-image: url('../icons/calendar-icon.svg');
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 2rem;
}

.date-wrapper {
  position: relative;
  display: inline-block;
}

.date-wrapper .calendar-icon {
  position: absolute;
  right: 1rem;
  top: 50%;
  width: 2rem;
  height: 2rem;
  background: url('../icons/calendar-icon.svg') no-repeat center / contain;
  background-color: #fff;
  cursor: pointer;
}


/* End Kontaktformular */


/* TextSlider */

.testimonial-slider {
    background: #ffffff;
    position: relative;
    overflow: hidden;
}

.testimonial-slider::before {
    content: "";
    background-image: url('../Images/logo-bg.svg');
    /* Optionales Logo im Hintergrund */
    background-repeat: no-repeat;
    background-position: center;
    background-size: 300px;
    opacity: 0.03;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 100%;
    transform: translate(-50%, -50%);
    z-index: 0;
}

.testimonial-content {
    max-width: 960px;
    margin: 0 auto;
    z-index: 1;
    position: relative;
    min-height: 350px;
    align-content: center;
}

.testimonial-slider .carousel-control-icon {
    font-size: 2rem;
    color: #1e3f8f;
    z-index: 2;
}

.testimonial-slider .carousel-control-prev,
.testimonial-slider .carousel-control-next {
    width: 5%;
}

.testimonial-content p,
.testimonial-content h5 {
    opacity: 0;
    transform: translateX(10px);
    transition: all 0.6s ease;
}

.testimonial-slider .carousel-item.active .testimonial-content p,
.testimonial-slider .carousel-item.active .testimonial-content h5 {
    opacity: 1;
    transform: translateY(0);
}





/* End TextSlider */

/* FORMULARE */

.form-container form input, input.form-control{
    background-color: transparent;
    border: none;
    border-bottom: 1px solid var(--bs-lightblue);
    border-radius: 0;
    box-shadow: none !important;
    padding: 0.5rem 0;
    color: var(--bs-primary);
}


.form-container form input::-webkit-input-placeholder,  .form-container form textarea::-webkit-input-placeholder { /* WebKit browsers */
    color: transparent;
}
.form-container form input:-moz-placeholder,  .form-container form textarea:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
    color: transparent;
}
.form-container form input::-moz-placeholder,  .form-container form textarea::-moz-placeholder { /* Mozilla Firefox 19+ */
    color: transparent;
}
.form-container form input:-ms-input-placeholder,  .form-container form textarea:-ms-input-placeholder { /* Internet Explorer 10+ */
    color: transparent;
}



.form-container form textarea{
    background-color: transparent;
    border: 1px solid var(--bs-lightblue);;
    border-radius: 0;
    box-shadow: none !important;
    padding: 0.5rem 0;
    color: var(--bs-primary);
    height: 192px;
    resize: none;
}

.form-container .form-actions button, .form-group input[type="submit"] {
    background-color: var(--bs-primary);
    color: white !important;
    font-weight: 500;
    padding: 0.75rem 1.75rem;
    border-radius: 999px;
    border: none;
    transition: all 0.3s ease;
}

.form-container .form-actions button:hover, .form-group input[type="submit"]:hover {
    background-color: var(--bs-lightblue);
}

.form-container form label,  label.form-label, .control-label{
    color: var(--bs-primary);
    font-weight: 500;
    margin-top: 1rem;
    margin-bottom: 1rem;
}

.form-element-check{
    display: flex;
    align-items: center;
    gap: 1rem;
}

.form-element-type-checkbox input[type="checkbox"] {
    appearance: auto!important;
}

select.selectpicker{
    background-color: transparent;
    border: none;
    border-bottom: 1px solid var(--bs-lightblue);
    border-radius: 0;
    box-shadow: none !important;
    padding: 0.5rem 0;
    display: block!important;
    color: var(--bs-primary);
}

/* End FORMULARE*/


/* Impressionen AREA */

.text-lightblue {
    color: #79B8DF;
}

.highlight-quote {
    font-style: italic;
    color: #7fafcb;
    font-size: 1.2rem;
    max-width: 60%;
    margin-left: auto;
    border: 0;
}

.impressionen-section img {
    object-fit: cover;
}

.impressionen-section a.btn img {
    width: 15px;
    margin: 0px 5px 2px 0;
}

.impressionen-section a{
    text-decoration: underline;
    color: #304f8c;
}

.highlight-quote img {
    width: 21px;
    margin: 0 1px 3px 5px;
}

.highlight-quote.text-start {
    margin-left: unset;
    margin-right: auto;
    max-width: 99%;
}

/* End Impressionen AREA */

.mmi-seminarliste .mmi-seminarliste-filter{
    gap: 0.5rem !important;
}

.mmi-seminarliste .mmi-seminarliste-filter .btn{
    background-color: var(--bs-primary) !important;
    color: white !important;
    font-weight: 500 !important;
    border: none !important;
    transition: all 0.3s ease !important;
    border-radius: var(--bs-border-radius-pill) !important;
    padding: 1rem 1.75rem!important;
}

.mmi-seminarliste .mmi-seminarliste-filter .btn:hover, .mmi-seminarliste .mmi-seminarliste-filter .btn.active{
    background-color: var(--bs-lightblue) !important;
}

.mmi-seminarliste .seminar-liste-container .seminar-gruppe h2{
    font-size: 1.875rem!important;
    font-weight: 700!important;
    line-height: 3.438rem!important;
    color: #304F8C!important;
    margin: 4rem 0px;
}

.mmi-seminarliste .seminar-liste-container .seminar-gruppe hr{
    display: none!important;
}

.mmi-seminarliste .seminar-liste-container .seminar-gruppe .seminar-item{
    padding: 1.5rem 2rem!important;
    border-bottom: none!important;
}

.mmi-seminarliste .seminar-liste-container .seminar-gruppe .seminar-item:last-child{
    border-bottom: 1px solid #7FAECB!important;
}

.mmi-seminarliste .seminar-liste-container .seminar-gruppe .seminar-item .seminar-zeitraum{
    font-size: 1.125rem!important;
    line-height: 1.563rem!important;
    color: #7FAECB!important;
}

.mmi-seminarliste .seminar-liste-container .seminar-gruppe .seminar-item .seminar-label{
    font-size: 1.125rem!important;
    line-height: 1.563rem!important;
    color: #304F8C!important;
}

.mmi-seminarliste .seminar-liste-container .seminar-gruppe .seminar-item .seminar-titel{
    font-size: 1.438rem!important;
    font-weight: 500!important;
    line-height: 2.188!important;
    color: #304F8C!important;
}

.mmi-seminarliste .seminar-liste-container .seminar-gruppe .seminar-item a{
    font-size: 1.125rem!important;
    line-height: 1.563rem!important;
    color: #7DB8D4!important;
}


/*Kurs Detailseiten*/
.event-detail p, .event-detail p span{
    font-size: 20px!important;
    line-height: 30px!important;
    font-family: 'Be Vietnam Pro', sans-serif!important;
}

.mmi-events.event-detail .texthtml * {
	font-family: inherit !important;
	line-height: inherit !important;
	margin: inherit !important;
	margin-bottom: 1rem !important;
}

.mmi-events.event-detail .lead.eyebrow{
    font-weight: 400 !important;
    margin-bottom: 0 !important;
}

.mmi-events.event-detail .texthtml li{
    margin: 0!important;
}

.mmi-events.event-detail .texthtml a{
    color: #1e3f8f!important;
}

.mmi-events.event-detail .texthtml a:hover{
    color: #7cb6dd!important
}

.event-detail .pagetitle-toolbar{
    border-top: 1px solid var(--bs-lightblue)!important;
    border-bottom: 1px solid var(--bs-lightblue)!important;
}

.event-detail .pagetitle-toolbar svg path {
    fill: var(--bs-blue)!important;
}

.event-detail .shariff-button{
    border: none!important;;
    margin: 0!important;
}

.event-detail .shariff-button a span{
    color: var(--bs-blue)!important;
}

.event-detail p{
   margin-bottom: 0!important; 
}

.event-detail .contact p{
    margin-bottom: 1rem!important;
}

.event-detail:not(.contact p){
   margin-bottom: 0!important; 
}

.event-detail h3.subtitle.texthtml p strong{
    color: var(--bs-lightblue)!important;
    margin-bottom: 0!important;
}

.event-detail .desc.texthtml p {
  margin-bottom: 0!important;
}

.event-detail .card{
    border: 2px solid var(--bs-blue)!important;
}

.event-detail .texthtml img {
  float: none !important;
}


/*Mein MMI Profil Menü*/
#c1637 .card.card-item.event-cat{
    border: 0!important;
    margin-bottom: 1rem!important;
}

#c1637 .card.card-item.event-cat a {
  font-size: 1.5rem!important;
  text-decoration: underline!important;
}

.event-list.card-btns .title{
    font-size: 1.5rem!important;
}

/*VA Anfrage Button Color*/
#veranstaltungsanfrage-app button{
    background-color: var(--bs-primary);
    color: white !important;
    font-weight: 500;
    padding: 0.5rem 1.75rem;
    border-radius: 999px;
    border: none;
    transition: all 0.3s ease;
    border-radius: var(--bs-border-radius-pill) !important;
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
}

#veranstaltungsanfrage-app button:hover{
    background-color: var(--bs-lightblue);
}

/*VA Anfrage label color*/
#veranstaltungsanfrage-app label{
    color: var(--bs-primary);
    font-weight: 500;
    margin-top: 1rem;
    margin-bottom: 1rem;
}


/* Merkliste Button */
.btn-merkliste-delete .text-hover{
    display: none;
}

.btn-merkliste-delete:hover .text-normal{
    display: none;
}

.btn-merkliste-delete:hover .text-hover {
  display: block;
}
  

/* RESPONSIVE ------- */

@media (max-width: 2000px) {
    .logo-footer {
        max-width: 200px;
        position: relative;
        z-index: 9;
    }

}

@media (max-width: 991px) {
    .meta-menu a {
        padding: 0.2rem 0.3rem;
    }

    .meta-menu {
        position: absolute;
        top: 20px;
        right: 0;
        max-width: 70%;
        left: 0;
        right: 0;
        margin-right: auto;
        margin-left: auto;
    }

    .logo-default {
        max-width: 100px;
    }

    .navbar-collapse {
        background-color: var(--bs-light);
    }

    .navbar .nav-link a,
    .navbar .nav-item a,
    .meta-menu a:hover {
        color: #10182B !important;
    }

}


@media (max-width: 576px) {
    .meta-menu {
        position: unset;
        max-width: 100%;
    }

    .main-header {
        padding: 10px 60px;
    }

    .circle-link {
        background-color: var(--bs-lightblue);
    }

    p.lead {
        line-height: 26px;
    }
}





/* Responsive Schriftgrößen */
@media (max-width: 1200px) {
    h1 {
        font-size: 2.5rem;
    }

    h2 {
        font-size: 2rem;
    }

    h3 {
        font-size: 1.75rem;
    }

    h4 {
        font-size: 1.5rem;
    }

    h5 {
        font-size: 1.25rem;
    }

    body {
        font-size: 1rem;
    }

    .lead {
        font-size: 1.1rem;
    }

    .nav-link {
        font-size: 1rem;
    }

    .btn {
        font-size: 0.95rem;
    }

    blockquote {
        font-size: 1.1rem;
    }

    .form-control,
    .form-select,
    label,
    .card-title,
    footer small {
        font-size: 1rem;
    }
}

@media (max-width: 992px) {
    h1 {
        font-size: 2.25rem;
    }

    h2 {
        font-size: 1.75rem;
    }

    h3 {
        font-size: 1.5rem;
    }

    h4 {
        font-size: 1.25rem;
    }

    h5 {
        font-size: 1.125rem;
    }

    body {
        font-size: 0.95rem;
    }

    .lead {
        font-size: 1rem;
    }

    .nav-link {
        font-size: 0.95rem;
    }

    .btn {
        font-size: 0.9rem;
    }

    blockquote {
        font-size: 1rem;
    }

    .form-control,
    .form-select,
    label,
    .card-title,
    footer small {
        font-size: 0.95rem;
    }

    /* .huge {
        font-size: 115px;
        line-height: 115px;
    }

    .huge-smaller {
        font-size: 35px;
        line-height: 35px;
    }
*/

    .testimonial-slider .lead{
        font-size: 1rem;
        font-weight: unset!important;
    }

    .testimonial-slider .carousel-control-prev{
        bottom: 0;
        top: unset;
        left: 30%;
    }

    .testimonial-slider .carousel-control-next{
        bottom: 0;
        top: unset;
        right: 30%;
    }

    .introbild img{
        height: 50vw;
    }
}

@media (max-width: 768px) {
    h1 {
        font-size: 2rem;
    }

    h2 {
        font-size: 1.5rem;
    }

    h3 {
        font-size: 1.25rem;
    }

    h4 {
        font-size: 1.125rem;
    }

    h5 {
        font-size: 1rem;
    }

    body {
        font-size: 0.9rem;
    }

    .lead {
        font-size: 0.95rem;
    }

    .nav-link {
        font-size: 0.9rem;
    }

    .btn {
        font-size: 0.875rem;
    }

    blockquote {
        font-size: 0.95rem;
    }

    .form-control,
    .form-select,
    label,
    .card-title,
    footer small {
        font-size: 0.9rem;
    }
    .highlight-quote{
        font-size:1rem;
        max-width:90%;
    }

    .impressionen-section img, .impressionen-section blockquote {
        padding: 0 !important;
        margin: 1rem 0 !important;
        text-align: left !important;
    }

    .contact .rounded-circle {
        width: 100px;
    }


}

@media (max-width: 576px) {
    h1 {
        font-size: 1.75rem;
    }

    h2 {
        font-size: 1.25rem;
    }

    h3 {
        font-size: 1.125rem;
    }

    h4 {
        font-size: 1rem;
    }

    h5 {
        font-size: 0.95rem;
    }

    body {
        font-size: 0.85rem;
    }

    .lead {
        font-size: 0.9rem;
    }

    .nav-link {
        font-size: 0.85rem;
    }

    .btn {
        font-size: 0.85rem;
    }

    blockquote {
        font-size: 0.9rem;
    }

    .form-control,
    .form-select,
    label,
    .card-title,
    footer small {
        font-size: 0.85rem;
    }



}




@media (min-width: 1600px) {

    .container,
    .container-lg,
    .container-md,
    .container-sm,
    .container-xl,
    .container-xxl {
        max-width: 1520px !important;
    }

}



@media (min-width: 2000px) {
    .logo-footer {
        transition: margin-left 0.6s ease-in-out;
    }

    .logo-footer {
        margin-left: -60px;
    }

    .navbar {
        max-width: 95%;
        left: 0;
        right: 0;
        margin-left: auto;
        margin-right: auto;
    }

    .navbar.scrolled {
        max-width: unset;
    }
}
/*
@media (min-width: 576px) {
    section.circles .circle-hover-switch, section.circles .circle-switch {
        width: 95px;
        height: 95px;
    }
}*/

@media (min-width: 768px) {
    section.circles .circle-hover-switch, section.circles .circle-switch {
        width: 120px;
        height: 120px;
    }

    body:not(.pagelevel-0) .circle-hover-switch, 
    body:not(.pagelevel-0) .circle-switch {
        /*Transparent*/
        background-color: transparent !important;
    }

    .slider-circle-wrapper{
        height: 460px;
    }
}

@media (min-width: 992px) {
    section.circles .circle-hover-switch, section.circles .circle-switch {
        width: 240px;
        height: 240px;
    }

    .slider-circle-wrapper{
        height: 400px;
    }


}




