.ruw_dienstpagina {
    width: 100%;
    overflow: hidden;
    float: left;
    display: flex;
    flex-direction: column;
    align-items: center;
    background-color: #ffffff;
    gap: 0px;
    box-sizing: border-box;
    gap: 0px;
    margin-bottom: 60px!important;
}
.ruw_dienstpagina .ruw_section {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    box-sizing: border-box;
    overflow: hidden;
    padding-top: 30px;
    padding-bottom: 60px;
}

.ruw_dienstpagina .ruw_section .ruw_row {
    padding: 20px;
    width: 80%;
    max-width: 1100px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    z-index: 10;
    align-items: center;
    gap: 50px;
}

@media screen and (max-width: 980px) {
    .ruw_dienstpagina .ruw_section .ruw_row {
        gap: 20px;
    }
}

.ruw_top_section{
    padding-top: 150px!important;
    position:relative;
    padding-bottom: 0px!important;
}

.ruwd_breadcrumb > ul {
    list-style: none;
    padding: 0px!important;
    margin: 0px!important;
    display: flex;
    align-items:center;
    gap: 5px;
    justify-content: center;
}
.ruwd_breadcrumb > ul > li {
    display: inline;
}
.ruwd_breadcrumb > ul > li > a {
    text-decoration: none;
    font-weight: 800;
    color: #222222;
    opacity: 0.5;
    transition: opacity 0.3s ease;
}
.ruwd_breadcrumb > ul > li > a:hover{
    opacity: 1;
}
.ruw_dienstpagina .ruw_section .ruw_row_caroussel{
    max-width: 100%;
    /* height: 700px; */
    width: 100%;
    position: relative;
    padding: 0px;
    display: block;
}
.splide__slide{
    padding: 5px;
}
.ruw_carousel_item{
    width: 100%;
    height: 100%;
    aspect-ratio: 1/1;
    background-size: cover;
    background-position: center;
}
.ruw_carousel_item {
  width: 100%;
  height: 400px;
  background-size: cover;
  background-position: center;
  transition: transform 0.5s ease, opacity 0.5s ease;
  transform-style: preserve-3d;
}
.ruw_row_caroussel > .top_row,
.ruw_row_caroussel > .bottom_row{
    position:absolute;
    bottom: -3px;
    height: 33px;
    min-width: 100%;
    left: 0px;
    transform: translate(-50%, 0%);
    left: 50%;
}

@media only screen and (min-width: 2150px) {
    .ruw_row_caroussel > .top_row,
    .ruw_row_caroussel > .bottom_row{
        display: none;
    }
}

.ruw_row_caroussel > .top_row{
    top: 0;
    bottom: auto;
    transform: rotate(180deg) translate(50%, 0%);
}
.rtxt_dienst_slogan{
    font-size: 2.6em;
    font-weight: 900;
    color: var(--dienst-700);
    text-align: center;
    margin-top: 10px;
    margin-bottom: 20px;
    width: 80%;
    line-height: 1.2em;
    max-width: 1100px;
}

.ruw_top_section::before{
    background: linear-gradient(180deg,var(--dienst-300 ) 0%, rgba(255, 255, 255, 1) 25%);
    content: '';
    position: absolute;
    bottom: 0px;
    left: 0;
    width: 100%;
    height: 250px;
}
p.rtxt_subheader {
    max-width: 720px;
    width: 100%;
    text-align: center;
    font-weight: 800;
    color: black;
}

.dienst_cta_primary
{
    display: inline-block;
    padding: 8px 19px;
    background-color: var(--dienst-700);
    color: white;
    font-size: 18px;
    margin-top: 20px;
    font-weight: 800;
    text-decoration: none;
    transition: background-color 0.3s ease;
}

.dienst_cta_primary:hover {
    background-color: var(--dienst-300);
}
.ruw_dienstpagina .ruw_section .ruw_row_full{
    width: 100% !important;
    max-width: 100% !important;
    padding: 0px !important;
}
.marquee {
    display: flex;
    flex-direction: row;
    align-content: center;
    align-items: center;
    justify-content: flex-end;
}
.marquee-inner > span {
    font-size: 60px;
    font-weight: 900;
    color: #ececec;
    /* margin: 50px 0px; */
}

@media screen and (max-width: 980px) {
    .marquee-inner > span {
        font-size: 30px;
    }
}

