/* =========================
   MPB FRONTEND BUILDER STYLES
   Automatische kolombreedtes in een row
========================= */

.mpb-section {
    margin-bottom: 30px;
    width: 100%;
}

.mpb-section-element {
    > [class^="container"] {
        padding: 0;
        margin: 0;
        width: 100%;
        max-width: 100%;
        .mpb-row.mpb-section {
            width: 100%;
        }
    }
}

/* ROWS */
.mpb-row {
    display: flex;
    flex-wrap: wrap;
    padding: var(--row-pad-d, 0);
    margin: var(--row-mar-d, 0);
    border-radius: var(--row-radius, 0);;
    width: inherit;
    box-sizing: border-box;
    .inner_row {
        display: flex;
        flex-wrap: wrap;
        gap: var(--row-gap, 1rem);
        position: relative;
    }
}
@media (max-width: 768px) {
    .mpb-row .inner_row {
        gap: 0;
    }
}

@media (max-width: 1024px) {
    .mpb-row {
        padding: var(--row-pad-t, 0);
        margin: var(--row-mar-t, 0);
    }
}

@media (max-width: 768px) {
    .mpb-row {
        padding: var(--row-pad-m, 0);
        margin: var(--row-mar-m, 0);
    }
}

/* COLS: automatische breedtes */
.mpb-col {
    box-sizing: border-box;
    min-width: 0;
    overflow: hidden; /* prevent swiper/carousel from stretching col */
    padding: var(--col-pad-d, 0);
    margin: var(--col-mar-d, 0);
    border-radius: var(--col-br-d, 0);
    flex: var(--col-w-d, 0%);
    align-self: stretch; /* stretch zodat alle cols even hoog zijn */
    max-width: var(--col-w-d, 100%);
    &.va-center {
        display: flex;
        align-items: center;
    }
    &.va-bottom {
        display: flex;
        align-items: flex-end;
    }
    .mpb-section {
        [class^="container"] {
            padding: 0;
        }
    }
}

.mpb-col-inner {
    width: 100%; /* altijd passend in de col */
    display: flex;
    flex-direction: column;
    height: 100%; /* nodig voor align-self:flex-end op componenten */
}


@media (max-width: 1024px) {
    .mpb-col {
        padding: var(--col-pad-t, var(--col-pad-d, 0));
        margin: var(--col-mar-t, var(--col-mar-d, 0));
        flex-basis: var(--col-w-t, 0%);
        max-width: var(--col-w-t, 100%);
        border-radius: var(--col-br-t, var(--col-br-d, 0));
    }
}

@media (max-width: 768px) {
    .mpb-col {
        padding: var(--col-pad-m, var(--col-pad-d, 0));
        margin: var(--col-mar-m, var(--col-mar-d, 0));
        flex-basis: var(--col-w-m, 0%);
        max-width: var(--col-w-m, 100%);
        border-radius: var(--col-br-m, var(--col-br-d, 0));
    }
}

/* COMPONENTS */
.mpb-component {
    box-sizing: border-box;
    padding: var(--pad-d, 0);
    margin: var(--mar-d, 0 0 30px 0);
    width: var(--width-d, auto);
    border-radius: var(--radius-d, 0);
    max-width: 100%;   /* nooit groter */
    word-break: break-word;
    p {
        &:last-of-type {
            margin: 0;
        }
    }
}

.mpb-image img {
    display: block;
    width: 100%;
    object-fit: cover;
    height: var(--img-h-d, auto);
    object-position: var(--img-pos-x-d, 50%) var(--img-pos-y-d, 50%);
    border-radius: var(--img-br-d);
}

@media (max-width: 1024px) {
    .mpb-component {
        padding: var(--pad-t, var(--pad-d, 0));
        margin: var(--mar-t, var(--mar-d, 0 0 30px 0));
        width: var(--width-t, var(--width-d, auto));
        border-radius: var(--radius-t, var(--radius-d, 0));
    }
    .mpb-image img {
        width: var(--img-size-t, var(--img-size-d, 100%));
        height: var(--img-h-t, auto);
        object-position: var(--img-pos-x-t, 50%) var(--img-pos-y-t, 50%);
        border-radius: var(--img-br-t);
    }
}

@media (max-width: 768px) {
    .mpb-component {
        padding: var(--pad-m, var(--pad-d, 0));
        margin: var(--mar-m, var(--mar-t, var(--mar-d, 0 0 25px 0)));
        width: var(--width-m, var(--width-d, auto));
        border-radius: var(--radius-m, var(--radius-d, 0));
    }
    .mpb-image img {
        width: var(--img-size-m, var(--img-size-t, var(--img-size-d, 100%)));
        height: var(--img-h-m, auto);
        object-position: var(--img-pos-x-m, 50%) var(--img-pos-y-m, 50%);
        border-radius: var(--img-br-m);
    }
}

/* ELEMENT REF */
.mpb-element-ref {
    display: flex;
    flex-wrap: wrap;
    gap: var(--row-gap, 1rem);
    padding: var(--row-pad-d, 0);
    margin: var(--row-mar-d, 0);
    box-sizing: border-box;
}
/* ================================
   ACCORDION COMPONENT
   ================================ */
