﻿.api_card {
    max-width: none;
    width: 100%;
}

.api_header {
    position: relative;
}

.api_header-graphic {
    position: absolute;
    left: 0;
    top: 0;
}

.api_header-text {
    grid-column: 1 / -1;
    text-align: center;
}

.api_q {
    padding: 10px 18px;
    border-radius: 28px;
}


.mv__squiggle-vert {
    top: 41px;
    /* bottom: 90px; */
    max-height: 409px;
    position: relative;
}

/* equal-height columns */
.content-layer .row.flex {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
}

    .content-layer .row.flex > [class*="col-"] {
        display: flex;
    }

/* card layout */
.single-feature {
    display: flex;
    flex-direction: column;
    height: 100%;
}

    /* push ONLY the link wrapper to the bottom (without messing the link itself) */
    .single-feature > a {
        margin-top: auto;
        display: inline-flex; /* stays not full width */
        align-self: flex-start; /* prevents full-width stretching */
        padding-top: 0; /* avoid pushing link text down */
    }

    /* if some existing css forces full width, this neutralizes it */
    .single-feature > a {
        width: auto;
        max-width: fit-content;
        margin-left: auto;
        margin-right: auto;
    }

/* --- About accordion: 2 columns (flex) --- */
.about-accordion__layout {
    display: flex;
    gap: 30px;
    align-items: stretch;
}

.about-accordion__col {
    flex: 1 1 0;
    min-width: 0;
    min-height: 360px !important;
}

/* --- Intro text --- */
.about-accordion__intro {
    color: #025db9 !important;
}

/* --- Lock both columns to same height as image --- */
.about-acc-col,
.about-accordion__col--image .accordion-image {
    height: 360px;
    max-height: 360px;
}

/* Left column becomes a flex container */
.about-acc-col {
    display: flex;
}

