.glightbox-container{width:100%;height:100%;position:fixed;top:0;left:0;z-index:999999!important;overflow:hidden;-ms-touch-action:none;touch-action:none;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%;-webkit-backface-visibility:hidden;backface-visibility:hidden;outline:0}.glightbox-container.inactive{display:none}.glightbox-container .gcontainer{position:relative;width:100%;height:100%;z-index:9999;overflow:hidden}.glightbox-container .gslider{-webkit-transition:-webkit-transform .4s ease;transition:-webkit-transform .4s ease;transition:transform .4s ease;transition:transform .4s ease,-webkit-transform .4s ease;height:100%;left:0;top:0;width:100%;position:relative;overflow:hidden;display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.glightbox-container .gslide{width:100%;position:absolute;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;opacity:0}.glightbox-container .gslide.current{opacity:1;z-index:99999;position:relative}.glightbox-container .gslide.prev{opacity:1;z-index:9999}.glightbox-container .gslide-inner-content{width:100%}.glightbox-container .ginner-container{position:relative;width:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;max-width:100%;margin:auto;height:100vh}.glightbox-container .ginner-container.gvideo-container{width:100%}.glightbox-container .ginner-container.desc-bottom,.glightbox-container .ginner-container.desc-top{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.glightbox-container .ginner-container.desc-left,.glightbox-container .ginner-container.desc-right{max-width:100%!important}.gslide iframe,.gslide video{outline:0!important;border:none;min-height:165px;-webkit-overflow-scrolling:touch;-ms-touch-action:auto;touch-action:auto}.gslide:not(.current){pointer-events:none}.gslide-image{-webkit-box-align:center;-ms-flex-align:center;align-items:center}.gslide-image img{max-height:100vh;display:block;padding:0;float:none;outline:0;border:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;max-width:100vw;width:auto;height:auto;-o-object-fit:cover;object-fit:cover;-ms-touch-action:none;touch-action:none;margin:auto;min-width:200px}.desc-bottom .gslide-image img,.desc-top .gslide-image img{width:auto}.desc-left .gslide-image img,.desc-right .gslide-image img{width:auto;max-width:100%}.gslide-image img.zoomable{position:relative}.gslide-image img.dragging{cursor:-webkit-grabbing!important;cursor:grabbing!important;-webkit-transition:none;transition:none}.gslide-video{position:relative;max-width:100vh;width:100%!important}.gslide-video .plyr__poster-enabled.plyr--loading .plyr__poster{display:none}.gslide-video .gvideo-wrapper{width:100%;margin:auto}.gslide-video::before{content:'';position:absolute;width:100%;height:100%;background:rgba(255,0,0,.34);display:none}.gslide-video.playing::before{display:none}.gslide-video.fullscreen{max-width:100%!important;min-width:100%;height:75vh}.gslide-video.fullscreen video{max-width:100%!important;width:100%!important}.gslide-inline{background:#fff;text-align:left;max-height:calc(100vh - 40px);overflow:auto;max-width:100%;margin:auto}.gslide-inline .ginlined-content{padding:20px;width:100%}.gslide-inline .dragging{cursor:-webkit-grabbing!important;cursor:grabbing!important;-webkit-transition:none;transition:none}.ginlined-content{overflow:auto;display:block!important;opacity:1}.gslide-external{display:-webkit-box;display:-ms-flexbox;display:flex;width:100%;min-width:100%;background:#fff;padding:0;overflow:auto;max-height:75vh;height:100%}.gslide-media{display:-webkit-box;display:-ms-flexbox;display:flex;width:auto}.zoomed .gslide-media{-webkit-box-shadow:none!important;box-shadow:none!important}.desc-bottom .gslide-media,.desc-top .gslide-media{margin:0 auto;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.gslide-description{position:relative;-webkit-box-flex:1;-ms-flex:1 0 100%;flex:1 0 100%}.gslide-description.description-left,.gslide-description.description-right{max-width:100%}.gslide-description.description-bottom,.gslide-description.description-top{margin:0 auto;width:100%}.gslide-description p{margin-bottom:12px}.gslide-description p:last-child{margin-bottom:0}.zoomed .gslide-description{display:none}.glightbox-button-hidden{display:none}.glightbox-mobile .glightbox-container .gslide-description{height:auto!important;width:100%;position:absolute;bottom:0;padding:19px 11px;max-width:100vw!important;-webkit-box-ordinal-group:3!important;-ms-flex-order:2!important;order:2!important;max-height:78vh;overflow:auto!important;background:-webkit-gradient(linear,left top,left bottom,from(rgba(0,0,0,0)),to(rgba(0,0,0,.75)));background:linear-gradient(to bottom,rgba(0,0,0,0) 0,rgba(0,0,0,.75) 100%);-webkit-transition:opacity .3s linear;transition:opacity .3s linear;padding-bottom:50px}.glightbox-mobile .glightbox-container .gslide-title{color:#fff;font-size:1em}.glightbox-mobile .glightbox-container .gslide-desc{color:#a1a1a1}.glightbox-mobile .glightbox-container .gslide-desc a{color:#fff;font-weight:700}.glightbox-mobile .glightbox-container .gslide-desc *{color:inherit}.glightbox-mobile .glightbox-container .gslide-desc .desc-more{color:#fff;opacity:.4}.gdesc-open .gslide-media{-webkit-transition:opacity .5s ease;transition:opacity .5s ease;opacity:.4}.gdesc-open .gdesc-inner{padding-bottom:30px}.gdesc-closed .gslide-media{-webkit-transition:opacity .5s ease;transition:opacity .5s ease;opacity:1}.greset{-webkit-transition:all .3s ease;transition:all .3s ease}.gabsolute{position:absolute}.grelative{position:relative}.glightbox-desc{display:none!important}.glightbox-open{overflow:hidden}.gloader{height:25px;width:25px;-webkit-animation:lightboxLoader .8s infinite linear;animation:lightboxLoader .8s infinite linear;border:2px solid #fff;border-right-color:transparent;border-radius:50%;position:absolute;display:block;z-index:9999;left:0;right:0;margin:0 auto;top:47%}.goverlay{width:100%;height:calc(100vh + 1px);position:fixed;top:-1px;left:0;background:#000;will-change:opacity}.glightbox-mobile .goverlay{background:#000}.gclose,.gnext,.gprev{z-index:99999;cursor:pointer;width:26px;height:44px;border:none;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.gclose svg,.gnext svg,.gprev svg{display:block;width:25px;height:auto;margin:0;padding:0}.gclose.disabled,.gnext.disabled,.gprev.disabled{opacity:.1}.gclose .garrow,.gnext .garrow,.gprev .garrow{stroke:#fff}.gbtn.focused{outline:2px solid #0f3d81}iframe.wait-autoplay{opacity:0}.glightbox-closing .gclose,.glightbox-closing .gnext,.glightbox-closing .gprev{opacity:0!important}.glightbox-clean .gslide-description{background:#fff}.glightbox-clean .gdesc-inner{padding:22px 20px}.glightbox-clean .gslide-title{font-size:1em;font-weight:400;font-family:arial;color:#000;margin-bottom:19px;line-height:1.4em}.glightbox-clean .gslide-desc{font-size:.86em;margin-bottom:0;font-family:arial;line-height:1.4em}.glightbox-clean .gslide-video{background:#000}.glightbox-clean .gclose,.glightbox-clean .gnext,.glightbox-clean .gprev{background-color:rgba(0,0,0,.75);border-radius:4px}.glightbox-clean .gclose path,.glightbox-clean .gnext path,.glightbox-clean .gprev path{fill:#fff}.glightbox-clean .gprev{position:absolute;top:-100%;left:30px;width:40px;height:50px}.glightbox-clean .gnext{position:absolute;top:-100%;right:30px;width:40px;height:50px}.glightbox-clean .gclose{width:35px;height:35px;top:15px;right:10px;position:absolute}.glightbox-clean .gclose svg{width:18px;height:auto}.glightbox-clean .gclose:hover{opacity:1}.gfadeIn{-webkit-animation:gfadeIn .5s ease;animation:gfadeIn .5s ease}.gfadeOut{-webkit-animation:gfadeOut .5s ease;animation:gfadeOut .5s ease}.gslideOutLeft{-webkit-animation:gslideOutLeft .3s ease;animation:gslideOutLeft .3s ease}.gslideInLeft{-webkit-animation:gslideInLeft .3s ease;animation:gslideInLeft .3s ease}.gslideOutRight{-webkit-animation:gslideOutRight .3s ease;animation:gslideOutRight .3s ease}.gslideInRight{-webkit-animation:gslideInRight .3s ease;animation:gslideInRight .3s ease}.gzoomIn{-webkit-animation:gzoomIn .5s ease;animation:gzoomIn .5s ease}.gzoomOut{-webkit-animation:gzoomOut .5s ease;animation:gzoomOut .5s ease}@-webkit-keyframes lightboxLoader{0%{-webkit-transform:rotate(0);transform:rotate(0)}100%{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes lightboxLoader{0%{-webkit-transform:rotate(0);transform:rotate(0)}100%{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@-webkit-keyframes gfadeIn{from{opacity:0}to{opacity:1}}@keyframes gfadeIn{from{opacity:0}to{opacity:1}}@-webkit-keyframes gfadeOut{from{opacity:1}to{opacity:0}}@keyframes gfadeOut{from{opacity:1}to{opacity:0}}@-webkit-keyframes gslideInLeft{from{opacity:0;-webkit-transform:translate3d(-60%,0,0);transform:translate3d(-60%,0,0)}to{visibility:visible;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);opacity:1}}@keyframes gslideInLeft{from{opacity:0;-webkit-transform:translate3d(-60%,0,0);transform:translate3d(-60%,0,0)}to{visibility:visible;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);opacity:1}}@-webkit-keyframes gslideOutLeft{from{opacity:1;visibility:visible;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{-webkit-transform:translate3d(-60%,0,0);transform:translate3d(-60%,0,0);opacity:0;visibility:hidden}}@keyframes gslideOutLeft{from{opacity:1;visibility:visible;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{-webkit-transform:translate3d(-60%,0,0);transform:translate3d(-60%,0,0);opacity:0;visibility:hidden}}@-webkit-keyframes gslideInRight{from{opacity:0;visibility:visible;-webkit-transform:translate3d(60%,0,0);transform:translate3d(60%,0,0)}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);opacity:1}}@keyframes gslideInRight{from{opacity:0;visibility:visible;-webkit-transform:translate3d(60%,0,0);transform:translate3d(60%,0,0)}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);opacity:1}}@-webkit-keyframes gslideOutRight{from{opacity:1;visibility:visible;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{-webkit-transform:translate3d(60%,0,0);transform:translate3d(60%,0,0);opacity:0}}@keyframes gslideOutRight{from{opacity:1;visibility:visible;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{-webkit-transform:translate3d(60%,0,0);transform:translate3d(60%,0,0);opacity:0}}@-webkit-keyframes gzoomIn{from{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}to{opacity:1}}@keyframes gzoomIn{from{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}to{opacity:1}}@-webkit-keyframes gzoomOut{from{opacity:1}50%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}to{opacity:0}}@keyframes gzoomOut{from{opacity:1}50%{opacity:0;-webkit-transform:scale3d(.3,.3,.3);transform:scale3d(.3,.3,.3)}to{opacity:0}}@media (min-width:769px){.glightbox-container .ginner-container{width:auto;height:auto;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.glightbox-container .ginner-container.desc-top .gslide-description{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.glightbox-container .ginner-container.desc-top .gslide-image,.glightbox-container .ginner-container.desc-top .gslide-image img{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.glightbox-container .ginner-container.desc-left .gslide-description{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.glightbox-container .ginner-container.desc-left .gslide-image{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.gslide-image img{max-height:97vh;max-width:100%}.gslide-image img.zoomable{cursor:-webkit-zoom-in;cursor:zoom-in}.zoomed .gslide-image img.zoomable{cursor:-webkit-grab;cursor:grab}.gslide-inline{max-height:95vh}.gslide-external{max-height:100vh}.gslide-description.description-left,.gslide-description.description-right{max-width:275px}.glightbox-open{height:auto}.goverlay{background:rgba(0,0,0,.92)}.glightbox-clean .gslide-media{-webkit-box-shadow:1px 2px 9px 0 rgba(0,0,0,.65);box-shadow:1px 2px 9px 0 rgba(0,0,0,.65)}.glightbox-clean .description-left .gdesc-inner,.glightbox-clean .description-right .gdesc-inner{position:absolute;height:100%;overflow-y:auto}.glightbox-clean .gclose,.glightbox-clean .gnext,.glightbox-clean .gprev{background-color:rgba(0,0,0,.32)}.glightbox-clean .gclose:hover,.glightbox-clean .gnext:hover,.glightbox-clean .gprev:hover{background-color:rgba(0,0,0,.7)}.glightbox-clean .gprev{top:45%}.glightbox-clean .gnext{top:45%}}@media (min-width:992px){.glightbox-clean .gclose{opacity:.7;right:20px}}@media screen and (max-height:420px){.goverlay{background:#000}}
/* 1. DER WRAPPER (Fixiert am Bildschirmrand) */
.oag-acc-wrapper {
    position: fixed;
    bottom: 20px;
    z-index: 999999;
    --panel-w: 300px; /* Breite des Menüs */
}

/* Positionierung über Backend-Auswahl */
.oag-acc-wrapper.is-right { right: 20px; left: auto; }
.oag-acc-wrapper.is-left { left: 20px; right: auto; }

/* 2. DER TRIGGER (Rollstuhl-Button) */
.oag-acc-trigger {
    width: 56px;
    height: 56px;
    background: var(--oag-acc-btn);
    color: #fff;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 4px 15px rgba(0,0,0,0.3);
    font-size: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s ease;
}
.oag-acc-trigger:hover { transform: scale(1.1); }

/* 3. DAS PANEL (Absolut zum Wrapper -> klebt am Button) */
.oag-acc-panel {
    position: absolute; 
    bottom: 75px; /* Sitzt genau über dem Button */
    width: var(--panel-w);
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.2);
    border: 1px solid #ddd;
    overflow: hidden;
    color: #333;
}

/* Panel-Ausrichtung: Bündig mit dem Button-Rand */
.oag-acc-wrapper.is-right .oag-acc-panel { right: 0; }
.oag-acc-wrapper.is-left .oag-acc-panel { left: 0; }

/* 4. HEADER & BRANDING */
.oag-acc-header {
    background: #f8f8f8;
    padding: 12px 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #eee;
}
.oag-acc-logo img {
    max-height: 25px;
    width: auto;
    display: block;
}
.oag-acc-title { font-weight: 800; font-size: 13px; color: var(--oag-acc-btn); text-transform: uppercase; }
.oag-acc-close { background: none; border: none; font-size: 22px; cursor: pointer; color: #999; }

/* 5. GRID & FUNKTIONS-BUTTONS */
.oag-acc-body { padding: 15px; }
.oag-acc-desc { font-size: 12px; margin-bottom: 12px; color: #666; line-height: 1.4; }
.oag-acc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 15px; }

.oag-acc-grid button {
    padding: 12px 5px;
    background: #fff;
    border: 1px solid #eee;
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    transition: all 0.2s ease;
}
.oag-acc-grid button:hover { border-color: var(--oag-acc-accent); background: #fcfcfc; }
.oag-acc-grid .btn-icon { font-size: 20px; }
.oag-acc-grid .btn-label { font-size: 11px; font-weight: 600; }

/* 6. RESET & FOOTER */
.oag-acc-reset {
    width: 100%;
    padding: 10px;
    border: none;
    border-radius: 6px;
    background: #eee;
    font-weight: bold;
    cursor: pointer;
    font-size: 12px;
    transition: background 0.2s;
}
.oag-acc-reset:hover { background: #ddd; }

.oag-acc-footer { 
    margin-top: 15px;
    padding: 10px; 
    font-size: 9px; 
    text-align: center; 
    background: #fafafa; 
    color: #bbb; 
    border-top: 1px solid #eee; 
}

/* 7. GLOBALE FILTER (Am HTML-Tag) */
html.acc-contrast { filter: contrast(1.8) brightness(1.1) !important; }
html.acc-grayscale { filter: grayscale(1) !important; }
html.acc-invert { filter: invert(1) hue-rotate(180deg) !important; }
html.acc-invert img, html.acc-invert video, html.acc-invert .oag-acc-wrapper { filter: invert(1) hue-rotate(180deg) !important; }
html.acc-fontsize { font-size: 125% !important; }
html.acc-underline a { text-decoration: underline !important; font-weight: bold !important; }

/* Mobil-Anpassung */
@media (max-width: 400px) {
    .oag-acc-wrapper { --panel-w: 280px; }
}

/* --- BASIS & VARIABLEN --- */

:root {
    --nav-bg-dark:  #ffffff; 
    --accent-color: #ddd;
    --text-white: #ffffff;
    --text-dark: #333333;
    
}






/* Versteckte Elemente */
.invisible {
    position: absolute;
    left: -100000px;
}

/* Container-Fix: Erlaubt das "Herausfallen" der Dropdowns */
.nav-main-container {
    position: relative;
    z-index: 1000;
    overflow: visible !important;
    background-color: var(--nav-bg-dark); /* Einheitlicher Hintergrund fï¿½r den Header */
    padding: 0 20px;
}

/* --- DESKTOP NAVIGATION (LEVEL 1) --- */
.mod_navigation.nav-main {
    display: flex;
    z-index: 1000;

    background: none;
}

.mod_navigation.nav-main ul.level_1 {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: row;
    align-items: center;
}

.mod_navigation.nav-main ul.level_1 > li {
    position: relative;
    margin: 0 15px; /* Gleichmï¿½ï¿½ige Abstï¿½nde zwischen den Hauptpunkten */
}

.mod_navigation.nav-main a, 
.mod_navigation.nav-main strong {
    text-decoration: none;
    color: var(--text-dark);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.85rem;
    letter-spacing: 1px;
    padding: 20px 0; /* Vergrï¿½ï¿½ert die Klickflï¿½che vertikal */
    display: inline-block;
    transition: all 0.3s ease;
}

/* Hover-Effekt Hauptmenï¿½ */
.mod_navigation.nav-main ul.level_1 > li:hover > a,
.mod_navigation.nav-main ul.level_1 > li:hover > strong {
    color: #333333);
}

/* Der schicke Unterstrich-Effekt */
.mod_navigation.nav-main ul.level_1 > li > a::after {
    content: '';
    position: absolute;
    width: 0;
    height: 2px;
    bottom: 15px;
    left: 0;
    background-color: var(--accent-color);
    transition: width 0.3s ease;
}

.mod_navigation.nav-main ul.level_1 > li:hover > a::after {
    width: 100%;
}

/* --- DROPDOWN (LEVEL 2) --- */
.mod_navigation.nav-main ul.level_2 {
    position: absolute;
    top: 100%; /* Dockt direkt unten am Header an */
    left: -15px;
    width: 240px;
    background: #ffffff;
    box-shadow: 0 10px 30px rgba(0,0,0,0.15);
    border-radius: 0 0 4px 4px; /* Sanfte Abrundung unten */
    display: flex;
    flex-direction: column;
    padding: 10px 0;
    list-style: none;
    
    /* Animation */
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 1100;
}

.mod_navigation.nav-main li:hover > ul.level_2 {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.mod_navigation.nav-main ul.level_2 li {
    width: 100%;
    margin: 0;
}

.mod_navigation.nav-main ul.level_2 a,
.mod_navigation.nav-main ul.level_2 strong {
    padding: 12px 25px;
    display: block;
    width: 100%;
    text-transform: none;
    font-size: 0.9rem;
    color: var(--text-dark);
    font-weight: 500;
    letter-spacing: 0;
}


.mod_sitemap ul {
    margin: 0;
    padding: 0;
    width: 100%;
    list-style: none
}

.mod_sitemap ul ul {
    padding-inline-start:1.5rem;border-left: 0.0625rem dotted #98a4ae
}

.mod_sitemap li {
    display: flex;
    flex-wrap: wrap
}

.mod_sitemap a {
    position: relative;
    display: flex;
    padding-inline-start:1.5rem}

.mod_sitemap a:before {
    position: absolute;
    top: 0;
    left: 0;
    width: 1rem;
    height: 100%;
    border-left: 0.0625rem dotted #98a4ae;
    border-bottom: 0.0625rem dotted #98a4ae;
    content: ""
}

.mod_sitemap .level_1>li:first-child a:before {
    border-left: transparent
}


/* Hover im Dropdown */
.mod_navigation.nav-main ul.level_2 a:hover {
    background: #f8fcf0; /* Ganz helles Grï¿½n */
    color: #2d5a27; /* Dunkleres Waldgrï¿½n fï¿½r Kontrast */
    padding-left: 30px; /* Kleiner Slide-Effekt */
}

/* ############ SIDEBAR ################## */
.nav-sidebar {
    background-color: #ffffff;
    border: 1px solid #eeeeee;
    border-radius: 4px;
    overflow: hidden;
}

.nav-sidebar ul { list-style: none; margin: 0; padding: 0; }

.nav-sidebar li a, 
.nav-sidebar li strong {
    display: block;
    padding: 14px 20px;
    color: var(--text-dark);
    text-decoration: none;
    font-size: 15px;
    border-bottom: 1px solid #f5f5f5;
    transition: all 0.2s ease;
}

.nav-sidebar li a:hover {
    background-color: #f9f9f9;
    padding-left: 25px;
    color: #2d5a27;
}

.nav-sidebar li strong.active {
    background-color: var(--nav-bg-dark);
    color: #000000;
    border-bottom: 1px solid var(--nav-bg-dark);
}

/* Sidebar Submenï¿½ (Level 2) */
.nav-sidebar ul.level_2 {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    background-color: #fafafa;
    transition: all 0.4s ease-in-out;
}

.nav-sidebar li.submenu:hover > ul.level_2,
.nav-sidebar li.submenu.trail > ul.level_2 {
    max-height: 600px;
    opacity: 1;
    padding-bottom: 10px;
}

.nav-sidebar ul.level_2 li a {
    padding: 10px 20px 10px 35px;
    font-size: 14px;
    color: #666;
    border-bottom: none;
}

/* --- MOBILE OPTIMIERUNG --- */
@media (max-width: 767px) {
    .menu-toggle { 
        display: block; 
        position: fixed; 
        top: 15px; 
        right: 15px; 
        z-index: 2000;
    }
    
    .hamburger, .hamburger::before, .hamburger::after {
        content: '';
        display: block;
        background: #ffffff;
        height: 3px;
        width: 28px;
        transition: all 0.3s;
    }
    .hamburger::before { transform: translateY(-8px); }
    .hamburger::after { transform: translateY(5px); }
    
    .mod_navigation.nav-main {
        position: fixed;
        top: 0;
        right: 0;
        width: 80%; /* Etwas schmaler fï¿½r moderneren Look */
        height: 100vh;
        background: var(--nav-bg-dark);
        padding: 80px 30px;
        transform: translateX(100%);
        transition: transform 0.4s ease;
        display: block;
    }

    .menu-is-open .mod_navigation.nav-main { transform: translateX(0); }

    .mod_navigation.nav-main ul.level_1 { flex-direction: column; align-items: flex-start; }

    .mod_navigation.nav-main ul.level_2 {
        position: static;
        opacity: 1;
        visibility: visible;
        transform: none;
        box-shadow: none;
        background: transparent;
        border-left: 2px solid var(--accent-color);
        margin: 10px 0 20px 10px;
    }
    
    .mod_navigation.nav-main ul.level_2 a {
        color: rgba(255,255,255,0.8);
        padding: 8px 15px;
    }
}

/* CONTAO LAYOUT CSS 
   Optimiert fÃ¼r: Header, Left, Main, Right, Footer + 100px Sidebar 
*/

:root {
    --kwg-sb-w: 100px;
    --kwg-nav-w: 400px;
    --kwg-accent: #0044ff;
    --kwg-ease: cubic-bezier(0.16, 1, 0.3, 1);
}

/* 1. Basis-Verschiebung fÃ¼r das gesamte Contao-Grid */
body {
    margin: 0;
    padding: 0;
}

#wrapper {
    margin-left: var(--kwg-sb-w); /* Platz fÃ¼r die Sidebar */
    width: calc(100% - var(--kwg-sb-w));
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    
}

/* 2. Header & Footer (Volle Breite des verbleibenden Platzes) */
#header, #footer {
    width: 100%;
    flex-shrink: 0;
   
}

/* 3. Der Container (UmschlieÃŸt Left, Main, Right) */
#container {
    display: flex;
    flex: 1; /* FÃ¼llt den vertikalen Raum zwischen Header und Footer */
}

#main {
    flex: 1; /* Main nimmt den restlichen Platz ein */
    padding: 20px;
}

#left, #right {
    width: 200px; /* Deine gewÃ¼nschte Breite fÃ¼r Seitenspalten */
    flex-shrink: 0;
}



/* ==============================================================
   1. VARIABLEN & RESET
   ============================================================== */
:root {
   

    /* Fluid Typo & Maße */
  /*  --font-size-base:   clamp(0.1rem, 0.7rem + 0.5vw, 1.0rem); */
    --header-height:    80px;
    --max-width:        1400px;
    --sidebar-width:    280px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
   font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-size: 0.9em;
    line-height: 1.6;
    overflow-x: hidden;
    background: #f8f9fa;
    color: #000000;
   
}

h1 {
            font-size: 2.5em;
            text-align: center;
            margin-bottom: 10px;
    }


/* ==============================================================
   2. LAYOUT STRUKTUR
   ============================================================== */
#wrapper {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

#container {
    display: grid;
    grid-template-columns: auto 1fr auto;
    flex: 1;
    width: 100%;
}