.mpb-accordion {
    width: 100%;
}
.mpb-accordion-item {
    border-bottom: 1px solid #e0e0e0;
}
.mpb-accordion-item:first-child {
    border-top: 1px solid #e0e0e0;
}
.mpb-accordion-trigger {
    width: 100%;
    background: none;
    border: none;
    padding: 14px 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    font-size: inherit;
    font-weight: 600;
    text-align: left;
    gap: 12px;
}
.mpb-accordion-trigger:hover {
    opacity: 0.75;
}
.mpb-accordion-icon {
    font-size: 20px;
    line-height: 1;
    flex-shrink: 0;
    transition: transform 0.2s ease;
}
.mpb-accordion-trigger[aria-expanded="true"] .mpb-accordion-icon {
    transform: rotate(45deg);
}
.mpb-accordion-body {
    padding: 0 0 14px 0;
}
.mpb-accordion-body[hidden] {
    display: none;
}

/* ================================
   GALLERY COMPONENT
   ================================ */
.mpb-gallery {
    display: grid;
    gap: var(--gal-gap, 8px);
    grid-template-columns: repeat(var(--gal-cols-d, 3), 1fr);
}
.mpb-gallery-img-wrap {
    overflow: hidden;
    aspect-ratio: var(--gal-ar-d, auto);
}
.mpb-gallery-img-wrap img {
    width: 100%;
    /* Als --gal-ar-d actief is (niet 'auto'), vul dan de wrap volledig */
    height: var(--gal-h-d, auto);
    object-fit: var(--gal-fit, cover);
    display: block;
    transition: transform 0.2s ease;
}
/* Wanneer aspect-ratio gebruikt wordt: img neemt volledige hoogte van wrap */
.mpb-gallery-img-wrap:where([style*="aspect-ratio"]) img,
.mpb-gallery img.mpb-gallery-img-ar {
    height: 100% !important;
}
.mpb-gallery-img-wrap img:hover {
    transform: scale(1.02);
}
@media (max-width: 1024px) {
    .mpb-gallery { grid-template-columns: repeat(var(--gal-cols-t, 2), 1fr); gap: var(--gal-gap-t, var(--gal-gap, 8px)); }
    .mpb-gallery-img-wrap { aspect-ratio: var(--gal-ar-t, var(--gal-ar-d, auto)); }
    .mpb-gallery-img-wrap img { height: var(--gal-h-t, auto); }
}
@media (max-width: 480px) {
    .mpb-gallery { grid-template-columns: repeat(var(--gal-cols-m, 1), 1fr); gap: var(--gal-gap-m, var(--gal-gap-t, var(--gal-gap, 8px))); }
    .mpb-gallery-img-wrap { aspect-ratio: var(--gal-ar-m, var(--gal-ar-t, var(--gal-ar-d, auto))); }
    .mpb-gallery-img-wrap img { height: var(--gal-h-m, auto); }
}

/* ================================
   BUTTONS COMPONENT
   ================================ */
.mpb-buttons-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: var(--btn-gap-d, 10px);
    align-items: center;
}
@media (max-width: 1024px) {
    .mpb-buttons-wrap { gap: var(--btn-gap-t, var(--btn-gap-d, 10px)); }
}
@media (max-width: 480px) {
    .mpb-buttons-wrap { gap: var(--btn-gap-m, var(--btn-gap-t, var(--btn-gap-d, 10px))); }
}
.mpb-buttons-wrap .btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    cursor: pointer;
    border: none;
    font-size: inherit;
    transition: opacity 0.15s ease;
}
.mpb-buttons-wrap .btn:hover {
    opacity: 0.85;
}

/* Buttons: volledig breed op mobiel */
@media (max-width: 480px) {
    .mpb-buttons-mobile-fullwidth .btn {
        width: 100%;
        justify-content: center;
        box-sizing: border-box;
    }
    .mpb-buttons-mobile-fullwidth {
        flex-direction: column;
    }
}

/* ================================
   TABS COMPONENT (frontend)
   ================================ */
.mpb-tabs {}
.mpb-tabs-nav, .mpb-tab-titles {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    border-bottom: 2px solid #0073aa;
    overflow-y: hidden;
}
.mpb-tab-trigger {
    padding: 8px 18px;
    background: #f0f0f0;
    color: #333;
    border: none;
    border-radius: 4px 4px 0 0;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: background 0.15s, color 0.15s;
    margin-bottom: -2px;
}
.mpb-tab-trigger:hover {
    background: #ddd;
}
.mpb-tab-trigger.is-active {
    background: #0073aa;
    color: #fff;
    font-weight: 600;
}
.mpb-tabs-content {
    border: 1px solid #0073aa;
    border-top: none;
    padding: 20px;
}
.mpb-tab-panel[hidden] {
    display: none;
}

/* ================================
   BANNER COMPONENT
   ================================ */
.mpb-banner {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.mpb-banner-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
}
.mpb-banner-content {
    position: relative;
    z-index: 2;
}
.mpb-banner-content p { color: inherit; }

/* ================================
   IMAGE OVERLAY
   ================================ */
.mpb-image { position: relative; overflow: hidden; }
.mpb-img-overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
}

/* ================================
   VIDEO COMPONENT
   ================================ */
.mpb-video { width: 100%; }
.mpb-video-thumb-wrap { cursor: pointer; }
.mpb-video-play-btn {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.2s;
}
.mpb-video-thumb-wrap:hover .mpb-video-play-btn { opacity: 0.85; }

