/*
 Theme Name:   GeneratePress Child
 Theme URI:    https://generatepress.com
 Description:  Default GeneratePress child theme
 Author:       Tom Usborne
 Author URI:   https://tomusborne.com
 Template:     generatepress
 Version:      0.1
*/

.highlight-scroll-section { min-height: 0vh; padding: 0vh 6vw; }
    .highlight-text { font-size: 36px; line-height: 1.7; color: #ccc; font-family: inherit; text-align: center; font-weight: 500; }
    .highlight-text .line { display: block; }
    @media (max-width: 768px) { .highlight-text { font-size: 28px; line-height: 1.0; } }
    @media (max-width: 480px) { .highlight-text { font-size: 24px; line-height: 1.7; } }

article img {padding-bottom: 30px; max-width: 800px;height: auto; }
.main-container { width: 100%; background: #0e181e; padding: 170px 0; } 
.inner-container { max-width: 1430px; margin: 0 auto; display: flex; flex-wrap: wrap; } 
.left-box { width: 60%; padding-right: 20px; box-sizing: border-box; } 
.right-box { width: 40%; display: flex; flex-direction: column; align-items: flex-start; } 
.main-container h1 { font-size: 80px; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; color: #fff; margin-top: 0; } 
.right-text { font-size:23px; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; color: #fff; margin-bottom: 40px; } 
.button { background: #ccc; color: #fff; text-decoration: none; padding: 10px 20px; border-radius: 35px; display: inline-flex; align-items: center; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; } 
.button::after { content: '⟶'; margin-left: 10px; } 
@media (max-width: 1024px) {.main-container h1 { font-size: 60px; }.right-text { margin-bottom: 30px; }.main-container {padding: 100px 25px 25px;} .gb-button { padding: 8px 16px; font-size: 16px; width: 100%; justify-content: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .gb-icon { display: none; }} 
@media (max-width: 768px) { .inner-container { flex-direction: column; } .left-box, .right-box { width: 100%; padding-right: 0; } .main-container h1 { font-size: 38px; margin-bottom: 20px; } .right-text { margin-bottom: 20px; } .button { padding: 12px 24px; font-size: 16px; }.main-container {padding-left:20px; padding-right:20px;padding-bottom:10px;} } 

.main-container-unter { width: 100%; background: #0e181e; padding: 180px 0 80px; box-sizing: border-box; overflow: visible; }
.inner-container-unter { max-width: 1430px; margin: 0 auto; display: flex; flex-wrap: wrap; padding: 0 20px; position: relative; }
.left-box-unter { width: 50%; padding-right: 40px; box-sizing: border-box; }
.right-box-unter { width: 50%; display: flex; flex-direction: column; align-items: flex-start; }
.main-container-unter h1 { font-size: 48px; font-weight: 400; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; color: #fff; margin-top: 0; margin-bottom: 20px; }
.hero-image-unter { width: 100%; height: auto; border-radius: 20px 20px 0 0; margin-top: 40px; object-fit: cover; }
.hero-image-container { position: relative; width: 100%; padding-bottom: 50%; }
.hero-image-container img { position: absolute; top: 0; left: 0; width: 100%; height: 150%; object-fit: cover; border-radius: 20px 20px 0 0; }
.right-text-unter { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; color: #fff; margin-bottom: 40px; font-size: 23px; line-height: 1.6;}
.gb-button { background: #ccc; color: #fff; text-decoration: none; padding: 10px 20px; border-radius: 35px; display: inline-flex; align-items: center; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; transition: background-color 0.3s ease; }
.gb-button { background-color: #aaa; }
.gb-icon { margin-left: 10px; }
@media (max-width: 1024px) { .left-box-unter { width: 40%; padding-right: 20px; } .right-box-unter { width: 60%; } .main-container-unter h1 { font-size: 40px; } .hero-image-container { padding-bottom: 75%; } .hero-image-container img { height: 100%; border-radius: 20px 20px 0 0; } }
@media (max-width: 768px) { .inner-container-unter { flex-direction: column; width: 100%; } .left-box-unter { width: 100%; padding-right: 0; } .right-box-unter { width: 100%; margin-bottom: 20px; } .main-container-unter h1 { font-size: 36px; } .hero-image-unter { margin-top: 0px; } .right-text-unter { margin-bottom: 20px; margin-top: 20px; } }
@media (max-width: 480px) { .main-container-unter { padding: 60px 0 40px; } .main-container-unter h1 { font-size: 28px; } .right-text-unter { font-size: 18px; } .gb-button { padding: 8px 16px; font-size: 14px; width: 100%; justify-content: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .gb-icon { display: none; } }



.widget-area { background-color: #fff !important; padding: 0 !important; margin: 0 !important; }
.widget-area .widget { background-color: #fff !important; padding: 0 !important; margin: 0 !important; }
.table-of-contents { position: sticky; top: 0; width: 100%; background: #fff; color: #000; padding: 0; margin: 0; box-shadow: none; z-index: 1000; }
.table-of-contents h2 { font-size: 18px; margin: 0; padding: 15px 15px 10px 15px; }
.table-of-contents ul { list-style: none; padding: 0 15px 15px 15px; margin: 0; }
.table-of-contents li { margin: 5px 0; }
.table-of-contents a { text-decoration: none; color: #000; transition: color 0.3s; padding: 5px 5px 5px 20px; display: block; position: relative; }
.table-of-contents a:hover { text-decoration: underline; }
.table-of-contents a.active { color: #ff3a2d; font-weight: bold; }
.table-of-contents a::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 5px; background: transparent; transition: background-color 0.3s; }
.table-of-contents a.active::before { background: #ff3a2d; height: var(--progress, 0%); transition: height 0.1s ease-out, background-color 0.3s; }

.custom-main-container { width: 100%; padding: 0px 0px; box-sizing: border-box; display: flex; flex-wrap: wrap; background: #0e181e; }
.custom-left-container { width: 20%; box-sizing: border-box; }
.custom-middle-container { width: 15%; box-sizing: border-box; display: flex; align-items: center; }
.custom-right-container { width: 65%; background: #f6f8f9; box-sizing: border-box; display: flex; justify-content: flex-start; padding: 0px; }
.custom-right-content { width: 1100px; max-width: 100%; margin-top: 30px; }
.custom-middle-container h2 { font-size: 20px; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; margin: 0; text-align: left; color: #fff; }
#custom-image-slider { width: 100%; overflow: hidden; }
.custom-slider-container { display: flex; transition: transform 1s cubic-bezier(0.45, 0.05, 0.55, 0.95); }
.custom-slider-slide { flex: 0 0 20%; padding: 0 10px; box-sizing: border-box; }
.custom-slider-slide img { width: 100%; height: auto; }
@media (max-width: 1024px) { .custom-left-container { width: 100%; padding-bottom: 20px; } .custom-middle-container { width: 30%; } .custom-middle-container h2 { padding: 20px; } .custom-right-container { width: 70%; } .custom-slider-slide { flex: 0 0 25%; } }
@media (max-width: 768px) { .custom-middle-container, .custom-right-container { width: 100%; } .custom-middle-container h2 { padding: 20px; } .custom-slider-slide { flex: 0 0 50%; } }
.custom-slider-slide img { width: 100%; height: auto; filter: grayscale(100%); transition: filter 0.3s ease; }
.custom-slider-slide img:hover { filter: grayscale(0%); }


.custom-bullet-point { display: flex; align-items: flex-start; margin-bottom: 60px; }
.custom-bullet-point::before { content: "•"; font-size: 32px; margin-right: 10px; line-height: 1;}
.custom-bullet-point p { margin: 0; font-size: 22px; line-height: 1.5; }
.custom-heading { font-size: 38px; margin-top: 0; margin-bottom: 20px; }

.values-container { width: 100%; padding: 0; box-sizing: border-box; }
.values-title { font-size: 21px; text-align: left; margin-bottom: 60px; font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif; }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; max-width: 100%; margin: 0 auto; }
.value-box { background-color: #fff; padding: 30px; border-radius: 8px; border: 1px solid #e1e1e1; transition: all 0.3s ease; }
.value-box:hover { transform: translateY(-10px); box-shadow: 0 10px 20px rgba(0,0,0,0.1); }
.value-box h3 { font-size: 24px; margin-bottom: 15px; font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif; }
.value-box p { font-size: 19px; line-height: 1.7; color: #666; font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif; }
@media (max-width: 992px) { .values-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 768px) { .values-grid { grid-template-columns: 1fr; } .values-title { font-size: 24px; } .value-box h3 { font-size: 20px; } .value-box p { font-size: 16px; } }

.li-content { margin-right: 150px; }
.wp-block-list { margin-left: 1.5em; padding-left: 1.5em; }
.wp-block-list li { margin-bottom: 20px; position: relative; }
.wp-block-list ul { list-style-type: disc; }
.wp-block-list ol { list-style-type: decimal; }
.wp-block-list ul ul, .wp-block-list ol ul { list-style-type: circle; margin-top: 10px; }
.wp-block-list ul ul ul, .wp-block-list ol ul ul { list-style-type: square; }
.wp-block-list ol ol, .wp-block-list ul ol { list-style-type: lower-alpha; margin-top: 10px; }
.wp-block-list ol ol ol, .wp-block-list ul ol ol { list-style-type: lower-roman; }
.wp-block-list li::marker { color: #ff3a2d; }
.wp-block-list li:hover::marker { color: #ff3a2d; }
@media screen and (max-width: 1200px) {.li-content { margin-right: 150px; }}
@media screen and (max-width: 992px) {.li-content { margin-right: 100px; }.wp-block-list { margin-left: 1em; padding-left: 1em; }}
@media screen and (max-width: 768px) {.li-content { margin-right: 50px; }.wp-block-list li { margin-bottom: 15px; }}
@media screen and (max-width: 576px) {.li-content { margin-right: 20px; }.wp-block-list { margin-left: 0.5em; padding-left: 0.5em; }.wp-block-list li { margin-bottom: 10px; }}


.process-container { display: flex; justify-content: center; align-items: flex-start; max-width: 1200px; margin: 0 auto; padding: 20px; }
.process-box { flex: 0 0 375px; margin: 0 20px; padding: 30px; position: relative; display: flex; flex-direction: column; }
.process-box:nth-child(1) { background-color: #0e181e; color: #fff; margin-top: 120px; }
.process-box:nth-child(2) { background-color: #f6f8f9; color: #000; margin-top: 40px; }
.process-box:nth-child(3) { background-color: #f6f8f9; color: #000; margin-top: 0; }
.process-box .number { position: absolute; top: 20px; right: 20px; font-size: 58px; font-weight: 500; }
.process-box h3 { margin-top: 120px; margin-bottom: 10px; font-size: 32px; text-align: left; }
.process-box p { font-size: 19px; text-align: left; flex-grow: 1; }

@media (max-width: 1024px) {
    .process-container { flex-direction: column; align-items: stretch; padding: 20px; }
    .process-box { flex-basis: 100%; margin: 30px 0; }
    .process-box:nth-child(1), .process-box:nth-child(2), .process-box:nth-child(3) { margin-top: 0; }
}

@media (max-width: 768px) {
    .process-container { padding: 5px; }
}


.re-leiste-custom-header-site { position: relative; margin-bottom: 60px; }
.re-leiste-custom-header-site::before { content: ''; position: absolute; left: 50%; top: 0; width: 10%; height: 1px; background-color: #f13b12; transform: translateX(-50%); }
.re-leiste-custom-container { width: 80%; padding: 0px; margin-top: 8%; margin-left: 20%; margin-right: 0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; background: #fff; }
.re-leiste-custom-header { position: relative; margin-bottom: 30px; }
.re-leiste-custom-header::before { content: ''; position: absolute; left: 0; top: 0; width: 10%; height: 1px; background-color: #f13b12; }
.re-leiste-custom-header h2 { margin: 20px 0 0; padding-left: 0px; font-size: 48px; color: #000; padding-top: 40px; }
.re-leiste-custom-boxes { display: flex; justify-content: space-between; }
.re-leiste-custom-box { width: 25%; padding: 15px; border-left: 1px solid #d4dee4; transition: all 0.3s ease; background-color: #fff; }
.re-leiste-custom-box-icon { width: 45px; height: 45px; fill: #f13b12; transition: fill 0.3s ease; }
.re-leiste-custom-box h3 { font-size: 21px; margin: 15px 0; color: #333; }
.re-leiste-custom-box p { font-size: 19px; line-height: 1.6; margin-bottom: 15px; color: #666; }
.re-leiste-custom-box-button { display: inline-flex; align-items: center; background: none; border: none; color: #f13b12; font-size: 14px; cursor: pointer; padding: 0; transition: color 0.3s ease; }
.re-leiste-custom-box-button::after { content: '⟶'; margin-left: 5px; transition: transform 0.3s ease; }
.re-leiste-custom-box:hover .re-leiste-custom-box-icon { fill: #ccc; background: none;}
.re-leiste-custom-box:hover .re-leiste-custom-box-button { color: #ccc; background: none;}
.re-leiste-custom-box:hover .re-leiste-custom-box-button::after { animation: re-leiste-pulse 1s infinite; }
@keyframes re-leiste-pulse { 0% { transform: translateX(0); } 50% { transform: translateX(5px); } 100% { transform: translateX(0); } }
.re-leiste-custom-button-container { width: 80%; padding: 0px; margin-left: 20%; margin-right: 0; margin-top: 60px; text-align: left; }
.re-leiste-custom-more-button { display: inline-flex; align-items: center; background-color: #000; border: none; color: #fff; font-size: 16px; cursor: pointer; padding: 10px 20px; margin-left: 10%; transition: all 0.3s ease; border-radius: 25px; }
.re-leiste-custom-more-button::after { content: '⟶'; margin-left: 10px; transition: transform 0.3s ease; }
.re-leiste-custom-more-button:hover { background-color: #ccc; color: #000; animation: re-leiste-pulse-shrink 0.5s ease-in-out infinite alternate; }
.re-leiste-custom-more-button:hover::after { transform: translateX(5px); }
@keyframes re-leiste-pulse-shrink { to { transform: scale(0.93); } }
@media (max-width: 1024px) { .re-leiste-custom-container, .re-leiste-custom-button-container { width: 100%; margin-left: 0; padding: 0 20px; box-sizing: border-box; } .re-leiste-custom-boxes { flex-wrap: wrap; } .re-leiste-custom-box { width: 50%; margin-bottom: 20px; } .re-leiste-custom-more-button { margin-left: 0; } }
@media (max-width: 480px) { .re-leiste-custom-box { width: 100%; } }



.outer-container-4711 { width: 100%; overflow: visible; box-sizing: border-box; position: relative; }
.inner-container-4711 { width: 1430px; max-width: 100%; margin: 0 auto; padding: 40px 0px; position: relative; }
.service-box-4711 { display: flex; justify-content: space-between; align-items: flex-start; padding: 20px 0; text-decoration: none; color: inherit; transition: transform 0.3s ease; position: relative; }
.service-box-4711::after { content: ''; position: absolute; bottom: 0; left: calc(-50vw + 50%); right: 24px; height: 1px; background-color: #d4dee4; }
.service-content-4711 { flex-grow: 1; }
.service-icon-4711 { width: 165px; height: 165px; margin-right: 30px; }
.service-icon-4711 img { width: 100%; height: auto; object-fit: contain; }
.service-title-4711 { font-size: 32px; font-weight: bold; color: #090909; margin-bottom: 10px; }
.service-description-4711 { font-size: 21px; color: #353c40; max-width: 80%; }
.service-arrow-4711 { font-size: 44px; color: #090909; margin-right: 20px; }
.service-box-4711:hover { transform: translateX(10px); }
.service-box-4711:hover .service-icon-4711 img { filter: brightness(0) saturate(100%) invert(36%) sepia(94%) saturate(7075%) hue-rotate(351deg) brightness(98%) contrast(101%); }
@media (max-width: 1430px) { .inner-container-4711 { width: 100%; } .service-box-4711::after { left: -20px; right: -20px; width: calc(100% + 40px); } }
@media (max-width: 768px) { .service-box-4711 { flex-wrap: wrap; } .service-content-4711 { width: calc(100% - 60px); } .service-arrow-4711 { position: absolute; top: 20px; right: 0; } .service-icon-4711 { width: 80px; height: 80px; } .service-title-4711 { font-size: 30px !important; } }
@media (max-width: 480px) { .service-box-4711 { flex-direction: column; align-items: flex-start; text-align: left; } .service-icon-4711 { width: 65px; height: 65px; text-align: left; } .service-icon-4711 img { display: block; margin-right: auto; } .service-title-4711 { font-size: 24px !important; text-align: left; margin-top: 20px; } .service-arrow-4711 { display: none; } .service-content-4711 { width: 100%; text-align: left; } }







.single .site-content { max-width: 1430px !important; margin-left: auto !important; margin-right: auto !important; width: 100% !important; padding-left: 15px !important; padding-right: 15px !important; }
.single #content { max-width: 1430px !important; margin-left: auto !important; margin-right: auto !important; width: 100% !important; padding-left: 15px !important; padding-right: 15px !important; }
.single .content-area { max-width: 1430px !important; margin-left: auto !important; margin-right: auto !important; width: 100% !important; padding-left: 15px !important; padding-right: 15px !important; }
.single .site-main { max-width: 1430px !important; margin-left: auto !important; margin-right: auto !important; width: 100% !important; padding-left: 15px !important; padding-right: 15px !important; }
@media (max-width: 1430px) {.single .site-content { max-width: 100% !important; } .single #content { max-width: 100% !important; }.single .content-area { max-width: 100% !important; } .single .site-main { max-width: 100% !important; }}





.latest-posts-container { display: flex; gap: 30px; flex-wrap: wrap; }
.latest-post-main { flex: 1 1 400px; }
.latest-posts-secondary { flex: 1 1 400px; display: flex; flex-direction: column; gap: 10px; }
.post-box { background: #0e181e; color: #fff; padding: 30px; transition: all 0.3s ease; display: flex; flex-direction: column; align-items: flex-start; text-decoration: none; }
.latest-post-main .post-box { border-radius: 10px; border: 1px solid #393939; height: calc(100% - 2px); }
.post-meta { font-size: 18px; margin-bottom: 10px; color: rgba(255, 255, 255, 0.7); }
.latest-post-main .post-box h2 { font-size: 42px; font-weight: 400; margin-bottom: 60px; line-height: 1.2; text-align: left; }
.latest-posts-secondary .post-box h2 { font-size: 26px; font-weight: 400; margin-bottom: 20px; line-height: 1.2; text-align: left; }
.read-more { text-decoration: underline; color: #fff; margin-top: auto; display: inline-block; }
.secondary-post p { font-size: 21px; line-height: 1.5; color: rgba(255, 255, 255, 0.7); text-align: left; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.post-box:hover { color: #ccc; }
.latest-post-main .post-box:hover { transform: scale(1.02); }
.secondary-post:hover { animation: pulse-right 0.3s ease-in-out forwards; }
@keyframes pulse-right { 0% { transform: translateX(0); } 50% { transform: translateX(10px); } 100% { transform: translateX(10px); } }
@media (max-width: 1200px) { .latest-post-main .post-box h2 { font-size: 36px; } .latest-posts-secondary .post-box h2 { font-size: 24px; } .secondary-post p { font-size: 18px; } }
@media (max-width: 992px) { .latest-post-main .post-box h2 { font-size: 32px; } .latest-posts-secondary .post-box h2 { font-size: 22px; } .secondary-post p { font-size: 16px; } }
@media (max-width: 768px) { .latest-posts-container { flex-direction: column; } .latest-post-main, .latest-posts-secondary { flex: 1 1 100%; } .latest-post-main .post-box h2 { font-size: 28px; } .latest-posts-secondary .post-box h2 { font-size: 20px; } .post-meta { font-size: 16px; } }
@media (max-width: 576px) { .latest-post-main .post-box h2 { font-size: 24px; } .latest-posts-secondary .post-box h2 { font-size: 18px; } .secondary-post p { font-size: 14px; } .post-meta { font-size: 14px; } }




.article-section { margin-bottom: 30px; position: relative; }
.blog-label { color: #090909; text-transform: uppercase; margin-bottom: 65px; display: flex; align-items: center; }
.blog-label::before { content: "•"; font-size: 1.5em; margin-right: 30px; line-height: 0; }
.article-section h2 { display: inline-block; color: #0e181e; text-transform: uppercase; margin-top: 0; margin-bottom: 20px; }
.all-articles { float: right; color: #0e181e; text-decoration: underline; text-transform: uppercase; transition: all 0.3s ease; }
.all-articles:hover { color: #ccc; text-decoration-color: #ccc; transform: scale(0.98); }
.article-container { display: flex; flex-wrap: wrap; justify-content: space-between; margin-top: 20px; clear: both; }
.article-box { width: 48%; background-color: #090909; color: #fff; padding: 40px; border-radius: 10px; transition: all 0.3s ease; display: flex; flex-direction: column; text-decoration: none; margin-bottom: 20px; }
.article-box:hover { transform: scale(0.98); }
.article-box h3 { margin-top: 20px; margin-bottom: 20px; font-size:36px !important;font-weight:400;}
.article-box p { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; flex-grow: 1; margin-bottom: 90px;}
.article-meta { margin-top: 30px; margin-bottom: 20px; }
.article-meta .separator { margin: 0 10px; }
.article-box:hover h3, .article-box:hover p, .article-box:hover .article-meta { color: #ccc; }

@media (max-width: 768px) { 
    .article-container { flex-direction: column; } 
    .article-box { width: 100%; } 
    .all-articles { float: none; display: block; margin-top: 10px; } 
}



 .treppe-effect { width: 100%; height: 7vh; position: relative; padding: 0; overflow: hidden; margin-bottom: -50px; }
    @media only screen and (max-width: 1024px) and (min-width: 768px) { .treppe-effect { margin-bottom: -25px !important; height: 7vh; } }
    @media only screen and (max-width: 767px) and (min-width: 481px) { .treppe-effect { margin-bottom: -20px !important; height: 6vh; } }
    @media only screen and (max-width: 480px) { .treppe-effect { margin-bottom: -15px !important; height: 6vh; } }

 .treppe-effect-1 { width: 100%; height: 7vh; position: relative; padding: 0; overflow: hidden; margin-bottom: -50px; }
    @media only screen and (max-width: 1024px) and (min-width: 768px) { .treppe-effect-1 { margin-bottom: -25px !important; height: 7vh; } }
    @media only screen and (max-width: 767px) and (min-width: 481px) { .treppe-effect-1 { margin-bottom: -20px !important; height: 6vh; } }
    @media only screen and (max-width: 480px) { .treppe-effect-1 { margin-bottom: -15px !important; height: 6vh; } }

.bex-container { width: 100%; background-color: #0a0d14; padding: 40px 0px; font-family: inherit; }
.bex-inner { max-width: 1430px; margin: 0 auto; padding: 0 20px; margin-top: 145px; margin-bottom:105px; }
.bex-header { display: flex; margin-bottom: 20px; width: 100%; }
.bex-header-left { width: 40%; text-align: left; }
.bex-header-left h3 { text-transform: uppercase; border-radius: 20px; display: inline-block; padding: 3px 15px; background-color: #ff3a2d; }
.bex-header-right { width: 60%; text-align: left; }
.bex-container .bex-inner .bex-header-right h2 { margin-top: 0; color: #fff; font-size: 53px !important; font-family: inherit; }
.bex-header-right p { color: #ccc; margin-top: 10px; margin-bottom: 60px; text-align: left; font-size: 21px; font-weight: 300; }
.bex-header h3 { color: #e7e6e2; font-size: 15px; }
.bex-header h2 { margin-top: 0; color: #fff; }
.bex-row { display: flex; justify-content: flex-start; margin: 0; padding: 20px 0; transition: background-color 0.3s; align-items: flex-start; }
.bex-box { color: #fff; }
.bex-box-icon { width: 120px; height: 120px; display: flex; justify-content: center; align-items: center; flex-shrink: 0; margin-right: 30px; }
.bex-box-icon img { max-width: 100%; max-height: 100%; object-fit: contain; filter: brightness(0) saturate(100%) invert(39%) sepia(85%) saturate(2760%) hue-rotate(341deg) brightness(100%) contrast(106%); }
.bex-box-title { width: 100%; text-align: left; }
.bex-box-text { width: 100%; text-align: left; font-size: 18px; }
.bex-container .bex-inner .bex-row .bex-box-text p { font-size: 20px !important; color: #ccc; line-height: 1.7; }
.bex-row:hover { background-color: #12171e; }
.bex-line { border-top: 1px solid #7e7e7e; }
.bex-box-content { display: flex; flex-direction: column; flex-grow: 1; width: 100%; }
@media (max-width: 768px) { .bex-header, .bex-row { flex-direction: column; } .bex-header-left, .bex-header-right, .bex-box { width: 100%; padding: 10px 0; } .bex-header-left { text-align: center; } .bex-box-icon { width: 100px; height: 100px; margin-bottom: 20px; margin-right: 0; } .bex-box-title, .bex-box-text { text-align: left; } .bex-row { align-items: flex-start; } .bex-box-content { width: 100%; } }
@media (max-width: 1024px) { .bex-box-title h2 { font-size: 26px; } .bex-box-icon { width: 100px; height: 100px; } .bex-box-title h2 { text-align: left; margin-left: 0; font-size: 23px; } }





.my-custom-icon { display: inline-block; width: 65px; height: 65px; font-size: 24px; color: #fff; z-index: 5; margin-right: 10px; vertical-align: middle; margin-bottom: 25px; position: relative; filter: brightness(0) saturate(100%) invert(39%) sepia(85%) saturate(2760%) hue-rotate(341deg) brightness(100%) contrast(106%); }
.my-custom-box-container { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 20px; }
.my-custom-box { flex: 1 1 calc(33.333% - 20px); min-width: 250px; background-color: #12171e; border-radius: 0px; padding: 20px; position: relative; overflow: hidden; transition: transform 0.3s ease; }
.my-custom-box::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background-color: #0e1015; box-shadow: 0 0 20px rgba(0, 0, 0, 0.3); transition: left 0.6s ease; z-index: 1; }
.my-custom-box:hover::before { left: 100%; }
.my-custom-title { color: #fff; position: relative; z-index: 2; text-align: left; display: flex; align-items: center; }
.my-custom-text { color: #fff; font-size: 23px; line-height: 1.5em; position: relative; z-index: 2; }
@media (max-width: 768px) { .my-custom-box { flex: 1 1 100%; } }

@media (min-width: 1099px) {
    nav .main-nav .mega-menu { position: static; }
    nav .main-nav .mega-menu > ul { position: absolute; width: 100%; left: 0 !important; display: flex; flex-wrap: wrap; padding: 15px 0 20px 5px; border-left: 1px solid #f6f6f6; border-radius: 5px; }
    nav .main-nav .mega-menu > ul > li > a { font-weight: normal; font-size: 18px; font-weight: 600; }
    nav .main-nav .mega-menu > ul > li { display: inline-block; width: 35%; vertical-align: top; }
    nav .main-nav .mega-menu.mega-menu-col-2 > ul > li { width: 55%; }
    nav .main-nav .mega-menu.mega-menu-col-3 > ul > li { width: 33.3333%; }
    nav .main-nav .mega-menu.mega-menu-col-5 > ul > li { width: 20%; }
    nav .main-nav .mega-menu ul .sub-menu { position: static; display: block; opacity: 1; visibility: visible; width: 100%; box-shadow: 0 0 0; left: 0; height: auto; pointer-events: auto; transform: scale(1); }
    nav .main-nav .mega-menu ul.toggled-on .sub-menu { pointer-events: auto; }
    nav .main-nav .mega-menu .sub-menu .menu-item-has-children .dropdown-menu-toggle { display: none; }
}

.bild-quer img{border-radius:8px;}
.h-grau {background-color: #31353f; color: #f6f6f6; border-radius: 20px; display: inline-block; padding: 3px 15px;text-transform: uppercase;font-size:18px;}
.grey-raster {filter: grayscale(100%);}
.grey-raster img{border:solid 1px #e5e0e0; border-radius:10px;padding:10px}
.raster-oben {border: solid 1px #202020;padding-top:30px;}
.oben-box {margin-top:50px;}
@media (max-width: 1024px) { .oben-box { margin-top:0px; } .grey-raster img{border:none;}}
@media (max-width: 768px) { .oben-box { margin-top:0px;}.grey-raster img{border:none;} }
.greyline { height: auto; filter: grayscale(100%);padding:10px; width: calc(86.666% - 47px);}
.seo-headline { font-size: 50px; font-weight: 600; line-height: 1.6; color: #333; margin: 20px auto; word-break: break-word; } 
.seo-headline .highlight { border: 2px solid #f6f6f6; border-radius: 20px; padding: 2px 8px; display: inline-block;} 
@media (max-width: 1024px) { .seo-headline { font-size: 35px; } }
@media (max-width: 768px) { .seo-headline { font-size: 30px !important; } .seo-headline .highlight { padding: 2px 4px; border: 2px solid #f6f6f6; border-radius: 20px; font-size:23px !important; } }
@media (max-width: 768px) { .seo-headline .highlight { display: inline; border: none; border-bottom: 2px solid #f6f6f6; border-radius: 0; padding: 0 0 2px 0; } }
.seo-headline-1 { font-size: 40px; font-weight: 600; line-height: 1.6; color: #333; margin: 20px auto; word-break: break-word; } 
.seo-headline-1 .highlight { border: 2px solid #000; border-radius: 20px; padding: 2px 8px; display: inline-block;} 
@media (max-width: 1024px) { .seo-headline-1 { font-size: 35px; } }
@media (max-width: 768px) { .seo-headline-1 { font-size: 30px !important; } .seo-headline .highlight { padding: 2px 4px; border: 2px solid #f6f6f6; border-radius: 20px; font-size:23px !important; } }
@media (max-width: 768px) { .seo-headline-1 .highlight { display: inline; border: none; border-bottom: 2px solid #000; border-radius: 0; padding: 0 0 2px 0; } }

.text-unten-container { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; }
.text-unten { text-align: left; font-size: 250px; font-weight: 800; color: transparent; background: linear-gradient(to top, rgba(31, 35, 40, 0.8), rgba(31, 35, 40, 1)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; margin: 0; padding: 0; flex: 1; }
.contact-button-1 { display: inline-block; padding: 5px 20px; background-color: #fff; color: #000 !important; text-decoration: none; transition: all 0.3s ease; border-radius: 35px; margin-bottom: 80px; }
.contact-button-1:hover { background-color: #ccc; color: #000; animation: pulse 0.3s ease-in-out; }
@keyframes pulse { 0% { transform: scale(1); } 50% { transform: scale(0.98); } 100% { transform: scale(1); } }
@media (max-width: 1024px) { .text-unten-container { flex-direction: column; align-items: flex-start; padding-left: 20px; } .text-unten { font-size: 180px; } .contact-button-1 { margin-top: 30px; } }
@media (max-width: 768px) { .text-unten { font-size: 120px !important; } }
@media (max-width: 480px) { .text-unten { font-size: 80px !important; } .contact-button-1 { margin-top: 30px; } }

.link-button { color: #fff; text-decoration: none; transition: color 0.3s ease; font-size:16px;}
.link-button:hover { color: #ccc; }

.zoom-up { opacity: 0; transform: translateY(20px); animation: zoom-up 1.8s forwards; animation-delay: var(--delay); }
@keyframes zoom-up { to { opacity: 1; transform: translateY(0); } }


.my-custom-icon-1 { display: inline-block; width: 65px; height: 65px; font-size: 24px; color: #fff; z-index: 5; margin-right: 10px; vertical-align: middle; margin-bottom: 25px; position: relative; }
.my-custom-box-container-1 { display: flex; flex-wrap: wrap; justify-content: center; gap: 20px; margin: 0 auto; }
.my-custom-box-1 { flex: 1 1 calc(50% - 20px); min-width: 250px; max-width: 390px; background-color: #20232d; border-radius: 0px; padding: 20px; position: relative; overflow: hidden; transition: transform 0.3s ease; margin-bottom: 20px; }
.my-custom-box-1::before { content: ''; position: absolute; bottom: -100%; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.3); z-index: 3; pointer-events: none; transition: bottom 0.5s ease; }
.my-custom-box-1:hover::before { bottom: 0; }
.my-custom-title-1 { color: #fff; position: relative; z-index: 4; text-align: left; display: flex; align-items: center; margin-top: 10px; opacity: 0; transform: translateY(20px); transition: opacity 0.5s ease, transform 0.5s ease; }
.my-custom-box-1:hover .my-custom-title-1 { opacity: 1; transform: translateY(0); }
.my-custom-text-1 { color: #fff; font-size: 15px; line-height: 1.5em; position: relative; z-index: 4; }
.my-custom-box-1 img { display: block; transition: filter 0.3s ease, box-shadow 0.3s ease; width: 100%; height: auto; max-width: 390px; filter: brightness(1); }
.my-custom-box-1:hover img { filter: brightness(0.9); }
@media (max-width: 1024px) { .my-custom-box-container-1 { padding:30px; } }
@media (max-width: 768px) { .my-custom-box-container-1 { padding:30px; } }
@media (max-width: 480px) { .my-custom-box-container-1 { padding:20px; } }


.bild-grau {filter: grayscale(100%);}

.custom-blog-loop .blog-post { display: flex; margin-bottom: 50px; } 
.custom-blog-loop .post-image { flex: 0 0 340px; margin-right: 40px; transition: transform 0.3s; } 
.custom-blog-loop .post-image:hover { transform: scale(1.05); } 
.custom-blog-loop .rounded-image { border-radius: 10px; width: 100%; height: auto; } 
.custom-blog-loop .post-content a{ flex: 1; color:#000;} 
.custom-blog-loop h2 a{ margin-top: 0;color:#000; } 
.custom-blog-loop .post-date { font-size: 0.9em; margin-bottom: 10px;}
@media (max-width: 768px) {.custom-blog-loop .blog-post { flex-direction: column; }.custom-blog-loop .post-image { margin-right: 0; margin-bottom: 20px; flex: 0 0 auto; }}


.main-navigation:not(.slideout-navigation) .main-nav li.nav-button a { color: #000; background: #f0f0f0; line-height: 36px; border-radius: 35px; margin-left: 20px; transition: all 0.6s ease 0s; } 
.main-navigation:not(.slideout-navigation) .main-nav li.nav-button a:hover { color: #7A9E9F; transform: scale(1.05); }


.button-gelb { background-color: #ff3a2d; color: #fff; border: none; border-radius: 35px; padding: 10px 30px; font-size: 23px; text-align: center; text-decoration: none; position: relative; overflow: hidden; transition: border 0.3s ease; }
.button-gelb::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background-color: rgba(255, 255, 255, 0.5); box-shadow: 0 0 20px rgba(255, 255, 255, 0.5); transition: left 0.6s ease; }
.button-gelb:hover::before { left: 100%; }
.button-gelb:hover { color: #fff; }
.button-gelb .icon { margin-right: 10px; }
.button-gelb .gb-icon {margin-left:20px;}

.button-gelb-1 { background-color: #ff3a2d; color: #fff; border: none; border-radius: 35px; padding: 15px 35px; font-size: 23px; text-align: center; text-decoration: none; position: relative; overflow: hidden; transition: border 0.3s ease; }
.button-gelb-1::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background-color: rgba(255, 255, 255, 0.5); box-shadow: 0 0 20px rgba(255, 255, 255, 0.5); transition: left 0.6s ease; }
.button-gelb-1:hover::before { left: 100%; }
.button-gelb-1:hover { color: #fff; }
.button-gelb-1 .icon { margin-right: 10px; }
.button-gelb-1 .gb-icon {margin-left:20px;}

.unique-container { width: 100%; max-width: 1430px; margin: 0 auto; box-sizing: border-box;}
.unique-left-box { border-left: 4px solid #000; padding: 20px; font-size: 23px; box-sizing: border-box;margin-bottom:40px;text-align:center;  }
.unique-right-box { display: flex; flex-wrap: wrap; gap: 20px;}
.unique-right-box img { width: calc(16.666% - 17px); max-width: 150px; height: auto; filter: grayscale(100%);border:solid 1px #ccc;border-radius:15px;padding:10px; }
@media (max-width: 768px) {.unique-container { padding: 0 20px; } .unique-right-box img { width: calc(50% - 10px); }}
@media (min-width: 769px) and (max-width: 1024px) {.unique-container { padding: 0 20px; }.unique-right-box img { width: calc(25% - 15px); }}
@media (min-width: 1025px) {.unique-left-box { width: 100%; }.unique-right-box { width: calc(100% - 300px); }.unique-container {margin-left:25%;margin-bottom:40px;}}

.button-container-12 { display: flex; align-items: center; position: relative; }
.button-container-12 .rounded-button-12 { background-color: #090909; color: #fff; padding: 10px 20px; border: none; border-radius: 25px; cursor: pointer; transition: background-color 0.3s, color 0.3s, transform 0.7s; font-size: 21px; }
.button-container-12 .round-button-12 { background-color: #090909; color: #fff; width: 47px; height: 47px; border: none; border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background-color 0.3s, color 0.3s, transform 0.7s; margin-left: 0; }
.button-container-12:hover .rounded-button-12, .button-container-12:hover .round-button-12 { background-color: #ff3a2d; color: #fff; }
.button-container-12:hover .rounded-button-12 { transform: translateX(60px); margin-left: -20px; }
.button-container-12:hover .round-button-12 { transform: translateX(-310px); }
.arrow-12 { font-size: 30px; color: inherit; transform: rotate(40deg); display: inline-block; }

#custom-image-slider { position: relative; max-width: 100%; overflow: hidden; }
#custom-image-slider .slider-container { display: flex; transition: transform 1s cubic-bezier(0.45, 0.05, 0.55, 0.95); width: 100%; }
#custom-image-slider .slider-slide { flex: 0 0 20%; max-width: 20%; box-sizing: border-box; padding: 0 5px; }
#custom-image-slider .slider-slide img { width: 75%; height: auto; filter: grayscale(100%); object-fit: cover; border-radius: 10px; }
@media (max-width: 1024px) { #custom-image-slider .slider-slide { flex: 0 0 25%; max-width: 25%; } }
@media (max-width: 768px) { #custom-image-slider .slider-slide { flex: 0 0 50%; max-width: 50%; } }