#main { grid-column: 2; padding: 120px 0 40px 0; } /* Padding oben für Fixierte Pille */

.inside {
    max-width: var(--max-width);
    margin: 0 auto;
    width: 100%;
    padding: 0 20px;
}


/* --- Full-Width Utility --- */
#main .inside.full-width {
    max-width: 100% !important;
    padding: 0 !important;
}


#header{
 position: fixed;
    top: 0px; /* Schwebend */
    left: 0;
    width: 100%;
    display: flex;
    justify-content: center;
     min-height: 100px;
    z-index: 2000;
    background: #ffffff;
}
/* ==============================================================
   3. NAVIGATION (DIE MENÜPILLE)
   ============================================================== */
.nav-wrapper {
    position: fixed;
    top: 10px; /* Schwebend */
    left: 0;
    width: 100%;
    display: flex;
    justify-content: center;
     

  
}

.menu-pille {
    border: 4px solid rgba(255, 255, 255, 0.2);
    padding: 10px 10px;
    border-radius: 20px;
    display: flex;
    align-items: center;
    gap: 20px;
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
    
}

.reg-logo .text {
    font-size: 1.6rem;
    font-weight: 900;
    letter-spacing: 2px;
    color: var(--white);
}

.nav-main-container ul {
    display: flex;
    list-style: none;
    gap: 25px;
}