/* ================================
   CUSTOM BG / BG-IMAGE
   ================================ */
[style*="--mpb-bg:"] { background: var(--mpb-bg) !important; color: var(--mpb-tc) !important; }

/* ================================
   GALLERY MOBILE LAYOUT
   ================================ */
@media (max-width: 480px) {
    .mpb-gallery.mobile-row {
        /* Naast elkaar: horizontal scroll */
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        overflow-y: visible !important;
        -webkit-overflow-scrolling: touch;
        gap: var(--gal-gap-m, 8px) !important;
        /* Reset grid */
        grid-template-columns: unset !important;
    }
    .mpb-gallery.mobile-row .mpb-gallery-img-wrap {
        flex: 0 0 auto !important;
        width: 70vw !important;
        max-width: 280px !important;
        min-width: 120px;
    }
    .mpb-gallery.mobile-stack {
        grid-template-columns: 1fr !important;
    }
}

/* ================================
   IMAGE FULLHEIGHT
   ================================ */
.mpb-image[style*="--img-fullheight:1"] picture,
.mpb-image[style*="--img-fullheight:1"] img {
    height: 100% !important;
    width: 100%;
    object-fit: cover;
    display: block;
}
.mpb-image[style*="--img-fullheight:1"] {
    height: 100%;
    display: flex;
}
/* Op kleinere schermen: terug naar auto hoogte */
@media (max-width: 768px) {
    .mpb-image[style*="--img-fullheight:1"] picture,
    .mpb-image[style*="--img-fullheight:1"] img {
        height: auto !important;
    }
    .mpb-image[style*="--img-fullheight:1"] {
        height: auto;
    }
}

/* ================================
   COMPONENT VISIBILITY PER DEVICE
   ================================ */
@media (min-width: 1025px) {
    .mpb-hide-desktop { display: none !important; }
}
@media (min-width: 481px) and (max-width: 1024px) {
    .mpb-hide-tablet { display: none !important; }
}
@media (max-width: 480px) {
    .mpb-hide-mobile { display: none !important; }
}

/* ================================
   PRIJSLIJST
   ================================ */
.mpb-pricelist { width: 100%; }

/* ============================================================
   CARDS COMPONENT
   ============================================================ */
.mpb-cards {
    display: grid;
    grid-template-columns: repeat(var(--cards-cols-d, 3), 1fr);
    gap: var(--cards-gap, 20px);
}
@media (max-width: 1024px) {
    .mpb-cards { grid-template-columns: repeat(var(--cards-cols-t, 2), 1fr); }
}
@media (max-width: 480px) {
    .mpb-cards { grid-template-columns: repeat(var(--cards-cols-m, 1), 1fr); }
}

/* Grid van cards */
.mpb-pricelist-grid {
    display: grid;
    grid-template-columns: repeat(var(--pl-cols-d, 3), 1fr);
    gap: var(--pl-gap-d, 20px);
}
@media (max-width: 1024px) {
    .mpb-pricelist-grid { grid-template-columns: repeat(var(--pl-cols-t, 2), 1fr); gap: var(--pl-gap-t, 16px); }
}
@media (max-width: 480px) {
    .mpb-pricelist-grid { grid-template-columns: repeat(var(--pl-cols-m, 1), 1fr); gap: var(--pl-gap-m, 12px); }
}

/* Individuele card */
.mpb-pl-card {
    border: 1px solid #e0e0e0;
    border-radius: var(--pl-rad-d, 8px);
    padding: var(--pl-pad-d, 24px 20px);
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: #fff;
}
/* Fix 2B: Items nemen beschikbare ruimte in, prijs/button zakken naar beneden */
.mpb-pl-card .mpb-pl-items {
    flex: 1;
}
.mpb-pl-card-title {
    font-size: 1.2em;
    font-weight: 700;
    margin: 0;
}
.mpb-pl-card-desc {
    font-size: 0.9em;
    color: #666;
}