.marquee-inner {
    padding: 20px;
    margin: 20px 0px;
}

.ruw_row.ruw_row_2col {
    display: grid!important;
    grid-template-columns: 1fr 1fr!important;
    align-content: center;
    align-items: center;
    justify-items: center;
    justify-content: center;
}

@media screen and (max-width: 980px) {
    .ruw_row.ruw_row_2col {
        display: flex !important;
        gap: 20px;
    }
    
    .ruw_row_reverse {
        grid-template-areas: "col1" "col2"!important;
    }
}

.ruw_img {
    display: block;
}

.fullwidth {
    max-width: 100% !important;
}

.ruw_img > img {
    max-width: 350px;
    max-height: 500px;
}

.ruw_row_col {
    display: flex;
    flex-direction: column;
    align-content: center;
    align-items: stretch;
    gap: 15px;
}

.rtxt_tinyheader {
    font-weight: 800;
    font-size: 17px;
    padding: 0px;
    color: var(--dienst-700);
}

.rtxt_moduleheader {
    color: black;
    font-weight: 900;
    font-size: 33px;
    line-height: 1.15em;
}

.ruw_row_col > * {
    padding: 0px!important;
}
.ruw_focus {
    width: 100%;
    display: grid;
    grid-template-columns: 270px 1fr;
    grid-gap: 40px;
}

@media screen and (max-width: 980px) {
    .ruw_focus {
        grid-template-columns: 1fr;
        grid-gap: 40px;
    }
    
    .ruw_focus_intro > * {
        text-align: center;
    }
}
.ruw_focus_intro > *{
    text-align: right;
}
#ruwd_horizontal_car > div > ul > li{
    opacity: .5;
}
/* Ensure vertical slider slides take full width immediately */
#ruwd_horizontal_car .splide__slide {
    width: 100% !important;
}
#ruwd_horizontal_car > div > ul > li > .splide_slide_content {
    transition-duration: 0.6s;
    background-color: #F5F5F5;
    padding: 16px;
    padding-left: 80px;
    height: 100px;
    position:relative;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 7px;
    width: 100%;
    box-sizing: border-box;
}

@media screen and (max-width: 768px) {
    #ruwd_horizontal_car > div > ul > li > .splide_slide_content {
        padding-left: 0px;
        width: 100%;
        max-width: 100%;
    }
}

#ruwd_horizontal_car > div > ul > li > .splide_slide_content::after{
    content: '';
    position: absolute;
    top: 0;
    left: 10px;
    width: 60px;
    height: 100%;
    z-index: 1;
    background-image: url("/wp-content/uploads/2025/07/check.svg");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 30px;
}
#ruwd_horizontal_car > div > ul > li > .splide_slide_content > *{
    margin: 0px!important;
    padding: 0px!important;
    font-size: 14px;
    gap: 15px;
}
#ruwd_horizontal_car > div > ul > li > .splide_slide_content > h3{
    font-size: 20px;
    font-weight: 900;
    color: black!important;
}


.ruw_focus_body > .splide > .splide__track > ul.splide__list >  .is-next {
    opacity: 1 !important;
    background-color: white !important;
}

.ruw_focus_intro {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    gap: 15px;
}

@media screen and (max-width: 980px) {
    .ruw_focus_intro {
        align-items: center;
    }
}

/* Grid layout voor focus items op kleine schermen */