.nav-main-container a, 
.nav-main-container strong {
    text-decoration: none;
    color: var(--white);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 0.85rem;
    transition: color 0.3s;
}

.nav-main-container a:hover { color: var(--reg-cyan); }

.nav-cta-btn {
    background: var(--reg-cyan);
    color: #000000 !important;
    padding: 8px 20px;
    border-radius: 20px;
    font-weight: 600;
    text-transform: uppercase;
    text-decoration: none;
    font-size: 0.9rem;
    transition: transform 0.4s;
}

.nav-cta-btn:hover { transform: scale(1.05); }

/* ==============================================================
   4. ARTIKEL GRID (KWG)
   ============================================================== */
/* Korrektur: Wir sprechen das innere Div von Contao an */
.kwg .mod_article__inner {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px;
    padding: 50px 0;
}

.kwg .mod_article__inner {
    display: grid;
    /* Erzeugt Spalten, die min. 300px und max. 500px groß sind */
    grid-template-columns: repeat(3, minmax(300px, 500px)); 
    gap: 30px;
    padding: 50px 0;
    justify-content: center; /* Zentriert die Karten, wenn Platz übrig ist */
}

/* ==============================================================
   5. DIE "GEILEN" BOXEN (CARDREG & BP-KLASSEN)
   ============================================================== */