/* Items binnen een card */
.mpb-pl-items {
    list-style: none;
    padding: 0;
    margin: 0;
    flex: 1;
}
.mpb-pl-item {
    display: flex;
    align-items: baseline;
    gap: 6px;
    padding: 6px 0;
    border-bottom: 1px solid currentColor;
    opacity: 0.9;
    font-size: 0.9em;
}
.mpb-pl-item:last-child { border-bottom: none; }
.mpb-pl-name  { flex: 0 0 auto; }
.mpb-pl-sep   { flex: 1; min-width: 16px; }
.mpb-pl-dots  { border-bottom: 2px dotted #ccc; height: 1px; display: block; position: relative; top: -4px; }
.mpb-pl-line  { border-bottom: 1px solid #ccc;  height: 1px; display: block; position: relative; top: -4px; }
.mpb-pl-price { flex: 0 0 auto; font-weight: 600; }

/* Totaalprijs */
.mpb-pl-total {
    display: flex;
    flex-direction: column;
    align-items: center;
    border-top: 2px solid #e0e0e0;
    padding-top: 12px;
    text-align: center;
    margin-top: auto; /* altijd onderin */
}
.mpb-pl-total-price {
    font-size: 1.8em;
    font-weight: 800;
    line-height: 1.1;
}
.mpb-pl-price-label {
    font-size: 0.8em;
    color: #888;
}

/* Button */
.mpb-pl-btn-wrap {
    text-align: center;
}
/* Button at bottom when no total price above it */
.mpb-pl-card > .mpb-pl-btn-wrap:not(:is(.mpb-pl-total + .mpb-pl-btn-wrap)) {
    margin-top: auto;
}

/* Voetnoot */
.mpb-pl-footnote {
    font-size: 0.78em;
    color: #aaa;
    text-align: center;
}

/* ================================
   RESPONSIVE COL STANDAARD
   Alle cols 100% op tablet/mobiel
   tenzij een harde breedte is bepaald
   ================================ */
@media (max-width: 768px) {
    .mpb-col {
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }
    .inner_row {
        flex-wrap: wrap;
    }
}

/* ================================
   LIJST COMPONENT
   ================================ */

/* Basis item layout */
.mpb-list-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 0;
}

/* Icon */
.mpb-list-icon {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    /* kleur wordt per-component via #list_id .mpb-list-icon { color } ingesteld */
}
.mpb-list-icon-svg {
    width: 16px;
    height: 16px;
    display: block;
}
.mpb-list-icon--number {
    font-weight: 700;
    min-width: 22px;
}

/* Tekst */
.mpb-list-text {
    line-height: 1.4;
}

/* Link stijl */
.mpb-list-link {
    display: flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    color: inherit;
}
.mpb-list-link:hover .mpb-list-text {
    text-decoration: underline;
}

/* Inline layout: items naast elkaar */
.mpb-list--inline .mpb-list-item {
    display: inline-flex;
}

/* Grid layout: items are block (display:grid set via compiled CSS on #list_ID) */
.mpb-list--grid {
    display: grid; /* fallback — compiled CSS overrides per ID */
    grid-template-columns: repeat(1, 1fr);
}

/* ================================
   TIJDLIJN COMPONENT
   ================================ */
.mpb-timeline {
    position: relative;
    padding-left: 60px;
}
.mpb-tl-track {
    position: absolute;
    left: 28px;
    top: 12px;
    bottom: 12px;
    width: 3px;
    border-radius: 3px;
    overflow: hidden;
    /* min-height nodig voor overflow:hidden + percentage-height fill */
    min-height: 10px;
}
.mpb-tl-fill {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 0%;
    border-radius: 3px;
    transition: height 0.1s linear;
}
.mpb-tl-item {
    position: relative;
    padding: 0 0 32px 20px;
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto 1fr;
    gap: 0 16px;
    align-items: start;
}
.mpb-tl-dot {
    position: absolute;
    left: -7px;
    top: 8px;
    width: 15px;
    height: 15px;
    border-radius: 50%;
    border: 2px solid;
    background: #fff;
    z-index: 1;
}
.mpb-tl-label {
    grid-column: 1;
    grid-row: 1;
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    border-radius: 20px;
    font-weight: 700;
    font-size: 14px;
    white-space: nowrap;
    align-self: start;
    margin-bottom: 8px;
}
.mpb-tl-content {
    grid-column: 2;
    grid-row: 1 / 3;
    padding-top: 4px;
    line-height: 1.6;
}

@media (max-width: 600px) {
    .mpb-timeline { padding-left: 44px; }
    .mpb-tl-track { left: 18px; }
    .mpb-tl-label { font-size: 12px; padding: 3px 8px; }
}

/* List: Dashicons custom icon (laad dashicons ook op frontend) */
.mpb-list--custom_icon .mpb-list-icon {
    font-size: 20px;
    flex: 0 0 auto;
}

/* List: eigen afbeelding */
.mpb-list-icon-img {
    object-fit: contain;
    display: inline-block;
    vertical-align: middle;
    flex: 0 0 auto;
}

/* ================================
   IMAGE FULLHEIGHT (Bug 9)
   Gebruik align-stretch zodat de col-inner de hoogte deelt
   ================================ */
.mpb-image--fullheight {
    height: 100%;
    display: flex;
    flex-direction: column;
}
.mpb-image--fullheight picture {
    flex: 1;
    display: flex;
}
.mpb-image--fullheight picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
/* Zet de parent col-inner ook op stretch zodat hij hoogte aanneemt */
.mpb-col:has(.mpb-image--fullheight) > .mpb-col-inner {
    display: flex;
    flex-direction: column;
    height: 100%;
}
.mpb-col:has(.mpb-image--fullheight) {
    align-self: stretch;
}
/* Mobiel: normale hoogte */
@media (max-width: 768px) {
    .mpb-image--fullheight,
    .mpb-image--fullheight picture img {
        height: auto !important;
    }
}

/* ============================================================
   IMAGE ASPECT RATIO
   Aspect ratio op picture zelf, img erft hoogte van parent
   ============================================================ */
.mpb-image picture {
    display: block;
    aspect-ratio: var(--img-ar-d, auto);
    overflow: hidden;
}
@media (max-width: 1024px) {
    .mpb-image picture { aspect-ratio: var(--img-ar-t, var(--img-ar-d, auto)); }
}
@media (max-width: 480px) {
    .mpb-image picture { aspect-ratio: var(--img-ar-m, var(--img-ar-t, var(--img-ar-d, auto))); }
}
/* Wanneer aspect-ratio actief is: img vult picture volledig */
.mpb-image:is([style*="--img-ar-d"], [style*="--img-ar-t"], [style*="--img-ar-m"]) picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Gallery: when aspect-ratio var is set, images fill the wrap height */
.mpb-gallery .mpb-gallery-img-wrap {
    /* Force img to fill height when aspect-ratio is active */
}
/* Use JS-added class or rely on: if wrap has explicit aspect-ratio, img fills it */
.mpb-gallery-img-wrap:not([style]) img {
    /* No inline style = no AR set = use height var */
}
/* Simpelste oplossing: altijd height:100% als de wrap een aspect-ratio heeft via CSS var */
@supports (aspect-ratio: 1) {
    .mpb-gallery-img-wrap img {
        /* Als ar var ingesteld is (niet auto), height:100% */
        height: var(--gal-ar-img-h, var(--gal-h-d, auto));
    }
}

/* ============================================================
   TABS POSITIE (boven/onder/links/rechts) + mobiel
   ============================================================ */
.mpb-tabs {
    display: flex;
    flex-direction: column;
}
.mpb-tabs.tabs-pos-bottom { flex-direction: column-reverse; }
.mpb-tabs.tabs-pos-left   { flex-direction: row; align-items: flex-start; }
.mpb-tabs.tabs-pos-right  { flex-direction: row-reverse; align-items: flex-start; }
/* Links/rechts: geen border-bottom op nav, border-right ipv */
.mpb-tabs.tabs-pos-left .mpb-tabs-nav,
.mpb-tabs.tabs-pos-left .mpb-tab-titles,
.mpb-tabs.tabs-pos-right .mpb-tabs-nav,
.mpb-tabs.tabs-pos-right .mpb-tab-titles {
    border-bottom: none;
    border-right: 2px solid #0073aa;
    flex-direction: column;
}
.mpb-tabs.tabs-pos-right .mpb-tabs-nav,
.mpb-tabs.tabs-pos-right .mpb-tab-titles {
    border-right: none;
    border-left: 2px solid #0073aa;
}

/* Links/rechts: tabs wrapper breedte via CSS var */
.mpb-tabs.tabs-pos-left .mpb-tab-titles, .mpb-tabs.tabs-pos-left .mpb-tabs-nav,
.mpb-tabs.tabs-pos-right .mpb-tab-titles, .mpb-tabs.tabs-pos-right .mpb-tabs-nav {
    flex: 0 0 var(--tabs-w-d, 200px);
    display: flex;
    flex-direction: column;
}
.mpb-tabs.tabs-pos-left .mpb-tab-titles button, .mpb-tabs.tabs-pos-left .mpb-tabs-nav button,
.mpb-tabs.tabs-pos-right .mpb-tab-titles button, .mpb-tabs.tabs-pos-right .mpb-tabs-nav button {
    width: 100%;
}
.mpb-tabs.tabs-pos-left .mpb-tab-content, .mpb-tabs.tabs-pos-left .mpb-tabs-content,
.mpb-tabs.tabs-pos-right .mpb-tab-content, .mpb-tabs.tabs-pos-right .mpb-tabs-content {
    flex: 1 1 auto;
    min-width: 0;
}

@media (max-width: 1024px) {
    .mpb-tabs.tabs-pos-left .mpb-tab-titles,
    .mpb-tabs.tabs-pos-right .mpb-tab-titles {
        flex-basis: var(--tabs-w-t, var(--tabs-w-d, 200px));
    }
}

/* Mobiel: altijd onder elkaar, volbreedte buttons */
@media (max-width: 480px) {
    .mpb-tabs.tabs-pos-left,
    .mpb-tabs.tabs-pos-right {
        flex-direction: column !important;
    }
    /* Nav: volbreedte, horizontale buttons */
    .mpb-tabs .mpb-tab-titles,
    .mpb-tabs .mpb-tabs-nav {
        flex: none !important;
        flex-direction: row !important;
        flex-wrap: wrap;
        border-right: none !important;
        border-left: none !important;
        border-bottom: 2px solid #0073aa !important;
        width: 100% !important;
        overflow-y: hidden;
    }
    /* Content: fix 2 — altijd volbreedte */
    .mpb-tabs .mpb-tabs-content {
        width: 100% !important;
        flex: 1 1 auto !important;
        min-width: 0 !important;
    }
    .mpb-tabs .mpb-tab-titles button,
    .mpb-tabs .mpb-tabs-nav button {
        flex: 1 1 auto;
    }
    /* Fix 3: Mobiel horizontaal scrollen — buttons op eigen breedte */
    .mpb-tabs.tabs-mobile-scroll .mpb-tab-titles,
    .mpb-tabs.tabs-mobile-scroll .mpb-tabs-nav {
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        -webkit-overflow-scrolling: touch;
    }
    .mpb-tabs.tabs-mobile-scroll .mpb-tab-titles button,
    .mpb-tabs.tabs-mobile-scroll .mpb-tabs-nav button {
        flex: 0 0 auto !important;
        width: auto !important;
        padding-left: 12px;
        padding-right: 12px;
        white-space: nowrap;
    }
}

/* ============================================================
   VIDEO OVERLAY (tekst over video)
   ============================================================ */
.mpb-video-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: var(--ov-justify, center);
    align-items: var(--ov-align, center);
    background: var(--ov-bg, rgba(0,0,0,0.6));
    color: var(--ov-color, #fff);
    padding: var(--ov-pad-d, 20px);
    text-align: var(--ov-text-align, center);
    z-index: 3;
    pointer-events: none;
}
.mpb-video-overlay .mpb-ov-inner {
    max-width: var(--ov-mw, 100%);
    width: 100%;
}

/* Pricelist check icon per item */
.mpb-pl-check {
    color: var(--color-primary, #0073aa);
    font-weight: 700;
    flex: 0 0 auto;
    margin-right: 4px;
}

/* ── BG-image row: overlay via ::before (gegenereerd als CSS vars via PHP) ── */


/* ── BG-image layer: absolute div in de row ── */
.mpb-row.mpb-has-bg-image {
    position: relative;
}
.mpb-bg-layer {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}
.mpb-bg-layer picture {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
}
.mpb-bg-layer img.mpb-bg-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: var(--bg-pos-d, 50% 50%);
    display: block;
    pointer-events: none;
    user-select: none;
}
@media (max-width: 1024px) {
    .mpb-bg-layer img.mpb-bg-img {
        object-position: var(--bg-pos-t, var(--bg-pos-d, 50% 50%));
    }
}
@media (max-width: 480px) {
    .mpb-bg-layer img.mpb-bg-img {
        object-position: var(--bg-pos-m, var(--bg-pos-d, 50% 50%));
    }
}
.mpb-bg-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
}
/* container staat altijd boven de bg-layer */
.mpb-row.mpb-has-bg-image > .container {
    position: relative;
    z-index: 2;
}