.ruw_focus_grid {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.ruw_focus_grid_item {
    background-color: #F5F5F5;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 7px;
    height: fit-content;
}

.ruw_focus_grid_item > * {
    font-size: 14px;
    text-align: center;
}

.ruw_focus_grid_item > h3 {
    font-size: 20px;
    font-weight: 900;
    color: black;
    text-align: center;
}

/* Zichtbaarheid controls: slider op grote schermen, grid op kleine schermen */
@media screen and (min-width: 981px) {
    .ruw_focus_slider {
        display: block;
    }
    
    .ruw_focus_grid {
        display: none !important;
        -webkit-appearance: none;
    }

    .ruw_focus_grid_item {
        display: none !important;
        -webkit-appearance: none;
    }
}

@media screen and (max-width: 980px) {
    .ruw_focus_slider {
        display: none;
    }
    
    .ruw_focus_grid {
        display: grid;
        gap: 15px;
    }

    .ruw_focus_grid_item {
        display: block !important;
    }
}

.col_img{
    grid-area: col1;
}
.col_text{
    grid-area: col2;
}
.ruw_row_2col{
    grid-template-areas: "col1 col2";
}
.ruw_row_reverse{
    grid-template-areas: "col2 col1";
}
.ruw_focus_intro > a.dienst_cta_primary{
    margin-top: 0px;
}
.ruw_faq_item{
    padding: 20px;
    padding-right: 60px;
    background-color: #F5F5F5;
    width: 100%;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 15px;
    position:relative;
}
.ruw_faq_list{
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
}
.ruw_faq_item > *{
    margin: 0px!important;
    padding: 0px!important;
}
.ruw_faq_question{
    font-size: 17px;
    font-weight: 800;
}
.ruw_faq_item::after{
    content: '';
    position: absolute;
    top: 0;
    right: 10px;
    width: 60px;
    height: 60px;
    z-index: 1;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 20px;
    background-image: url('data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%3E%0A%20%20%3Cpath%20fill%3D%22%23000000%22%20d%3D%22M15.0857864%2C12.5%20L6.79289322%2C20.7928932%20C6.40236893%2C21.1834175%206.40236893%2C21.8165825%206.79289322%2C22.2071068%20C7.18341751%2C22.5976311%207.81658249%2C22.5976311%208.20710678%2C22.2071068%20L17.2071068%2C13.2071068%20C17.5976311%2C12.8165825%2017.5976311%2C12.1834175%2017.2071068%2C11.7928932%20L8.20710678%2C2.79289322%20C7.81658249%2C2.40236893%207.18341751%2C2.40236893%206.79289322%2C2.79289322%20C6.40236893%2C3.18341751%206.40236893%2C3.81658249%206.79289322%2C4.20710678%20L15.0857864%2C12.5%20Z%22%20transform%3D%22rotate(90%2012%2012.5)%22%2F%3E%0A%3C%2Fsvg%3E%0A');
}
.ruw_faq_item.ruw_faq_item_open::after{
    transform: rotate(180deg);
}
.cta_standby{
    font-weight: 400;
    background-color: #F5F5F5!important;
    color: #9C9C9C!important;
}

.ruw_dienst_badges {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: center;
}

.ruw_dienst_badges > a {
    margin: 0px!important;
}

.ruw_dienst_badge > a {
    margin: 0px;
}

.text_centered{
    text-align: center!important;
    max-width: 800px;
    font-weight: 400;
}

#ruw_happy_customers_caroussel > .splide__track .splide__list {
    display: flex;
    align-items: center;
}

#ruw_happy_customers_caroussel > .splide__track .splide__list .splide__slide {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}

#ruw_happy_customers_caroussel .splide__pagination {
    transform: translateY(60px);
}

#ruw_happy_customers_caroussel .splide__pagination li button {
    background: #000;
    opacity: 0.25;
}

#ruw_happy_customers_caroussel .splide__pagination li button.is-active {
    background: var(--dienst-700);
    opacity: 1;
}

#ruw_happy_customers_caroussel > .splide__track .splide__list .splide__slide .ruw_klanten_caroussel_item {
    max-width: 200px;
    max-height: 200px;
    width: 100%;
    height: auto;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
}

#ruw_happy_customers_caroussel > .splide__track .splide__list .splide__slide img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    display: block;
    margin: 0 auto;
}
#ruw_happy_customers_caroussel{
    width: 100%;
    max-width: 1000px;
    position:relative;
}

@media screen and (max-width: 980px) {
    #ruw_happy_customers_caroussel{
        margin-top: 40px;
    }
}

#ruw_happy_customers_caroussel::after{
    background: linear-gradient(90deg,rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 15%, rgba(255, 255, 255, 0) 85%, rgba(255, 255, 255, 1) 100%);
    content: '';
    position: absolute;
    top: 0;
    left: 0;    
    width: 100%;
    height: 100%;
    pointer-events: none;
}
.ruw_pages > *{
    margin: 0px!important;
    padding: 0px!important;
    font-size: 15px!important;
}
.ruw_pages > h5{
    font-weight: 800;
    font-size: 15px;
    color: black;
    margin-bottom: 10px;
}
.ruw_pages{
    width: 100%;
    max-width: 1100px;
    padding: 25px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
    background-color: #F5F5F5;
}
.ruw_nopadding,
.ruw_nopadding > div{
    padding: 0px!important;
    margin: 0px!important;
}

