/* Standard: alles wie gehabt – kein fixed */
#donateBtn {
    transition: transform .2s ease, opacity .2s ease;
}

/* Ausgeklinkt (floating) ab lg und nur auf großen Screens sichtbar */
@media (min-width: 992px) {
    #donateBtn.is-floating {
        position: fixed;
        top: 16px;
        right: var(--donate-right, 24px); /* wird per JS exakt auf Containerkante gesetzt */
        z-index: 1050;
        transform: translateZ(0);
    }
        /* kleine „kompakt“-Optik beim Schweben (optional) */
        #donateBtn.is-floating .fw-bold {
            letter-spacing: .02em;
        }
}

/* ===== MOBILE "SPENDEN"-BUTTON ===== */
.donate-fab {
    position: fixed;
    right: 5vw; /* proportional zum Bildschirmrand */
    bottom: 6vh; /* bleibt bei Scroll und Bildschirmgrößen proportional gleich */
    z-index: 1070;
    border-radius: 9999px;
    padding: 0.9rem 1.4rem;
    font-weight: 700;
    text-transform: uppercase;
    background-color: #d6ad43;
    color: #000;
    box-shadow: 0 8px 24px rgba(0,0,0,0.25);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

    /* Hover-Effekt */
    .donate-fab:hover {
        transform: translateY(-2px);
        box-shadow: 0 12px 28px rgba(0,0,0,0.35);
    }

    /* keine Bewegung auf kleinen Geräten beim Scrollen */
    .donate-fab.is-fixed {
        position: fixed;
    }

/* optional: leicht verkleinern auf sehr kleinen Screens */
@media (max-height: 600px) {
    .donate-fab {
        bottom: 4vh;
        padding: 0.7rem 1.1rem;
    }
}


.osahan-main-nav .container {
    display: flex;
    align-items: center;
}



/* OWL SLIDER */
.slider-wrap {
    position: relative;
    background: #fff;
    border-radius: 16px;
    padding: 16px 48px
}

.logo-item {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px
}

.logo-box {
    width: 100%;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center
}

    .logo-box img {
        max-width: 100%;
        max-height: 100%;
        object-fit: contain;
        display: block
    }

.owl-dots {
    display: none
}

.owl-nav button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border-radius: 999px;
    background: #111 !important;
    color: #fff !important
}

.owl-nav .owl-prev {
    left: 8px
}

.owl-nav .owl-next {
    right: 8px
}

/* Pfeile */
.slider-wrap {
    position: relative;
    overflow: visible;
    padding: 16px 32px;
}
/* overflow sichtbar */
.owl-nav button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 36px;
    height: 36px;
    border-radius: 999px;
    background: #111 !important;
    color: #fff !important;
    opacity: .75;
    transition: opacity .2s ease;
    box-shadow: 0 4px 14px rgba(0,0,0,.2);
}

    .owl-nav button:hover {
        opacity: 1;
    }

.owl-nav .owl-prev {
    left: -22px;
}
/* außerhalb */
.owl-nav .owl-next {
    right: -22px;
}
/* außerhalb */

/* Wenn du die Pfeile nur auf Hover zeigen willst: */

.slider-wrap:hover .owl-nav button { opacity: .9; }
.slider-wrap .owl-nav button { opacity: 0; }


@media (max-width: 768px) {
    .banner-slide {
        background-image: linear-gradient(rgba(0,0,0,0.35), rgba(0,0,0,0.35)), var(--mobile-bg);
    }
}


.w-80 {
    width: 80% !important;
}

@media (min-width: 992px) {
    .desktop-margin-right {
        margin-right: 10%;
    }
}
.nav-link-hover:hover {
    color: #d6ad43 !important;
}

:root {
    --bs-warning-rgb: 214, 173, 67;
}

.navbar-nav .nav-item > .nav-link {
    position: relative;
}

.navbar-nav .nav-item.active > .nav-link::before,
.navbar-nav .nav-link.active::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3px;
    background-color: #d6ad43; /* Wunschfarbe */
}


.navbar-nav .nav-link.active {
    color: #d6ad43; /* dein Sporthilfe-Gold o.ä. */
}

.nav-link.active {
    color: #d6ad43; /* dein Sporthilfe-Gold o.ä. */
}

/* Optional: Dropdown-Items */
.dropdown-menu .dropdown-item.active {
    font-weight: 600;
    color: #000000;
}


.newsletter-divider-top,
.newsletter-divider-bottom {
    width: 100%;
    height: 1px;
    background: rgba(255,255,255,0.08); /* sehr leichte Linie */
}

.newsletter-divider-top {
    margin-bottom: 40px;
}