/* ================================
   GALLERY CAROUSEL (SwiperJS)
   ================================ */
.mpb-gallery-carousel {
    width: 100%;
    max-width: 100%;
    min-width: 0;        /* prevent flex/grid children from overflowing */
    overflow: hidden;
    box-sizing: border-box;
    contain: layout;    /* strict layout containment */
}
.mpb-gallery-carousel .swiper {
    display: block;
    width: 100% !important;
    max-width: 100%;
    overflow: hidden;
    box-sizing: border-box;
}
.mpb-gallery-carousel .swiper-slide {
    box-sizing: border-box;
}
.mpb-gallery-carousel .swiper-slide img {
    width: 100%;
    display: block;
    object-fit: cover;
}

/* ================================
   GALLERY GRID (masonry)
   ================================ */
.mpb-gallery-grid {
    display: block !important; /* override .mpb-gallery display:grid — masonry gebruikt column-count */
    column-count: 3; /* fallback — overschreven door inline #ID CSS */
    column-gap: var(--gal-gap, 8px);
}
.mpb-gallery-grid .mpb-gal-mitem {
    break-inside: avoid;
    display: inline-block; /* required for column-count masonry */
    width: 100%;
    margin-bottom: var(--gal-gap, 8px);
}
.mpb-gallery-grid .mpb-gal-mitem img {
    width: 100%;
    display: block;
    border-radius: 4px;
    height: auto; /* CRITICAL: auto height for masonry portrait/landscape mix */
}

