.ct-section {
width:100%;
background-size:cover;
background-repeat:repeat;
}
.ct-section>.ct-section-inner-wrap {
display:flex;
flex-direction:column;
align-items:flex-start;
}
.ct-div-block {
display:flex;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.ct-new-columns {
display:flex;
width:100%;
flex-direction:row;
align-items:stretch;
justify-content:center;
flex-wrap:wrap;
}
.ct-link-text {
display:inline-block;
}
.ct-link {
display:flex;
flex-wrap:wrap;
text-align:center;
text-decoration:none;
flex-direction:column;
align-items:center;
justify-content:center;
}
.ct-link-button {
display:inline-block;
text-align:center;
text-decoration:none;
}
.ct-link-button {
background-color: #1e73be;
border: 1px solid #1e73be;
color: #ffffff;
padding: 10px 16px;
}
.ct-image {
max-width:100%;
}
.ct-fancy-icon>svg {
width:55px;height:55px;}
.ct-inner-content {
width:100%;
}
.ct-slide {
display:flex;
flex-wrap:wrap;
text-align:center;
flex-direction:column;
align-items:center;
justify-content:center;
}
.ct-nestable-shortcode {
display:flex;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-comments {
width:100%;
text-align:left;
}
.oxy-comment-form {
width:100%;
}
.oxy-login-form {
width:100%;
}
.oxy-search-form {
width:100%;
}
.oxy-tabs-contents {
display:flex;
width:100%;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-tab {
display:flex;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-tab-content {
display:flex;
width:100%;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-testimonial {
width:100%;
}
.oxy-icon-box {
width:100%;
}
.oxy-pricing-box {
width:100%;
}
.oxy-posts-grid {
width:100%;
}
.oxy-gallery {
width:100%;
}
.ct-slider {
width:100%;
}
.oxy-tabs {
display:flex;
flex-wrap:nowrap;
flex-direction:row;
align-items:stretch;
}
.ct-modal {
flex-direction:column;
align-items:flex-start;
}
.ct-span {
display:inline-block;
text-decoration:inherit;
}
.ct-widget {
width:100%;
}
.oxy-dynamic-list {
width:100%;
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
			.ct-div-block,
			.oxy-post-content,
			.ct-text-block,
			.ct-headline,
			.oxy-rich-text,
			.ct-link-text { max-width: 100%; }
			img { flex-shrink: 0; }
			body * { min-height: 1px; }
		}            .oxy-testimonial {
                flex-direction: row;
                align-items: center;
            }
                        .oxy-testimonial .oxy-testimonial-photo-wrap {
                order: 1;
            }
            
                        .oxy-testimonial .oxy-testimonial-photo {
                width: 125px;                height: 125px;                margin-right: 20px;
            }
            
                        .oxy-testimonial .oxy-testimonial-photo-wrap, 
            .oxy-testimonial .oxy-testimonial-author-wrap, 
            .oxy-testimonial .oxy-testimonial-content-wrap {
                align-items: flex-start;                text-align: left;            }
            
                                                            .oxy-testimonial .oxy-testimonial-text {
                margin-bottom:8px;font-size: 21px;
line-height: 1.4;
-webkit-font-smoothing: subpixel-antialiased;
            }
            
                                    .oxy-testimonial .oxy-testimonial-author {
                font-size: 18px;
-webkit-font-smoothing: subpixel-antialiased;
            }
                            

                                                .oxy-testimonial .oxy-testimonial-author-info {
                font-size: 12px;
-webkit-font-smoothing: subpixel-antialiased;
            }
            
             
            
                        .oxy-icon-box {
                text-align: left;                flex-direction: column;            }
            
                        .oxy-icon-box .oxy-icon-box-icon {
                margin-bottom: 12px;
                align-self: flex-start;            }
            
                                                                        .oxy-icon-box .oxy-icon-box-heading {
                font-size: 21px;
margin-bottom: 12px;            }
            
                                                                                    .oxy-icon-box .oxy-icon-box-text {
                font-size: 16px;
margin-bottom: 12px;align-self: flex-start;            }
            
                        .oxy-icon-box .oxy-icon-box-link {
                margin-top: 20px;                            }
            
            
            /* GLOBALS */

                                                            .oxy-pricing-box .oxy-pricing-box-section {
                padding-top: 20px;
padding-left: 20px;
padding-right: 20px;
padding-bottom: 20px;
text-align: center;            }
                        
                        .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-price {
                justify-content: center;            }
            
            /* IMAGE */
                                                                                    .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-graphic {
                justify-content: center;            }
            
            /* TITLE */
                                                            
                                    .oxy-pricing-box .oxy-pricing-box-title-title {
                font-size: 48px;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-title-subtitle {
                font-size: 24px;
            }
            

            /* PRICE */
                                                .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-price {
                                                flex-direction: row;                                            }
            
                                    .oxy-pricing-box .oxy-pricing-box-currency {
                font-size: 28px;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-amount-main {
                font-size: 80px;
line-height: 0.7;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-amount-decimal {
                font-size: 13px;
            }
                        
                                    .oxy-pricing-box .oxy-pricing-box-term {
                font-size: 16px;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-sale-price {
                font-size: 12px;
color: rgba(0,0,0,0.5);
                margin-bottom: 20px;            }
            
            /* CONTENT */

                                                                        .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-content {
                font-size: 16px;
color: rgba(0,0,0,0.5);
            }
            
            /* CTA */

                                                                        .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-cta {
                justify-content: center;            }
            
        
                                .oxy-progress-bar .oxy-progress-bar-background {
            background-color: #000000;            background-image: linear-gradient(-45deg,rgba(255,255,255,.12) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.12) 75%,transparent 75%,transparent);            animation: none 0s paused;        }
                
                .oxy-progress-bar .oxy-progress-bar-progress-wrap {
            width: 85%;        }
        
                                                        .oxy-progress-bar .oxy-progress-bar-progress {
            background-color: #66aaff;padding: 40px;animation: none 0s paused, none 0s paused;            background-image: linear-gradient(-45deg,rgba(255,255,255,.12) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.12) 75%,transparent 75%,transparent);        
        }
                
                        .oxy-progress-bar .oxy-progress-bar-overlay-text {
            font-size: 30px;
font-weight: 900;
-webkit-font-smoothing: subpixel-antialiased;
        }
        
                        .oxy-progress-bar .oxy-progress-bar-overlay-percent {
            font-size: 12px;
        }
        
        .ct-slider .unslider-nav ol li {border-color: #ffffff; }.ct-slider .unslider-nav ol li.unslider-active {background-color: #ffffff; }.ct-slider .ct-slide {
				padding: 0px;			}
		
                        .oxy-superbox .oxy-superbox-secondary, 
            .oxy-superbox .oxy-superbox-primary {
                transition-duration: 0.5s;            }
            
            
            
            
            
        
        
        
        
            .oxy-shape-divider {
                width: 0px;
                height: 0px;
                
            }
            
            .oxy_shape_divider svg {
                width: 100%;
            }
            .oxy-pro-menu .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .sub-menu{
box-shadow:px px px px ;}

.oxy-pro-menu .oxy-pro-menu-show-dropdown .oxy-pro-menu-list .menu-item-has-children > a svg{
transition-duration:0.4s;
}

.oxy-pro-menu .oxy-pro-menu-show-dropdown .oxy-pro-menu-list .menu-item-has-children > a div{
margin-left:0px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-open-icon svg{
width:30px;
height:30px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-open-icon{
padding-top:15px;
padding-right:15px;
padding-bottom:15px;
padding-left:15px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-open-icon, .oxy-pro-menu .oxy-pro-menu-mobile-open-icon svg{
transition-duration:0.4s;
}

.oxy-pro-menu .oxy-pro-menu-mobile-close-icon{
top:20px;
left:20px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-close-icon svg{
width:24px;
height:24px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-close-icon, .oxy-pro-menu .oxy-pro-menu-mobile-close-icon svg{
transition-duration:0.4s;
}

.oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-off-canvas-container, .oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-open-container{
background-color:#ffffff;
}

.oxy-pro-menu .oxy-pro-menu-off-canvas-container, .oxy-pro-menu .oxy-pro-menu-open-container{
background-image:url();
}

.oxy-pro-menu .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .menu-item-has-children > a svg, .oxy-pro-menu .oxy-pro-menu-open-container .oxy-pro-menu-list .menu-item-has-children > a svg{
font-size:24px;
}

.oxy-pro-menu .oxy-pro-menu-dropdown-links-toggle.oxy-pro-menu-open-container .menu-item-has-children ul, .oxy-pro-menu .oxy-pro-menu-dropdown-links-toggle.oxy-pro-menu-off-canvas-container .menu-item-has-children ul{
background-color:rgba(0,0,0,0.2);
border-top-style:solid;
}

.oxy-pro-menu .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .oxy-pro-menu-list{
                    flex-direction: row;
               }
.oxy-pro-menu .oxy-pro-menu-container .menu-item a{
                    text-align: left;
                    justify-content: flex-start;
                }
.oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-open-container .menu-item, .oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-off-canvas-container .menu-item{
                    align-items: flex-start;
                }

            .oxy-pro-menu .oxy-pro-menu-off-canvas-container{
                    top: 0;
                    bottom: 0;
                    right: auto;
                    left: 0;
               }
.oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-open-container .oxy-pro-menu-list .menu-item a, .oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .menu-item a{
                    text-align: left;
                    justify-content: flex-start;
                }

            .oxy-site-navigation {
--oxynav-brand-color:#4831B0;
--oxynav-neutral-color:#FFFFFF;
--oxynav-activehover-color:#EFEDF4;
--oxynav-background-color:#4831B0;
--oxynav-border-radius:0px;
--oxynav-other-spacing:8px;
--oxynav-transition-duration:0.3s;
--oxynav-transition-timing-function:cubic-bezier(.84,.05,.31,.93);
}

.oxy-site-navigation .oxy-site-navigation__mobile-close-wrapper{
text-align:left;
}

.oxy-site-navigation > ul{ left: 0; }
.oxy-site-navigation {
                        --oxynav-animation-name: none; 
                    }

                .oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(1){ 
                    background-color: var(--oxynav-brand-color);
                    transition: var(--oxynav-transition-duration);
                    margin-left: var(--oxynav-other-spacing);
                    border: none;
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2){ 
                    background: transparent;
                    border: 1px solid currentColor;
                    transition: var(--oxynav-transition-duration);
                    margin-left: var(--oxynav-other-spacing);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2):not(:hover) > img{
                    filter: invert(0) !important;
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:hover{
                    background-color: var(--oxynav-activehover-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(1) > a{
                    color: var(--oxynav-neutral-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2) > a{
                    color: var(--oxynav-brand-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:hover > a{
                    color: var(--oxynav-brand-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(1) > a::after{
                    color: var(--oxynav-neutral-color);   
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2) > a::after{
                    color: var(--oxynav-brand-color);   
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:hover > a::after{
                    color: var(--oxynav-brand-color);   
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true'] > ul{
                    display: none;
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true'] > button, .oxy-site-navigation > ul:not(.open) > li[data-cta='true'] > ul{
                    display: none;
                }

                .ct-section-inner-wrap, .oxy-header-container{
  max-width: 1120px;
}
body {font-family: 'proxima-nova';}body {line-height: 1.5;font-size: 16px;font-weight: 300;color: rgba(0,0,0,0.6);}.oxy-nav-menu-hamburger-line {background-color: rgba(0,0,0,0.6);}h1, h2, h3, h4, h5, h6 {font-family: 'proxima-nova-condensed';font-size: 36px;font-weight: 700;}h2, h3, h4, h5, h6{font-size: 30px;}h3, h4, h5, h6{font-size: 24px;}h4, h5, h6{font-size: 20px;}h5, h6{font-size: 18px;}h6{font-size: 16px;}a {color: #000000;text-decoration: none;}a:hover {text-decoration: none;}.ct-link-text {text-decoration: ;}.ct-link {text-decoration: ;}.ct-link-button {border-radius: 3px;}.ct-section-inner-wrap {
padding-top: 75px;
padding-right: 20px;
padding-bottom: 75px;
padding-left: 20px;
}.ct-new-columns > .ct-div-block {
padding-top: 20px;
padding-right: 20px;
padding-bottom: 20px;
padding-left: 20px;
}.oxy-header-container {
padding-right: 20px;
padding-left: 20px;
}@media (max-width: 992px) {
				.ct-columns-inner-wrap {
					display: block !important;
				}
				.ct-columns-inner-wrap:after {
					display: table;
					clear: both;
					content: "";
				}
				.ct-column {
					width: 100% !important;
					margin: 0 !important;
				}
				.ct-columns-inner-wrap {
					margin: 0 !important;
				}
			}
.oxel_dynamicslider {
 width:100%;
}
.swiper-container {
}
.oxel_dynamicslider__container {
 height:400px;
}
.swiper-wrapper {
}
.swiper-slide {
}
.projekte-grid {
}
.section-padding {
}
.section-padding .ct-section-inner-wrap {
padding-right: 60px;
padding-left: 60px;
}
@media (max-width: 991px) {
.section-padding {
}
.section-padding .ct-section-inner-wrap {
padding-right: 20px;
padding-left: 20px;
}
}

@media (max-width: 767px) {
.section-padding {
}
.section-padding .ct-section-inner-wrap {
padding-right: 20px;
padding-left: 20px;
}
}

.subpage-start {
}
.subpage-start .ct-section-inner-wrap {
padding-top: 100px;
}
.h-xl {
 font-family:proxima-nova-condensed;
 font-size:2.4rem;
 font-weight:200;
 line-height:1.2;
 margin-bottom:40px;
 color:#000000;
}
@media (max-width: 767px) {
.h-xl {
 font-size:2rem;
 margin-bottom:20px;
}
}

@media (max-width: 479px) {
.h-xl {
 font-size:1.8rem;
}
}

.h-l {
 font-family:proxima-nova-condensed;
 font-size:1.8rem;
 font-weight:200;
 line-height:1.4;
 margin-bottom:20px;
 color:#000000;
}
.project-info-wrap {
 width:100%;
 gap:80px;
}
.project-info-wrap:not(.ct-section):not(.oxy-easy-posts),
.project-info-wrap.oxy-easy-posts .oxy-posts,
.project-info-wrap.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
align-items:flex-start;
justify-content:space-between;
gap:80px;
}
@media (max-width: 1120px) {
.project-info-wrap {
 text-align:left;
 gap:20px;
}
.project-info-wrap:not(.ct-section):not(.oxy-easy-posts),
.project-info-wrap.oxy-easy-posts .oxy-posts,
.project-info-wrap.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:flex-start;
gap:20px;
}
}

.project-info-text {
}
.project-info--table {
 width:50%;
 margin-top:20px;
}
@media (max-width: 1120px) {
.project-info--table {
 width:100%;
}
}

.project-info--text {
 width:50%;
}
@media (max-width: 1120px) {
.project-info--text {
 width:100%;
}
}

.project-info--table-wrap {
 width:100%;
 padding-top:15px;
 padding-bottom:15px;
 border-top-color:#c8c8c8;
 border-top-width:1px;
 border-top-style:solid;
}
.project-info--table-wrap:not(.ct-section):not(.oxy-easy-posts),
.project-info--table-wrap.oxy-easy-posts .oxy-posts,
.project-info--table-wrap.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
align-items:center;
justify-content:space-between;
}
.project-info--table-label {
 font-family:'proxima-nova-condensed';
 text-transform:uppercase;
 font-size:0.9rem;
 color:#a3a3a3;
 letter-spacing:2px;
}
.project-info--table-value {
}
.grayscale:hover{
 filter:grayscale(0%);
}
.grayscale {
 filter:grayscale(100%);
 transition-duration:0.3s;
 transition-timing-function:ease;
}
.btn-primary {
 padding-top:10px;
 padding-right:20px;
 padding-bottom:10px;
 padding-left:20px;
 margin-top:30px;
 gap:10px;
 border-radius:50px;
 border-top-color:#c8c8c8;
 border-right-color:#c8c8c8;
 border-bottom-color:#c8c8c8;
 border-left-color:#c8c8c8;
 border-top-width:1px;
 border-right-width:1px;
 border-bottom-width:1px;
 border-left-width:1px;
 border-top-style:solid;
 border-right-style:solid;
 border-bottom-style:solid;
 border-left-style:solid;
width: fit-content;
}
.btn-primary:not(.ct-section):not(.oxy-easy-posts),
.btn-primary.oxy-easy-posts .oxy-posts,
.btn-primary.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
align-items:center;
gap:10px;
}
.section-border {
 border-top-color:#c8c8c8;
 border-top-width:1px;
 border-top-style:solid;
}
.content-50w {
 width:50%;
}
@media (max-width: 1120px) {
.content-50w {
 width:100%;
}
}

.footer-link:hover{
 color:#a3a3a3;
}
.footer-link {
}
.footer-divider {
}
@media (max-width: 767px) {
.footer-divider {
}
.footer-divider:not(.ct-section):not(.oxy-easy-posts),
.footer-divider.oxy-easy-posts .oxy-posts,
.footer-divider.ct-section .ct-section-inner-wrap{
display:none;
}
}

.oxy-close-modal {
}
.rechtlich {
}
.rechtlich-text {
}
.oxy-stock-content-styles {
}
:root {
  --max-menu-width: 300px;
}


@media(max-width: 1120px) {
  :root {
    --max-menu-width: 180px;
  }
}/* === Vertikale Menübasis === */
.sidebar-navigation {
  background: #fff;
  border-right: 1px solid #eee;
  padding: 2rem 1rem;
}

.main-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 60px;
}

/* === Hauptlinks === */
.main-menu > .menu-item > a {
  display: block;
  color: #000;
  text-decoration: none;
  padding: 0.1rem 0rem;
  position: relative;
  transition: all 0.25s ease;
  text-transform: uppercase;
  font-family: 'proxima-nova-condensed';
  font-size: 1rem;
  font-weight: 300;
  letter-spacing: 1px;
}

/* Aktiver Kreis */
.main-menu .current-menu-item > a::before,
.main-menu .current-menu-ancestor > a::before,
.main-menu a.active::before {
  content: "";
  position: absolute;
  left: -15px;
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  background: #000;
  border-radius: 50%;
}

/* Aktiver Link leicht eingerückt */
.main-menu .current-menu-item > a,
.main-menu .current-menu-ancestor > a,
.main-menu a.active {
  transform: translateX(15px);
}

/* === Untermenüs === */
.sub-menu {
  list-style: none;
  margin: 0.3rem 0 0.6rem 1rem;
  padding-left: 0.5rem;
  border-left: 1px solid #c8c8c8;
  display: none; 
}

.sub-menu li a {
  display: block;
  color: #000000;
  font-size: 0.8rem;
  text-decoration: none;
  padding: 0.2rem 0.3rem;
  opacity: .8;
  transition: all 0.2s ease;
}

.menu-item.open > .sub-menu {
  display: block;
}

  transition: transform 0.2s ease;
}

.menu-item.open > a::after {
  transform: translateY(-50%) rotate(90deg);
}
body {
  background: #e6e7e8;
}/* --- BASIS-STYLING --- */
.projekt-grid {
  width: 100%;
  display: grid;
  grid-gap: 1.5rem;
}

.projekt-item {
  overflow: hidden;
  position: relative;
  transition: transform 0.3s ease;
}

.projekt-item:hover .projekt-thumb img {
  filter: grayscale(0);
}

.projekt-item:hover .projekt-content {
  transform: translateY(0);
  opacity: 1;
}

.projekt-thumb {
  position: relative;
  overflow: hidden;
}

.projekt-thumb img {
  display: block;
  width: 100%;
  height: 550px;
  object-fit: cover;
  filter: grayscale(100%);
  transition: all 0.3s ease;
}

.projekt-content {
  display: flex;
  align-items: center;
  position: absolute;
  left: 40px;
  bottom: 40px;
  transition: all 0.3s ease;
  transform: translateY(100%);
  opacity: 0;
  z-index: 2;
}

.projekt-content h3 {
  font-size: 1.8rem;
  font-weight: 300;
  color: #f4f4f4;
  line-height: 1;
}

.projekt-content img {
  width: 20px;
  margin-left: 14px;
}

.projekt-overlay {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%; /* jetzt über das ganze Bild */
  background: linear-gradient(to top, rgba(0,0,0,0.7), rgba(0,0,0,0)); /* Gradient bleibt gleich */
  pointer-events: none;
  opacity: 0; /* start unsichtbar */
  transition: opacity 0.5s ease; /* Smooth einblenden */
  z-index: 1; /* unter Text */
}

/* Hover: Overlay einblenden */
.projekt-item:hover .projekt-overlay {
  opacity: 1; /* nur Opacity ändern, Gradient bleibt gleich */
}

/* Text über Overlay */
.projekt-content {
  display: flex;
  align-items: center;
  position: absolute;
  left: 40px;
  bottom: 40px;
  transition: all 0.3s ease;
  transform: translateY(100%);
  opacity: 0;
  z-index: 2; /* über Overlay */
}

.projekt-item:hover .projekt-content {
  transform: translateY(0);
  opacity: 1;
}


/* --- GRID-MUSTER --- */
@media (min-width: 1024px) {
  .projekt-grid {
    grid-template-columns: repeat(9, 1fr);
  }

  /* 1. Reihe – 40% / 60% */
  .projekt-grid > .projekt-item:nth-child(8n + 1) {
    grid-column: span 4;
  }

  .projekt-grid > .projekt-item:nth-child(8n + 2) {
    grid-column: span 6;
  }

  /* 2. Reihe – 50% / 33% */
  .projekt-grid > .projekt-item:nth-child(8n + 3) {
    grid-column: 2 / span 5;
  }

  .projekt-grid > .projekt-item:nth-child(8n + 4) {
    grid-column: 7 / span 4;
  }

  /* 3. Reihe – 3x 33% */
  .projekt-grid > .projekt-item:nth-child(8n + 5),
  .projekt-grid > .projekt-item:nth-child(8n + 6),
  .projekt-grid > .projekt-item:nth-child(8n + 7) {
    grid-column: span 3;
  }

  .projekt-grid > .projekt-item:nth-child(8n + 7) {
    margin-right: -1.5rem;
  }

  /* 4. Reihe – 33% / 50% (spiegelverkehrt zu Reihe 2) */
  .projekt-grid > .projekt-item:nth-child(8n + 8) {
    grid-column: 1 / span 4;
  }
}

/* --- Tablet & Mobile (bis 1023px): einfaches 2er-Grid --- */
@media (max-width: 1120px) {
  .projekt-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Bilder etwas kleiner halten */
  .projekt-thumb img {
    height: 350px;
  }

  .projekt-content {
    left: 20px;
    bottom: 20px;
  }

  .projekt-content h3 {
    font-size: 1.4rem;
  }

  .swiper-pagination {
    left: 20px !important;
  }
}

/* --- Kleinere Smartphones (bis 600px): bleibt 2er-Grid --- */
@media (max-width: 600px) {
  .projekt-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .projekt-thumb img {
    height: 250px;
  }

  .projekt-content h3 {
    font-size: 1.2rem;
  }

  .projekt-gallery .swiper-slide img {
    height: 300px;
  }
}
/* --- Grundlayout --- */
.site-navigation {
  position: relative;
}

.main-menu .sub-menu {
  display: none;
  margin-left: 1rem;
}

.main-menu .menu-item-has-children.open > .sub-menu {
  display: block;
}

/* --- Burger-Button --- */
.menu-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 1rem;
  z-index: 999;
}

.burger {
  display: inline-block;
  width: 24px;
  height: 2px;
  background: black;
  position: relative;
  transition: all 0.3s ease;
}

.burger::before,
.burger::after {
  content: '';
  position: absolute;
  left: 0;
  width: 24px;
  height: 2px;
  background: black;
  transition: all 0.3s ease;
}

.burger::before { top: -7px; }
.burger::after { top: 7px; }

.menu-toggle.active .burger {
  background: transparent;
}

.menu-toggle.active .burger::before {
  transform: rotate(45deg);
  top: 0;
}

.menu-toggle.active .burger::after {
  transform: rotate(-45deg);
  top: 0;
}

/* --- Mobile Ansicht --- */
@media (max-width: 992px) {  
  .main-menu {
    margin-top: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }
  
  .menu-toggle {
    display: block;
  }

  .main-menu {
    display: none;
    position: absolute;
    top: 100%;
    right: 0;
    flex-direction: column;
    background: #e6e7e8;
    padding: 1rem;
    min-width: 240px;
  }

  .main-menu.open {
    display: flex;
    animation: fadeIn 0.3s ease;
  }

  @keyframes fadeIn {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
  }
}
/* =========================================================
   MAGAZINE SLIDER
   ========================================================= */

.magazine-slider-wrapper {
  position: relative;
  width: 100%;
  overflow: hidden;
}

/* --- Grundstruktur --- */
.magazine-slide {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-right: 1px solid #c8c8c8;
}

.magazine-content {
  display: flex;
  flex-direction: column;
  padding-right: 50px;
}

.magazine-image img {
  width: 100%;
  height: 600px;
  object-fit: cover;
  display: block;
  margin-bottom: 20px;
}

/* --- Textaufbau --- */
.magazine-text {
  display: flex;
  flex-direction: row;
  gap: 1rem;
}

.magazine-header {
  width: 50%;
}

.magazine-title {
  font-weight: 300;
}

.magazine-info {
  width: 50%;
}

/* --- Animation der Textelemente --- */
.magazine-info .btn-primary,
.magazine-title,
.magazine-date,
.magazine-desc {
  opacity: 0;
  transition: all 0.3s ease;
}

.swiper-slide-active .magazine-title,
.swiper-slide-active .magazine-date,
.swiper-slide-active .magazine-desc,
.swiper-slide-active .magazine-info .btn-primary {
  opacity: 1;
}

/* =========================================================
   NAVIGATION
   ========================================================= */

.magazine-button-group {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 50px;
  position: absolute;
  bottom: 15px;
  left: 0;
}

.magazine-button-prev,
.magazine-button-next {
  width: 16px;
  height: 16px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  cursor: pointer;
  transition: opacity 0.3s;
  z-index: 10;
}

.magazine-button-prev {
  background-image: url('/app/uploads/2025/11/swiper-arrow-left.png');
}

.magazine-button-next {
  background-image: url('/app/uploads/2025/11/swiper-arrow-right.png');
}

.magazine-button-prev:hover,
.magazine-button-next:hover {
  opacity: 0.7;
}

/* =========================================================
   PAGINATION
   ========================================================= */

.magazine-pagination {
  font-family: 'proxima-nova-condensed';
  position: absolute;
  bottom: 40px;
  right: 20px;
  color: #a3a3a3;
  font-weight: 200;
  font-size: 3rem;
}

.pagination-current {
  color: #000000;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */

@media(max-width: 768px) {
  .magazine-content {
    padding-bottom: 150px;
    padding-right: 20px;
  }

  .magazine-text {
    flex-direction: column;
  }

  .magazine-header,
  .magazine-info {
    width: 100%;
  }

  .magazine-image img {
    height: 300px;
  }

  .magazine-slide {
    border-right: 0;
  }
}
.ff-default .ff-el-form-control {
  background: transparent !important;
  border-radius: 0 !important;
  border: 0 !important;
  border-bottom: 1px solid #a3a3a3 !important;
  font-family: "proxima-nova-condensed" !important;
  letter-spacing: 1px !important;
  padding: 8px 2px !important;
}

.ff-default .ff_btn_style {
  background: transparent !important;
  color: #000000 !important;
  padding: 6px 20px !important;
  border-radius: 50px !important;
  border: 1px solid #a3a3a3 !important;
  width: fit-content !important;
  font-family: "proxima-nova-condensed" !important;
  font-weight: 200 !important;
  font-size: 1rem !important;
}/* =========================================================
   PROJEKT GALLERY SLIDER
   ========================================================= */

.projekt-gallery {
  width: 100%;
  margin: 0 auto;
  position: relative;
}

/* --- Swiper Slides --- */
.projekt-gallery .swiper-slide {
  position: relative;
  overflow: hidden;
}

/* --- Bildcontainer mit Blur-Hintergrund --- */
.projekt-gallery-image-wrapper {
  position: relative;
  width: 100%;
  height: 1000px;
  overflow: hidden;
}

/* --- Hintergrundbild (Blur-Effekt) --- */
.projekt-gallery-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: blur(20px);
  transform: scale(1.1);
  z-index: 1;
  transition: transform 0.5s ease, filter 0.5s ease;
}

/* --- Hauptbild im Vordergrund --- */
.projekt-gallery-image-wrapper img {
  position: relative;
  z-index: 2;
  display: block;
  height: 100%;
  width: auto;
  margin: 0 auto;
  object-fit: contain; /* Hochformatbilder bleiben komplett sichtbar */
  transition: transform 0.5s ease;
}

/* --- Hover-Effekt: sanfter Zoom --- */
.swiper-slide-active .projekt-gallery-image-wrapper img:hover {
  transform: scale(1.03);
}

/* --- Pagination unten links --- */
.projekt-gallery .swiper-pagination {
  width: auto !important;
  left: 60px !important;
  bottom: 0 !important;
  padding: 6px 12px;
  background: #e6e7e8;
}

.projekt-gallery .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  background: #000000;
  opacity: 0.1;
  border-radius: 0 !important;
  transition: all 0.3s ease;
}

.projekt-gallery .swiper-pagination-bullet-active {
  width: 42px;
  background: #000000;
  opacity: 1;
}


/* =========================================================
   RESPONSIVE STYLES
   ========================================================= */

@media (max-width: 1024px) {
  .projekt-gallery-image-wrapper {
    height: 400px;
  }

  .projekt-gallery .swiper-pagination {
    left: 30px !important;
  }
}

@media (max-width: 768px) {
  .projekt-gallery-image-wrapper {
    height: 350px;
  }

  .projekt-gallery .swiper-pagination {
    left: 20px !important;
  }
}

@media (max-width: 600px) {
  .projekt-gallery-image-wrapper {
    height: 300px;
  }

  .projekt-gallery-bg {
    filter: blur(15px);
  }

  .projekt-gallery .swiper-pagination {
    left: 15px !important;
  }
}