/* Slick Carousel Styling */
.ruw-slick-carousel {
    margin-top: 20px;
    width: 100%;
    max-width: 600px;
}

.ruw-slick-carousel .slick-slide-item {
    width: 100%;
    text-align: center;
}

.ruw-slick-carousel .slick-slide-item img {
    width: 100%;
    height: 440px;
    object-fit: cover;
    border-radius: 4px;
}

/* Responsive Slick carousel images */
@media screen and (max-width: 1200px) {
    .ruw-slick-carousel .slick-slide-item img {
        height: 380px;
    }
}

@media screen and (max-width: 900px) {
    .ruw-slick-carousel .slick-slide-item img {
        height: 320px;
    }
}

@media screen and (max-width: 980px) {
    .ruw-slick-carousel {
        max-width: 100%;
        margin-top: 15px;
    }
    
    .ruw-slick-carousel .slick-slide-item img {
        height: 280px;
    }
}

.ruw-slick-carousel .slick-dots {
    bottom: -70px;
}

@media screen and (max-width: 980px) {
    .ruw-slick-carousel .slick-dots {
        bottom: -55px;
    }
}

.slick-dots li {
    margin: 0px;
}

.ruw-slick-carousel .slick-dots li button:before {
    color: #F5F5F5;
    font-size: 12px;
    opacity: 1;
}

.ruw-slick-carousel .slick-dots li.slick-active button:before {
    color: var(--dienst-700);
}

/* Cases Carousel Styling */
.cases_explanation {
    text-align: center;
    font-size: 16px;
    font-weight: 300;
    color: #666;
    margin-top: 24px;
}

.ruw-dienst-cases-wrapper {
    width: 100%;
    margin-top: 20px;
}

.ruw24c_carroussel {
    width: 100%;
    max-width: 100%;
}

.ruw24c_carroussel_card {
    padding: 15px;
    position: relative;
    cursor: pointer;
}

.ruw24c_carroussel_card_inner {
    background-size: cover;
    background-position: center;
    height: 100%;
    width: 100%;
    padding-top: 100%;
    position: relative;
    border-radius: 2px;
    overflow: hidden;
    transition: transform 0.3s ease;
}

.ruw24c_carroussel_card:hover .ruw24c_carroussel_card_inner {
    transform: scale(1.05);
}

.ruw24c_carroussel_card_overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: color-mix(in srgb, var(--overlay-color, #000000) 90%, transparent);
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 2;
    border-radius: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ruw24c_carroussel_card:hover .ruw24c_carroussel_card_overlay {
    opacity: 1;
}

.ruw24c_carroussel_card_title {
    color: white;
    font-size: clamp(1.5rem, 1.169rem + 1.395vw, 2.25rem); /* 24px - 36px */
    font-weight: 900;
    text-align: center;
    padding: 20px;
    line-height: 1.2;
}

.card_blur {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    filter: blur(20px);
    z-index: -1;
    opacity: 0.3;
}

.no-cases-message {
    text-align: center;
    color: #666;
    font-style: italic;
    padding: 40px 20px;
}

.rw24_overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.8);
    z-index: 9999;
    display: flex;
    justify-content: center;
    align-items: center;
}

.rw24_modal {
    background: white;
    border-radius: 2px;
    overflow: hidden;
    max-width: 90vw;
    max-height: 90vh;
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.rw24_img {
    background-size: cover;
    background-position: center;
    min-height: 400px;
    position: relative;
}

.rs24_close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.9);
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.rs24_close::before {
    content: "×";
    font-size: 24px;
    font-weight: bold;
}

.rw24_nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    background: rgba(255, 255, 255, 0.9);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    font-weight: bold;
}

.rw24_prev {
    left: 20px;
}

.rw24_prev::before {
    content: "‹";
}

.rw24_next {
    right: 20px;
}

.rw24_next::before {
    content: "›";
}

.rs24_content {
    padding: 40px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.rs24_cta {
    background: var(--dienst-500);
    color: white;
    padding: 12px 24px;
    text-decoration: none;
    border-radius: 4px;
    text-align: center;
    font-weight: 600;
    transition: background-color 0.3s ease;
}

.rs24_cta:hover {
    background: var(--dienst-600);
}

.r24_dots {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
}

.r24_dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.5);
    cursor: pointer;
}