/* ===== Uniforme Swiper navigatie voor alle carousels ===== */
.mpb-gallery-carousel,
.mpb-cards-carousel,
.mpb-carousel {
    position: relative;
    /* Prevent swiper from stretching parent flex/grid cells */
    width: 100%;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    box-sizing: border-box;
    display: block !important; /* override .mpb-cards { display:grid } */
}

/* Force all swiper wrappers inside mpb columns to be contained */
.mpb-col .swiper,
.mpb-col-inner .swiper,
.mpb-section .swiper {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

/* Prevent swiper-wrapper from going wider than its container */
.mpb-col .swiper-wrapper,
.mpb-col-inner .swiper-wrapper {
    width: 100%;
    box-sizing: border-box;
}

/* Critical: mpb-col must not grow beyond flex allocation */
.mpb-col {
    min-width: 0;
    overflow: hidden;
}
.mpb-gallery-carousel .swiper-button-prev,
.mpb-gallery-carousel .swiper-button-next,
.mpb-cards-carousel .swiper-button-prev,
.mpb-cards-carousel .swiper-button-next,
.mpb-carousel .swiper-button-prev,
.mpb-carousel .swiper-button-next,
.mpb-reviews-carousel .swiper-button-prev,
.mpb-reviews-carousel .swiper-button-next {
    width: 38px;
    height: 38px;
    background: rgba(255,255,255,0.92);
    border-radius: 50%;
    box-shadow: 0 2px 6px rgba(0,0,0,0.18);
    color: #222;
    top: 50%;
    transform: translateY(-50%);
}
.mpb-gallery-carousel .swiper-button-prev::after,
.mpb-gallery-carousel .swiper-button-next::after,
.mpb-cards-carousel .swiper-button-prev::after,
.mpb-cards-carousel .swiper-button-next::after,
.mpb-carousel .swiper-button-prev::after,
.mpb-carousel .swiper-button-next::after,
.mpb-reviews-carousel .swiper-button-prev::after,
.mpb-reviews-carousel .swiper-button-next::after {
    font-size: 14px;
    font-weight: 700;
}

/* Equal height cards */
.mpb-cards--equal-h .card_wrapper,
.mpb-cards--equal-h .mpb-card-item {
    height: 100%;
    display: flex;
    flex-direction: column;
}
.mpb-cards--equal-h .card_wrapper .card,
.mpb-cards--equal-h .mpb-card-item > * {
    flex: 1;
    display: flex;
    flex-direction: column;
}
/* img_base must fill full height so image stretches too */
.mpb-cards--equal-h .card_wrapper .img_base {
    height: 100%;
    display: flex;
    flex-direction: column;
}
/* For left/right type: picture and img fill the image column */
.mpb-cards--equal-h .card_wrapper .img_base .img picture,
.mpb-cards--equal-h .card_wrapper .img_base .img picture img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    display: block;
}