/* --- Accordion list layout --- */
.about-acc-list {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

    /* Items should not stretch */
    .about-acc-list .single-accordian {
        flex: 0 0 auto;
        display: flex;
        flex-direction: column;
    }

    /* Body scrolls if needed */
    .about-acc-list .accordian-body {
        overflow: auto;
    }

/* --- Image --- */
.about-accordion__col--image .accordion-image img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

/* --- Mobile --- */
@media (max-width: 1023px) {
    .about-accordion__layout {
        flex-direction: column;
    }

    .about-acc-col,
    .about-accordion__col--image .accordion-image {
        height: auto;
        max-height: none;
    }

    .about-acc-list {
        height: auto;
        justify-content: flex-start;
        padding: 0;
    }
}

/* PROJECTEN */
.ctd-card {
    position: relative;
    padding-bottom: 0; /* important: remove space for arrows */
}

.ctd-nav {
    position: absolute;
    left: 50%;
    bottom: -58px; /* pushes it OUT of the green card */
    transform: translateX(-50%);
    display: flex;
    gap: 32px;
    justify-content: center;
}
    .ctd-nav.row {
        margin: 0;
    }

.ctd-card {
    overflow: visible;
}

/* =========================
   FEATURE (baseline)
   ========================= */

.feature.section {
    background: #02a274;
    padding: 70px 0 60px;
}

@media (max-width: 1023px) {
    .feature.section {
        padding: 50px 0 45px;
    }
}

.feature .single-feature,
.feature .single-feature h3 {
    color: #fff;
}

/* =========================
   BUTTONS ALWAYS AT BOTTOM
   ========================= */

.feature .row.flex {
    align-items: stretch; /* equal column height */
}

    .feature .row.flex > [class*="col-"] {
        display: flex; /* allow child to stretch */
    }

.feature .single-feature {
    width: 100%;
    display: flex;
    flex-direction: column;
}

    .feature .single-feature a {
        margin-top: auto; /* push button down */
        align-self: center; /* keep centered */
    }

.feature.section {
    background: #02a274;
    position: relative;
    overflow: visible;
    padding: 70px 0 60px;
}

    .feature.section .container {
        position: relative;
        z-index: 2;
    }

    /* TOP WAVE */
    .feature.section.feature--wave-top::before {
        content: "";
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        width: 100vw;
        height: 220px;
        top: -219px;
        background: url("/images/wave-top.svg") no-repeat top center / 100% 100%;
        pointer-events: none;
        z-index: 1;
    }

    /* BOTTOM WAVE */
    .feature.section.feature--wave-bottom::after {
        content: "";
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        width: 100vw;
        height: 200px;
        bottom: -199px;
        background: url("/images/wave-bottom.svg") no-repeat bottom center / 100% 100%;
        pointer-events: none;
        z-index: 1;
    }

    /* content safety */
    .feature.section.feature--wave-top {
        padding-top: 120px;
    }

    .feature.section.feature--wave-bottom {
        padding-bottom: 120px;
    }

/* Mobile: rectangle only */
/*@media (max-width: 1023px) {
    .feature.section.feature--wave-top::before,
    .feature.section.feature--wave-bottom::after {
        display: none;
    }

    .feature.section {
        padding: 45px 0 40px;
    }
}

.feature.section.feature--wave-bottom {
    padding-bottom: 260px;*/ /* wave + spacing */
/*}
    .feature.section.feature--wave-top::before,
    .feature.section.feature--wave-bottom::after {
        left: 0;
        transform: none;
        width: 100%;
    }*/

/* account */
.acount_container {
    display: flex;
    gap: 24px; /* optional */
    align-items: stretch; /* this is the key */
}

.acount_box {
    flex: 1;
    display: flex;
    flex-direction: column;
}

/* aanbod */
/* override grid -> flex */
.akcamp_wrapper {
    max-width: none; /* full width */
    width: 100%;
    margin: 0;
    padding-bottom: 40px;
}

.akcamp_grid {
    display: flex;
    flex-wrap: wrap;
    gap: 28px; /* same gap as before */
}

    /* 3 columns desktop */
    .akcamp_grid > .akcamp_card {
        flex: 1 1 calc((100% - (28px * 2)) / 3);
        min-width: 340px; /* keeps your “card min width” idea */
    }

/* 2 columns tablet */
@media (max-width: 1023px) {
    .akcamp_grid > .akcamp_card {
        flex-basis: calc((100% - 28px) / 2);
    }
}

/* 1 column mobile */
@media (max-width: 640px) {
    .akcamp_wrapper {
        /*padding: 0 16px;*/
    }

    .akcamp_grid > .akcamp_card {
        flex-basis: 100%;
        min-width: 0;
    }
}

.akcamp_grid {
    display: flex;
    flex-wrap: wrap;
    gap: 28px;
    justify-content: space-between;
}

    /* desktop: 3 per row */
    .akcamp_grid > .akcamp_card {
        flex: 0 0 300px;
        max-width: 300px;
    }

/* medium: 2 per row */
@media (max-width: 1100px) {
    .akcamp_grid > .akcamp_card {
        flex-basis: 340px;
        max-width: 340px;
    }
}

/* mobile: 1 per row */
@media (max-width: 640px) {
    .akcamp_grid > .akcamp_card {
        flex-basis: 100%;
        max-width: 100%;
    }
}

/* voor de 2 card ghost fix */
.akcamp_grid::after {
    content: "";
    flex: 0 0 340px; /* MUST match card width */
}

/* voor de footer */
/* ================================
   FOOTER: ALIGNMENT PASS
   (black bars = guides only)
   ================================ */

/* FOLLOW (green) – 2 columns: content left, socials right */
footer.footer .follow {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 40px;
}

    footer.footer .follow > div:first-child {
        max-width: 720px; /* keeps text block from wandering too wide */
    }

    /* socials sit right, vertically aligned */
    footer.footer .follow .social {
        display: flex;
        align-items: center;
        justify-content: flex-end;
        gap: 18px;
        margin-left: auto;
    }

    /* keep lead (title + camera) neat */
    footer.footer .follow .lead {
        display: flex;
        align-items: center;
        gap: 16px;
    }

    /* prevent quote text from looking “shifted” */
    footer.footer .follow .footer-quote {
        margin-top: 10px;
        max-width: 620px;
    }


/* PANEL (light) – force 3 clear columns aligned: left / center / right */
footer.footer .panel .row {
    display: flex;
    align-items: center;
    gap: 28px;
    margin: 0;
}

    /* kill bootstrap-like column behavior fighting with our alignment */
    footer.footer .panel .row > .col {
        flex: 1 1 0;
        min-width: 0;
    }

        /* center the middle column (Tel/Mail) */
        footer.footer .panel .row > .col:nth-child(2) {
            text-align: center;
        }

/* right column (logo) pinned right */
footer.footer .panel .icon-col {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

/* make the logo not “float” vertically */
footer.footer .panel .footer-icon {
    display: block;
    max-width: 240px;
    height: auto;
}

/* copyright: lighter + visually centered */
footer.footer .panel .copyright {
    font-weight: 400; /* thinner */
    text-align: center;
    margin: 14px 0 0;
}


@media (max-width: 1024px) {
    footer.footer .follow {
        flex-direction: column;
        align-items: flex-start;
    }

        footer.footer .follow .social {
            justify-content: flex-start;
            margin-left: 0;
        }

    footer.footer .panel .row {
        flex-direction: column;
        align-items: flex-start;
    }

        footer.footer .panel .row > .col:nth-child(2) {
            text-align: left;
            padding-top: 20px;
            padding-bottom:20px;
        }

    footer.footer .panel .icon-col {
        justify-content: flex-start;
        width: 100%;
    }
}
footer.footer .panel .icon-col {
    display: flex;
    align-items: flex-end; /* bottom */
    justify-content: flex-end;
}

footer.footer .panel .divider {
    width: 100%;
    align-self: stretch;
    margin: 26px 0 12px;
}

footer.footer .panel .row,
footer.footer .panel .divider {
    padding-left: 0;
    padding-right: 0;
}
footer.footer .panel {
    padding-left: 24px;
    padding-right: 24px;
}

    footer.footer .panel .row {
        padding-left: 0;
        padding-right: 0;
    }

    footer.footer .panel .divider {
        margin-left: 0;
        margin-right: 0;
    }
    /* Divider should start where the left text starts and end where the logo ends */
    footer.footer .panel .divider {
        background: #025db9;
        /* match Bootstrap column gutter */
        --footer-gutter: 55px;
        width: calc(100% - (var(--footer-gutter) * 2));
        margin: 26px var(--footer-gutter) 12px;
    }
    /* Footer middle column: center the block, left-align the text */
    footer.footer .panel .row > .col:nth-child(2) .addr {
        display: inline-block; /* allows centering as a block */
        text-align: left; /* text itself stays left-aligned */
    }

    /* pluske bij de cards */

/* =========================================
   AKCAMP CARD – CTA + PLUS + ACCORDION (CLEAN)
   - Plus is inside CTA area (only plus toggles)
   - Accordion appears ABOVE CTA and pushes CTA down
   - Collapsed state shows NOTHING (no padding/borders/text bleed)
   - Hover color: #FFC206
   ========================================= */

/* Card must be able to grow in height */
/*.akcamp_card {
    display: flex;
    flex-direction: column;
}*/

/* CTA wrapper stays at bottom */
/*.akcamp_card__ctaWrap {
    position: relative;
    margin-top: auto;
}*/

/* CTA link (make room for the + circle) */
/*.akcamp_card__cta {
    display: block;
    padding-right: 64px;
}*/

/* + BUTTON (outline only, centered) */
/*.akcamp_ctaPlus {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: transparent;
    border: 2px solid #fff;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    cursor: pointer;
    z-index: 2;*/ /* ensure it sits above the link */
/*}

    .akcamp_ctaPlus span {
        display: inline-block;
        font-size: 28px;
        font-weight: 700;
        line-height: 1;*/
        /* optical centering */
        /*transform: translateY(-3px);
        transition: transform 220ms ease, color 220ms ease, border-color 220ms ease;
    }*/

    /* Hover = site yellow (plus + circle) */
    /*.akcamp_ctaPlus:hover {
        border-color: #FFC206;
        color: #FFC206;
    }*/

    /* Keyboard focus */
    /*.akcamp_ctaPlus:focus-visible {
        outline: 3px solid #FFC206;
        outline-offset: 2px;
    }*/


/* =========================================
   ACCORDION (grid trick, NO BLEED when closed)
   ========================================= */

/* must be placed between .akcamp_card__body and .akcamp_card__ctaWrap in HTML */
/*.akcamp_accordion {
    margin: 0 18px;*/ /* no top margin when closed */
    /*display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 220ms ease, margin-top 220ms ease;
}*/

/* inner collapses fully (no padding/borders visible when closed) */
/*.akcamp_accordionInner {
    overflow: hidden;
    padding: 0;
    border-left: 0;
    border-right: 0;
}*/

/* open */
/*.akcamp_card.is-open .akcamp_accordion {
    grid-template-rows: 1fr;
    margin-top: 10px;*/ /* spacing appears only when open */
/*}

.akcamp_card.is-open .akcamp_accordionInner {
    padding: 12px 14px;*/
    /* subtle left/right “barrier” so it still reads as one card */
    /*border-left: 2px solid rgba(255,255,255,.45);
    border-right: 2px solid rgba(255,255,255,.45);
}

.akcamp_grid {
    align-items: flex-start;
}*/

/* symbol drawing */
/*.akcamp_ctaPlus span::before {
    content: "+";
    font-size: 28px;
    font-weight: 700;
    line-height: 1;
}*/

/* when open → minus */
/*.akcamp_ctaPlus[aria-expanded="true"] span::before {
    content: "–";*/ /* real minus, not hyphen */
/*}*/

/* =========================================
   BIG BANNER ACCORDION (ak_strip / ak_strip_blue)
   + in white outlined circle, hover yellow #FFC206
   open state shows minus
   content beneath banner with subtle side barriers
   ========================================= */

/* Make sure banner can position the button */
.ak_strip--toggle,
.ak_strip_blue.ak_strip--toggle {
    position: relative;
}

/* The + / - button on the right of the banner */
.ak_stripPlus {
    position: absolute;
    right: 18px;
    top: 49%;
    transform: translateY(-50%);
    width: 42px;
    height: 42px;
    border-radius: 999px;
    background: transparent; /* not filled */
    border: 2px solid #fff; /* white outline */
    color: #fff; /* symbol color */

    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    cursor: pointer;
}

    /* draw + / - via CSS so we can swap cleanly */
    .ak_stripPlus span::before {
        content: "+";
        font-size: 28px;
        font-weight: 700;
        line-height: 1;
        position: relative;
    }

    /* open => minus */
    .ak_stripPlus[aria-expanded="true"] span::before {
        content: "–"; /* real minus */
    }

    /* hover => website yellow */
    .ak_stripPlus:hover {
        border-color: #FFC206;
        color: #FFC206;
    }

    /* keyboard focus */
    .ak_stripPlus:focus-visible {
        outline: 3px solid #FFC206;
        outline-offset: 2px;
    }

/* Panel spacing directly under banner */
.ak_stripAccordion {
    margin: 10px 0 18px;
}

/* Collapse/expand smoothly (grid trick, no bleed) */
.ak_stripAccordion {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 220ms ease, margin-top 220ms ease;
}

/* inner collapses fully */
.ak_stripAccordion__inner {
    overflow: hidden;
    /* closed state = nothing visible */
    padding: 0;
    border-left: 0;
    border-right: 0;
    /* keep text readable */
    font-size: 16px;
    line-height: 1.45;
}

.ak_stripAccordion__inner p {
padding-top: 12px;
}

/* open state */
.ak_stripAccordion.is-open {
    grid-template-rows: 1fr;
}

    /* visual container when accordion is open */
    .ak_stripAccordion.is-open .ak_stripAccordion__inner {
        padding: 12px 18px;
        /* subtle border */
        border-left: 2px solid rgba(255,255,255,.45);
        border-right: 2px solid rgba(255,255,255,.45);
        border-bottom: 2px solid rgba(255,255,255,.45);
        /* soft drop shadow */
        box-shadow: 0 6px 14px rgba(0,0,0,.12);
        /* slight rounding so it feels intentional */
        border-radius: 0 0 14px 14px;
    }
.ak_stripAccordion {
    margin-top: -12px; /* tucks it under the banner edge */
margin-bottom: 40px;
}

/* Ensure the accordion column can grow and doesn't get clipped */
.about-accordion__layout,
.about-accordion__col,
.about-accordion__col--items,
.about-acc-col,
.about-acc-list,
.accordian-wrapper {
    overflow: visible !important;
    height: auto !important;
    min-height: 360px;
}

/* Critical: make sure bodies are NOT absolutely positioned */
.single-accordian,
.accordian-body {
    position: relative !important;
}

/* If you animate open/close, do it with max-height so it still pushes layout */
.accordian-body {
    display: block; /* participates in layout */
    max-height: 0;
    overflow: hidden;
    transition: max-height 220ms ease;
}

/* Whatever class you use to mark an item open:
   adjust this selector to match your JS (examples below) */
.single-accordian.is-open .accordian-body,
.single-accordian.active .accordian-body,
.single-accordian.open .accordian-body {
    max-height: 600px; /* enough for your content */
}

/* Optional: stop the right image column from stretching weirdly */
.about-accordion__layout {
    align-items: flex-start;
}
/* No clipping anywhere in the accordion area */
.about-accordion__layout,
.about-accordion__col--items,
.accordian-wrapper,
.single-accordian {
    overflow: visible !important;
    height: auto !important;
    max-height: none !important;
}

/* Closed = not in layout */
.accordian-body {
    display: none;
    overflow: visible !important; /* kill scrollbars */
    max-height: none !important;
}

/* Open = natural height (pushes section down) */
.single-accordian.is-open .accordian-body,
.single-accordian.active .accordian-body,
.single-accordian.open .accordian-body {
    display: block;
}

/* Optional: keep the image column from stretching oddly */
.about-accordion__layout {
    align-items: flex-start;
}

/* Accordion list must NOT redistribute space when an item opens */
.about-acc-list,
.accordian-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: space-between !important; /* kills space-between */
    gap: 14px; /* fixed spacing */
}

/* Ensure each item keeps its own spacing */
.single-accordian {
    margin: 0 !important;
}

/* If you had a rule giving the wrapper a fixed height, remove it */
.about-accordion__col--items,
.about-acc-col,
.accordian-wrapper {
    height: auto !important;
}

.vak_headerBox {
    cursor: pointer;
    transition: border-color 0.2s ease;
}

    .vak_headerBox h3 {
        transition: color 0.2s ease;
    }

    .vak_headerBox:hover {
        border-color: #FFC206; /* Akindo yellow */
    }

        .vak_headerBox:hover h3 {
            color: #FFC206; /* Akindo yellow */
        }

    .vak_headerBox:focus-visible {
        border-color: #FFC206;
    }

        .vak_headerBox:focus-visible h3 {
            color: #FFC206;
        }

.vak_row {
    cursor: pointer;
    transition: border-color 0.2s ease;
}

    .vak_rowText,
    .vak_row .aanbod-icon,
    .vak_row .aanbod-icon i {
        transition: color 0.2s ease;
    }

    .vak_row:hover {
        border-color: #FFC206; /* Akindo yellow */
    }

        .vak_row:hover .vak_rowText,
        .vak_row:hover .aanbod-icon,
        .vak_row:hover .aanbod-icon i {
            color: #FFC206; /* Akindo yellow */
        }