/* =====================
   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;
}

.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-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: 1050;
    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-darkblue);
    text-decoration: none;
}

a:hover {
    color: var(--bs-blue);
    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;
    min-height: 540px;
    background-image: url(../Images/bow-top-header.svg);
    background-position: top center;
    background-repeat: no-repeat;

}

.meta-menu {
    position: absolute;
    top: 50px;
    right: 0;
}
#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 .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);
    /* Blau */
}

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

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

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

/* End Active Zustand 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 {
    background-color: rgba(255, 255, 255, 0.9);
    border: 1px solid #fff;
}

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


/* SCROLL-MENU */

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


.navbar.scrolled .meta-menu a.buttn {
    background: transparent;
    color: var(--bs-lightblue);
}

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

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

.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: 240px;
    height: 240px;
    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;
}

.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: 30px;
    font-weight: 200;
    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 */

/* 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: 150px;
}

.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 */
.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;
}



@media (min-width:768px) {
    .slider-circle-content {
        width: 675px;
        transform: translate(5%, -50%);
        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-content {
        width: 675px;
        transform: translate(-50%, -50%);
    }

    .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;
    background-color: #c8e3ff!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: #0b1325;
    overflow: hidden;
}

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

.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-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;
    background-image: url(../icons/mmi-logomarke-big.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
}

.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 */


/* Impressionen AREA */

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

.highlight-quote {
    font-style: italic;
    color: #79B8DF;
    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;
}

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

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

/* End Impressionen AREA */


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

@media (max-width: 2000px) {
    .logo-footer {
        max-width: 200px;
    }

}

@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;
    }
*/
}

@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%;
    }
}

@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;
    }
}