/* Equal height for review grid */
.mpb-reviews-grid.mpb-reviews--equal-h {
    align-items: stretch;
}
.mpb-reviews-grid.mpb-reviews--equal-h .mpb-review-card {
    height: 100%;
    display: flex;
    flex-direction: column;
}
.mpb-reviews-grid.mpb-reviews--equal-h .mpb-review-text {
    flex: 1;
}

/* Equal height for carousel slides */
.mpb-cards-carousel.mpb-cards--equal-h .swiper-slide {
    height: auto;
    display: flex;
    flex-direction: column;
}
.mpb-cards-carousel.mpb-cards--equal-h .swiper-wrapper {
    align-items: stretch;
}
.mpb-cards-carousel.mpb-cards--equal-h .card_wrapper,
.mpb-cards-carousel.mpb-cards--equal-h .card {
    height: 100%;
    display: flex;
    flex-direction: column;
}

/* ===== Review component ===== */
.mpb-reviews-grid {
    display: grid;
    grid-template-columns: repeat(var(--rev-cols-d, 3), 1fr);
    gap: 20px;
}
@media (max-width: 1024px) { .mpb-reviews-grid { grid-template-columns: repeat(var(--rev-cols-t, 2), 1fr); } }
@media (max-width: 480px)  { .mpb-reviews-grid { grid-template-columns: repeat(var(--rev-cols-m, 1), 1fr); } }