.newsletter-divider-bottom {
    margin-top: 40px;
}


/* Wrapper ist Referenz für absolute Positionierung */
.bg-homepage {
    position: relative; /* falls noch nicht gesetzt */
}

/* Container für beide Fähnchen */
.hero-ribbons {
    position: absolute;
    top: -40px; /* lässt die „Fahnen“ über die schwarze Leiste ragen */
    right: 0;
    z-index: 1050; /* über der Navigation */
    display: flex;
    flex-direction: column;
    gap: 0; /* direkt untereinander – kannst du anpassen */
    align-items: flex-end;
    pointer-events: auto;
}

/* einzelne Fahne */
.hero-ribbon img {
    width: 150px;
    max-width: 150px;
    height: auto;
    max-height: 250px;
    display: block;
}

/* Nur Desktop – unter 992px ausblenden */
@media (max-width: 991.98px) {
    .hero-ribbons {
        display: none !important;
    }
}

#sponsor-carousel .logo-item img {
    width: 160px !important;
    height: auto !important;
}

#sponsor-carousel .logo-item {
    padding: 10px 10px; /* mehr Abstand */
}


/* Nur MOBILE: Offcanvas-Menü */
@media (max-width: 991.98px) {
    /* Offcanvas-Nav generell mittig ausrichten */
    .offcanvas .navbar-nav {
        align-items: center;
    }

    /* Dropdown-Menü im Offcanvas: untereinander, ohne Rahmen, zentrierter Text */
    .offcanvas .dropdown-menu {
        position: static;
        float: none;
        transform: none !important;
        box-shadow: none;
        border: 0;
        background: transparent;
        padding: 0;
        margin: 0 0 0.75rem;
        text-align: center;
    }

        /* Einzelne Einträge (Gremien, Team, …) zentrieren */
        .offcanvas .dropdown-menu .dropdown-item {
            text-align: center;
            padding-left: 0;
            padding-right: 0;
        }
}

.pillarix-cta-button {
    margin: 2rem 0;
}

    .pillarix-cta-button .btn {
        /* Hier euer Olympia-/Sporthilfe-Branding */
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.05em;
    }

        .pillarix-cta-button .btn:hover {
            /* Hier euer Olympia-/Sporthilfe-Branding */
            background: #000;
        }

.elite-filter-nav .nav-link {
    border-radius: 2px;
    padding-inline: 1.25rem;
}

    .elite-filter-nav .nav-link.active {
        /* ggf. deine Sporthilfe-Farbe */
        background-color: #d4a214;
        color: #fff;
    }

/* --- FILTER NAV STYLING --- */

.elite-filter-nav {
    gap: 0.75rem; /* Abstand zwischen den Pills */
    flex-wrap: wrap; /* Umbrechen wenn zu lang */
}

    .elite-filter-nav .nav-link {
        color: #c8a23b; /* Gold */
        border: 1px solid #c8a23b;
        padding: 6px 14px;
        border-radius: 3px;
        font-weight: 600;
        background: transparent;
        transition: all 0.2s ease;
    }

        /* Hover & Active identisch */
        .elite-filter-nav .nav-link:hover,
        .elite-filter-nav .nav-link.active {
            background: #c8a23b; /* Gold */
            color: #fff !important;
            border-color: #c8a23b;
        }

        /* Fokus-Ring entfernen */
        .elite-filter-nav .nav-link:focus {
            box-shadow: none !important;
        }


/* Sticky Seitennavigation (Elitesportler-Seite) */
@media (min-width: 992px) { /* nur Desktop / große Screens */
    .sidebar-sticky {
        position: sticky;
        top: 100px; /* Abstand von oben – ggf. an Navbar-Höhe anpassen */
        z-index: 20; /* damit sie nicht unter Content verschwindet */
    }
}

/* CTA-Button-Wrapper (span mit .rte-cta-btn) */
.page-section.rte span.rte-cta-btn {
    display: inline-block;
    padding: 0.6rem 1.4rem;
    border-radius: 999px;
    background-color: #d6ad43; /* Sporthilfe-Gold */
    border: 1px solid #d6ad43;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: all 0.2s ease-in-out;
}

    /* Link im Button */
    .page-section.rte span.rte-cta-btn a {
        color: #000 !important;
        text-decoration: none !important;
    }

    /* Hover-Effekt */
    .page-section.rte span.rte-cta-btn:hover {
        background-color: #000;
        border-color: #000;
    }

        .page-section.rte span.rte-cta-btn:hover a {
            color: #fff !important;
        }
.page-section.rte span.rte-cta-btn {
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
}

.hero-inline-img {
    max-height: 80vh;
    object-fit: contain;
}