.cardreg {
    position: relative;
    overflow: hidden;
    min-height: 350px;
    padding: 40px;
    border-radius: 5px;
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    border: 8px solid rgba(255, 255, 255, 0.8);
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
}

.cardreg:hover {
   
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.3);
}

.cardreg h2 {
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--reg-cyan);
    margin-bottom: 15px;
    text-transform: uppercase;
}

/* BP-1: Sonnig & Gepunktet */
.bp-1 { background: linear-gradient(135deg, rgba(149, 212, 116, 0.4) 0%, rgba(255, 255, 255, 0.1) 100%); }
.bp-1::before {
    content: ''; position: absolute; inset: 0; z-index: -1;
    background-image: radial-gradient(rgba(255, 255, 255, 0.2) 1px, transparent 1px);
    background-size: 20px 20px;
}

/* BP-2: Tech-Stripe */
.bp-2 { background: rgba(45, 110, 58, 0.3); border-left: 6px solid var(--reg-cyan); }
.bp-2::before {
    content: ''; position: absolute; inset: 0; z-index: -1;
    background-image: repeating-linear-gradient(45deg, rgba(204, 255, 102, 0.03) 0px, rgba(204, 255, 102, 0.03) 1px, transparent 1px, transparent 10px);
}

/* BP-3: Glow-Effekt */
.bp-3 { background: radial-gradient(circle at top left, rgba(106, 191, 75, 0.5) 0%, rgba(30, 46, 26, 0.2) 100%); }
.bp-3::after {
    content: ''; position: absolute; bottom: -20px; right: -20px; width: 100px; height: 100px;
    background: var(--reg-cyan); filter: blur(50px); opacity: 0.3; z-index: -1;
}