.r24_dot_active {
    background: var(--dienst-700);
}

.r24_loader {
    width: 50px;
    height: 50px;
    border: 5px solid #f3f3f3;
    border-top: 5px solid var(--dienst-500);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

@media screen and (max-width: 980px) {
         .rw24_modal {
         grid-template-columns: 1fr;
         grid-template-rows: 1fr;
         max-width: 95vw;
     }
 }

/* Additional responsive styles */
@media screen and (max-width: 980px) {
    .ruw_dienstpagina .ruw_section {
        padding-top: 40px;
        padding-bottom: 40px;
    }
    
    .ruw_top_section {
        padding-top: 100px!important;
    }
    
    .ruw_dienstpagina .ruw_section .ruw_row {
        width: 90%;
        padding: 15px;
    }
    
    .rtxt_dienst_slogan {
        font-size: 2em;
        width: 95%;
    }
    
    .rtxt_moduleheader {
        font-size: 28px;
        text-align: center;
    }
    
    .rtxt_tinyheader {
        text-align: center;
    }
    
    .ruwd_breadcrumb > ul {
        flex-wrap: wrap;
        justify-content: center;
        gap: 3px;
    }
    
    .ruwd_breadcrumb > ul > li {
        font-size: 14px;
    }
    
    /* Center align all text content on mobile */
    .ruw_row_col {
        text-align: center;
    }
    
    .ruw_row_col h2,
    .ruw_row_col h3,
    .ruw_row_col p,
    .ruw_row_col div {
        text-align: center;
    }
    
    /* Center align FAQ content */
    .ruw_faq_question {
        text-align: center;
    }
    
    .ruw_faq_answer {
        text-align: center;
    }
    
    /* Center align service badges */
    .ruw_dienst_badges {
        justify-content: center;
        flex-wrap: wrap;
    }
    
    /* Center align summary content */
    .ruw_pages h5 {
        text-align: center;
    }
    
    .ruw_pages > * {
        text-align: center;
    }
}

@media screen and (max-width: 480px) {
    .rtxt_dienst_slogan {
        font-size: 1.8em;
    }
    
    .rtxt_moduleheader {
        font-size: 24px;
    }
    
    .ruw_dienstpagina .ruw_section .ruw_row {
        width: 95%;
        padding: 10px;
    }
    
    .ruw-slick-carousel {
        max-width: unset;
    }
    
    .ruw-slick-carousel .slick-slide-item img {
        max-height: 250px;
    }
}

@media screen and (max-width: 400px) {
    .ruw-slick-carousel .slick-slide-item img {
        height: 220px;
    }
    
    /* Center align buttons and CTAs */
    .dienst_cta_primary {
        margin-left: auto;
        margin-right: auto;
        display: block;
        width: fit-content;
    }
}

@media screen and (max-width: 768px) {
    .mobile-mt-40 {
        margin-top: 40px;
    }
}

.flex {
    display: flex;
}

.mt-auto {
    margin-top: auto;
}

.mb-md {
    margin-bottom: 60px;
}

.mb-lg {
    margin-bottom: 120px;
}

.mt-md {
    margin-top: 60px;
}

@media screen and (min-width: 980px) {
    .dienst_gradient {
        background-image: linear-gradient(to bottom, #fff, #eee 84%, #fff 84%);
    }
}

.p-0 {
    padding: 0px !important;
}

.pb-0 {
    padding-bottom: 0px !important;
}


/* Functie voor weergeven thema kleuren */
ul.footer_subdiensten_links {
    list-style-type: none !important;
    padding: 0px !important;
    margin: 0px;
}

ul.footer_subdiensten_links > li {
    margin-bottom: 5px;
}

ul.footer_subdiensten_links > li > a {
    color: #999999;
    transition: all 0.3s ease;
    font-weight: 400;
}

ul.footer_subdiensten_links > li > a:hover {
    color: #EB622D;
}

.slick-track{
    display: block;
}
.ruw-slick-carousel .slick-slide-item img{
    width: auto;
    height: auto;
}


.ruw25_slider_fade {
    width: 100%;
    min-height: 20px;
    aspect-ratio: 3/2;
    position: relative;
    overflow: hidden;
}

.ruw-slick-carousel {
    width: 100%;
}

.ruw_row_col.col_img {
    width: 100%;
}

.ruw_fadeslider_item {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
}
.ruw25_slider_fade,
.slick-track,
.slick-list,
.ruw_fadeslider_item{
    border-radius: 2px;
    height: 100%;
}

a.black_link_underline {
    text-decoration: underline !important;
    color: #000000;
    transition: all 0.3s ease;
}

a.black_link_underline:hover {
    color: var(--dienst-700);
    text-decoration: underline !important;
}

.lees_meer_over {
    font-weight: 300;
}


/* Shortcode : [subdiensten_mega_menu] */
#subdiensten_mega_menu {
    border: none;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    padding: 0;
    max-width: 100%;
    max-height: 700px;
    overflow: hidden;
    margin-top: 10vh;
    margin-bottom: auto;
    animation: fade-out 0.3s ease-out;
}

#subdiensten_mega_menu:open {
    animation: fade-in 0.3s ease-out;
}