.mpb-review-card {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 8px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.mpb-review-stars { display: flex; gap: 2px; font-size: 20px; color: #ddd; }
.mpb-star--filled { color: #f4b400; }
.mpb-review-title { margin: 0; font-size: 1.05em; }
.mpb-review-text { flex: 1; font-size: 0.95em; line-height: 1.6; color: #444; }
.mpb-review-author-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: auto;
    padding-top: 12px;
    border-top: 1px solid currentColor;
}
.mpb-review-author-img {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}
.mpb-review-author-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
    min-width: 0;
}
.mpb-review-author-name { font-weight: 600; font-size: 0.88em; }
.mpb-review-company { font-size: 0.8em; color: #888; }
.mpb-review-logo { margin-left: auto; flex-shrink: 0; object-fit: contain; }

/* Dots pagination: always below carousel content */
.mpb-reviews-carousel .swiper-pagination,
.mpb-cards-carousel .swiper-pagination,
.mpb-gallery-carousel .swiper-pagination,
.mpb-carousel .swiper-pagination {
    position: relative;
    bottom: auto;
    margin-top: 12px;
    display: block;
}
/* Extra bottom padding on wrap div for dots */
[id^="revwrap_"] .swiper-pagination,
[id^="csw_wrap_"] .swiper-pagination,
[id^="sw_wrap_"] .swiper-pagination,
[id^="carwrap_"] .swiper-pagination {
    position: relative !important;
    bottom: auto !important;
    margin-top: 10px;
}

/* ===== Breadcrumbs component ===== */
.mpb-breadcrumbs { padding: 6px 0; }
.mpb-bc-list {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
    font-size: 0.875em;
}
.mpb-bc-list.mpb-bc-align-center { justify-content: center; }
.mpb-bc-list.mpb-bc-align-right  { justify-content: flex-end; }
.mpb-bc-list a { color: inherit; text-decoration: underline; opacity: 0.7; }
.mpb-bc-list a:hover { opacity: 1; }
.mpb-bc-sep { opacity: 0.4; }
.mpb-bc-current { opacity: 0.5; }

/* ================================================
   MPB SCROLL ANIMATIONS
   ================================================ */
[data-mpb-animate] {
    opacity: 0;
    will-change: opacity, transform;
}
[data-mpb-animate][data-anim-type="slide"][data-anim-dir="up"]    { transform: translateY(var(--anim-dist, 25px)); }
[data-mpb-animate][data-anim-type="slide"][data-anim-dir="down"]  { transform: translateY(calc(-1 * var(--anim-dist, 25px))); }
[data-mpb-animate][data-anim-type="slide"][data-anim-dir="left"]  { transform: translateX(var(--anim-dist, 25px)); }
[data-mpb-animate][data-anim-type="slide"][data-anim-dir="right"] { transform: translateX(calc(-1 * var(--anim-dist, 25px))); }
[data-mpb-animate][data-anim-type="fade"][data-anim-dir="up"]    { transform: translateY(var(--anim-dist, 25px)); }
[data-mpb-animate][data-anim-type="fade"][data-anim-dir="down"]  { transform: translateY(calc(-1 * var(--anim-dist, 25px))); }
[data-mpb-animate][data-anim-type="fade"][data-anim-dir="left"]  { transform: translateX(var(--anim-dist, 25px)); }
[data-mpb-animate][data-anim-type="fade"][data-anim-dir="right"] { transform: translateX(calc(-1 * var(--anim-dist, 25px))); }
[data-mpb-animate][data-anim-type="zoom"]  { transform: scale(0.85); }
[data-mpb-animate][data-anim-type="flip"]  { transform: perspective(600px) rotateX(15deg); }

[data-mpb-animate].mpb-anim-visible {
    opacity: 1 !important;
    transform: none !important;
    transition-property: opacity, transform;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

/* Fade */
[data-mpb-animate][data-anim-type="fade"] { opacity: 0; }
/* Slide directions */
[data-mpb-animate][data-anim-type="slide"][data-anim-dir="up"]    { transform: translateY(var(--anim-dist, 25px)); }
[data-mpb-animate][data-anim-type="slide"][data-anim-dir="down"]  { transform: translateY(calc(-1 * var(--anim-dist, 25px))); }
[data-mpb-animate][data-anim-type="slide"][data-anim-dir="left"]  { transform: translateX(var(--anim-dist, 25px)); }
[data-mpb-animate][data-anim-type="slide"][data-anim-dir="right"] { transform: translateX(calc(-1 * var(--anim-dist, 25px))); }
/* Fade + slide (combined) */
[data-mpb-animate][data-anim-type="fade"][data-anim-dir="up"]    { transform: translateY(var(--anim-dist, 25px)); }
[data-mpb-animate][data-anim-type="fade"][data-anim-dir="down"]  { transform: translateY(calc(-1 * var(--anim-dist, 25px))); }
[data-mpb-animate][data-anim-type="fade"][data-anim-dir="left"]  { transform: translateX(var(--anim-dist, 25px)); }
[data-mpb-animate][data-anim-type="fade"][data-anim-dir="right"] { transform: translateX(calc(-1 * var(--anim-dist, 25px))); }
/* Zoom */
[data-mpb-animate][data-anim-type="zoom"] { transform: scale(0.85); }
/* Flip */
[data-mpb-animate][data-anim-type="flip"] { transform: perspective(600px) rotateX(20deg); }

/* Carousel overflow fix — NEVER allow carousel to break out of its container */
.mpb-component.mpb-card .swiper,
.mpb-component.mpb-gallery .swiper,
.swiper-container-mpb {
    overflow: hidden !important;
    max-width: 100% !important;
    width: 100% !important;
}
.mpb-col-inner .swiper {
    overflow: hidden !important;
    max-width: 100% !important;
}
.swiper-wrapper {
    width: 100%;
}

/* Fix 2: remove bottom margin from last component in col — prevents double spacing */
.mpb-col-inner > .mpb-component:last-child {
    --mar-d: 0px 0px 0px 0px !important;
    --mar-t: 0px 0px 0px 0px !important;
    --mar-m: 0px 0px 0px 0px !important;
    margin-bottom: 0 !important;
}
/* Also remove bottom margin from heading inside last component */
.mpb-col-inner > .mpb-component:last-child h1:last-child,
.mpb-col-inner > .mpb-component:last-child h2:last-child,
.mpb-col-inner > .mpb-component:last-child h3:last-child,
.mpb-col-inner > .mpb-component:last-child h4:last-child,
.mpb-col-inner > .mpb-component:last-child p:last-child {
    margin-bottom: 0;
}

/* ── Gallery border-radius ── */
.mpb-gallery-img-wrap img {
    border-radius: var(--gal-br-d, 0px);
}
.mpb-gallery-img-wrap {
    border-radius: var(--gal-br-d, 0px);
    overflow: hidden;
}
@media (max-width: 1024px) {
    .mpb-gallery-img-wrap img, .mpb-gallery-img-wrap { border-radius: var(--gal-br-t, var(--gal-br-d, 0px)); }
}
@media (max-width: 480px) {
    .mpb-gallery-img-wrap img, .mpb-gallery-img-wrap { border-radius: var(--gal-br-m, var(--gal-br-t, var(--gal-br-d, 0px))); }
}

/* ── Pricelist badge (4D) ── */
.mpb-pl-card {
    position: relative;
    overflow: visible !important;
}
/* Ensure grid wrapper allows badge to overflow */
.mpb-pl-grid {
    overflow: visible !important;
}
.mpb-pl-badge {
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-secondary, #f4b400);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 3px 14px;
    border-radius: 20px;
    white-space: nowrap;
    z-index: 10;
    box-shadow: 0 2px 6px rgba(0,0,0,.15);
}
/* Give cards with a badge extra top margin so badge is visible */
.mpb-pl-card:has(.mpb-pl-badge) {
    margin-top: 16px;
}

/* Pricelist fullwidth button */
.mpb-pl-btn-wrap .btn-block {
    display: flex !important;
    width: 100%;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    line-height: normal;
}

/* ── Pricelist price size and euro symbol ── */
.mpb-pl-total-price {
    margin: 0 !important;
    display: block;
}
/* h2-h6 classes inherit theme heading styles automatically — no extra rules needed */
.mpb-pl-euro {
    font-size: 0.6em;
    vertical-align: super;
    line-height: 1;
    margin-right: 1px;
}