/* BP-4: Deep Forest */
.bp-4 { background: rgba(30, 46, 26, 0.7); 
         border: 1px solid var(--reg-cyan);
         color: #ffffff; }
         
         
         
/* Galerie Grund-Styling */
.content-gallery {
    margin: 2rem 0;
    padding: 0;
}

/* ==============================================================
    Galerie
   ============================================================== */
.content-gallery--cols-4 ul, .content-gallery--cols-6 ul, .content-gallery--cols-8 ul {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 15px; /* Abstand zwischen den Bildern */
    list-style: none;
    padding: 0;
    margin: 0;
}

/* ==============================================================
                            Footer 
   ============================================================== */


#footer {
        background: #f5f5f5;
        color: #111;
        padding: 60px 20px 30px;
        border-top: 1px solid #e5e5e5;
    }

    .footer-container {
        max-width: 1400px;
        margin: auto;
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
        gap: 40px;
    }

    .footer-section h3 {
        font-size: 16px;
        margin-bottom: 15px;
        font-weight: 600;
        color: #000;
    }

    .footer-section p {
        font-size: 14px;
        color: #555;
        line-height: 1.6;
    }

    .footer-section ul {
        list-style: none;
        padding: 0;
        margin: 0;
    }

    .footer-section ul li {
        margin-bottom: 10px;
    }

    .footer-section ul li a {
        text-decoration: none;
        color: #666;
        font-size: 14px;
        transition: all 0.2s ease;
    }

    .footer-section ul li a:hover {
        color: #000;
        padding-left: 4px;
    }

    .socials a {
        display: inline-block;
        margin-right: 12px;
        font-size: 18px;
        color: #777;
        transition: 0.2s;
    }

    .socials a:hover {
        color: #000;
        transform: translateY(-2px);
    }

    .footer-bottom {
        text-align: center;
        margin-top: 50px;
        padding-top: 20px;
        border-top: 1px solid #ddd;
        font-size: 13px;
        color: #777;
    }

    @media (max-width: 600px) {
        footer {
            padding: 40px 15px;
        }
    }
    
    
    /* Footer end */