#subdiensten_mega_menu::backdrop {
    background: rgba(0, 0, 0, 0.5);
}

#subdiensten_mega_menu_content {
    display: grid;
    grid-template-columns: 1fr 400px;
    min-height: 400px;
}

#subdiensten_mega_menu_items {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 15px;
    background-color: #fcfcfc;
    overflow-y: auto;
    min-width: 650px;
}

/* No-images mode (980px - 1100px) */
#subdiensten_mega_menu_content.no-images-mode {
    grid-template-columns: 1fr;
    max-width: 650px;
    margin: 0 auto;
}

a#subdiensten_mega_menu_item, a#subdiensten_mega_menu_item_parent {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    transition: all 0.3s ease;
    padding: 10px 20px;
    text-decoration: none;
}

a#subdiensten_mega_menu_item:hover {
    background-color: #e6e6e6;
}

a#subdiensten_mega_menu_item_parent:hover {
    background-color: var(--hover-color) !important;
}

#subdiensten_mega_menu_item_content {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

#subdiensten_mega_menu_item_arrow {
    transform: rotate(180deg);
}

#subdiensten_mega_menu_item_arrow svg {
    transform: translateY(4px);
}

#subdiensten_mega_menu_item_title {
    font-size: 20px;
    font-weight: 900;
    color: #222222;
    padding: 0px;
    margin: 0px;
}

#subdiensten_mega_menu_item_title_parent {
    font-size: 20px;
    font-weight: 900;
    color: #fff;
    padding: 0px;
    margin: 0px;
}

#subdiensten_mega_menu_item_subtitle {
    font-size: 14px;
    font-weight: 400;
    color: #666666;
    padding: 0px;
    margin: 0px;
}

#subdiensten_mega_menu_item_subtitle_parent {
    font-size: 14px;
    font-weight: 400;
    color: #fff;
    padding: 0px;
    margin: 0px;
}

#subdiensten_mega_menu_items_list {
    list-style-type: none;
    padding: 0px;
    margin: 0px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 5px;
}

#subdiensten_mega_menu_image {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
}

@media screen and (max-width: 1100px) {
    #subdiensten_mega_menu_content {
        min-height: 100%;
    }
}


@media screen and (max-width: 979px) {
    #subdiensten_mega_menu {
        display: none;
    }
}

@keyframes fade-in {
    0% {
        opacity: 0;
        display: none;
    }

    100% {
        opacity: 1;
        display: block;
    }
}

@keyframes fade-out {
    0% {
        opacity: 1;
        display: block;
    }

    100% {
        opacity: 0;
        display: none;
    }
}

@keyframes backdrop-fade-in {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 0.25;
    }
}

/* Shortcode : [dienst_subdiensten_links] */
.gerelateerde_subdiensten {
    display: flex;
    gap: 10px;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 20px;
}

@media screen and (max-width: 480px) {
    .gerelateerde_subdiensten {
        flex-direction: column;
    }
}

.subdienst_button {
    display: flex;
    justify-content: center;
    align-items: center;
    color: white;
    font-size: 18px;
    font-weight: 800;
    transition: opacity 0.3s ease;
    padding: 8px 19px;
}

.subdienst_button:hover {
    opacity: 0.75;
}

@media screen and (max-width: 480px) {
    .subdienst_button {
        width: 100%;
        flex-grow: 1;
    }
}

.subdiensten_header {
    display: flex;
    flex-direction: column;
    gap: 15px;
    align-items: center;
    justify-content: center;
}

.subdiensten_header_subtitle {
    font-size: 16px;
    font-weight: 900;
    padding: 0px;
}

.subdiensten_header_title {
    font-size: 36px;
    font-weight: 800;
}

@media screen and (max-width: 980px) {
    .subdiensten_header_title {
        font-size: 30px;
    }
}

@media screen and (max-width: 768px) {
    .subdiensten_header_title {
        font-size: 24px;
    }
}

/* function dienst_3d_images_hero */
#dienst-3d-images-grid {
    display: flex;
    justify-content: center;
    align-items: center;
    perspective: 1600px;
    height: 400px;
    position: relative;
}

.dienst-3d-image-item {
    height: 350px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: 10px;
    transform-style: preserve-3d;
}

#dienst-3d-image-0 {
    border-radius: 0 10px 10px 0;
}

#dienst-3d-image-4 {
    border-radius: 10px 0 0 10px;
}


/* Shortcode : [referenties_grid] */

.referenties_filter_wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-bottom: 64px;
    flex-wrap: wrap;
}

.referenties_filter_label {
    font-weight: 200;
    font-size: 16px;
    color: #222222;
}

.referenties_filter_desktop {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

.referenties_filter_buttons {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

.referenties_filter_btn {
    padding: 0.75rem 1.5rem;
    border: none;
    background-color: rgba(255, 255, 255, 0.5);
    color: #222222;
    font-size: 20px;
    font-weight: 900;
    cursor: pointer;
    transition: all 0.3s ease;
    border-radius: 2px;

    &:hover {
        background-color: rgba(255, 255, 255, 0.75);
    }
}

.referenties_filter_btn.active {
    background-color: #E95F3E;
    color: white;
    pointer-events: none;
}

.referenties_filter_mobile {
    display: none;
}

.referenties_filter_select {
    padding: 0.75rem 1.5rem;
    border: none;
    background-color: rgba(255, 255, 255, 0.5);
    color: #222222;
    font-size: 18px;
    font-weight: 900;
    border-radius: 2px;
    cursor: pointer;
    min-width: 200px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 1.25em;
    padding-right: 3rem;
}

.referenties_grid_container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    padding: 0 0 2rem 0;
    align-items: stretch;
}

.referenties_grid_item {
    cursor: pointer;
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.referenties_grid_image {
    width: 100%;
    aspect-ratio: 1 / 1;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: 2px;
    position: relative;
    flex-shrink: 0;
}

.referenties_grid_overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: color-mix(in srgb, var(--overlay-color, #000000) 90%, transparent);
    opacity: 0;
    transition: opacity 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    border-radius: 2px;
}

.referenties_grid_item:hover .referenties_grid_overlay {
    opacity: 1;
}

.referenties_grid_overlay_content {
    text-align: center;
    color: white;
}

.referenties_grid_discipline {
    font-size: 18px;
    font-weight: 400;
    letter-spacing: 0.5px;
    margin: 0 0 0.5rem 0;
    color: white;
}

.referenties_grid_title {
    font-size: clamp(1.5rem, 1.169rem + 1.395vw, 2.25rem); /* 24px - 36px */
    font-weight: 900;
    color: white;
    margin: 0;
    line-height: 1.3;
}

.referenties_load_more_wrapper {
    display: flex;
    justify-content: center;
    padding: 2rem 0;
}

.referenties_load_more_btn {
    padding: 0.75rem 2.5rem;
    background-color: #F5F5F5;
    border: 0px solid red !important;
    color: #222222;
    font-size: 16px;
    font-weight: 300;
    cursor: pointer;
    transition: all 0.3s ease;
    border-radius: 2px;

    &:hover {
        background-color: #EAEAEA;
    }
}

@media screen and (max-width: 1024px) {
    .referenties_grid_container {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }
}

@media screen and (max-width: 767px) {
    .referenties_filter_desktop {
        display: none !important;
    }
    
    .referenties_filter_mobile {
        display: block;
        width: 100%;
    }
    
    .referenties_filter_select {
        width: 100%;
    }
    
    .referenties_filter_wrapper {
        flex-direction: column;
        align-items: stretch;
        gap: 0.75rem;
        margin-bottom: 48px;
    }
    
    .referenties_filter_label {
        text-align: left;
    }
    
    .referenties_grid_container {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }
}