/* ==============================================================
   6. MOBILE ANPASSUNG
   ============================================================== */
@media (max-width: 1024px) {
    #container { grid-template-columns: 1fr; }
    .nav-wrapper { top: 0; }
    .menu-pille { border-radius: 0; width: 100%; gap: 15px; padding: 10px; }
    .nav-main-container { display: none; } /* Hamburger hier einbauen */
}

@media (max-width: 768px) {
    .kwg .mod_article__inner { grid-template-columns: 1fr; }
}
.content-accordion {
    border-bottom: 1px solid #eee
}

.handorgel__header {
    display: block;
    margin: 0
}

.handorgel__header__button {
    display: block;
    width: 100%;
    padding: 5px 5px;
    margin: 0;
    border: 0;
    border-top: 1px solid #eee;
    background-color: #fff;
    border-radius: 0;
    color: inherit;
    cursor: pointer;
    font-size: 14px;
    text-align: left;
    transition: background-color .2s ease;
    user-select: none
}

.handorgel__header__button::-moz-focus-inner {
    border: 0
}

.handorgel__content {
    display: none;
    overflow: hidden;
    height: 0;
    border: 1px solid #eee;
    background-color: #f6f6f6;
    transition: height .1s ease .1s
}

.handorgel__content--open {
    display: block;
    transition: height .2s ease
}

.handorgel__content--opened {
    overflow: visible
}

.handorgel__content__inner {
    padding: 5px 5px;
    opacity: 0;
    transition: opacity .1s ease
}

.handorgel__content--opened .handorgel__content__inner {
    opacity: 1;
    transition: opacity .3s ease
}

.handorgel .accordion {
    display: none;
    overflow: hidden;
    height: 0;
    transition: height .2s ease
}

.handorgel .accordion.open {
    display: block;
    transition: height .2s ease
}

.handorgel .accordion.active {
    overflow: visible
}

