/* ============================================================
   FOOTER CSS — Bandenwinkel v3 (grote, leesbare tekst)
   Locatie: app/design/frontend/<vendor>/<theme>/web/css/footer.css
   ============================================================ */

:root {
    --footer-bg:        #1a2740;
    --footer-bg-deep:   #131e30;
    --footer-accent:    #e8552a;
    --footer-muted:     rgba(255,255,255,0.72);
    --footer-border:    rgba(255,255,255,0.12);
    --footer-transition: 0.2s ease;
}

/* -------------------------------------------------------
   Basis
------------------------------------------------------- */
.page-footer,
.page-footer .footer.content,
.page-footer .footer-columns,
footer.page-footer {
    background-color: var(--footer-bg) !important;
    color: #ffffff !important;
    font-size: 16px !important;
    line-height: 1.6 !important;
}

.page-footer {
    border-top: 4px solid var(--footer-accent) !important;
}

.page-footer a {
    color: #ffffff !important;
    text-decoration: none !important;
    transition: color var(--footer-transition) !important;
}

.page-footer .footer.content {
    border-top: none !important;
    padding: 0 !important;
    max-width: 100% !important;
}

/* -------------------------------------------------------
   Klantenservice balk (icoon + tekst blokjes)
------------------------------------------------------- */
.footer-service-bar {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 60px !important;
    flex-wrap: wrap !important;
    background-color: rgba(0,0,0,0.20) !important;
    border-bottom: 1px solid var(--footer-border) !important;
    padding: 28px 40px !important;
}

.footer-service-item {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    color: #ffffff !important;
}

.footer-service-item i {
    font-size: 2.2rem !important;
    color: var(--footer-accent) !important;
}

.footer-service-item strong {
    display: block !important;
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    color: #ffffff !important;
}

.footer-service-item span {
    display: block !important;
    font-size: 0.95rem !important;
    color: var(--footer-muted) !important;
    line-height: 1.4 !important;
}

/* -------------------------------------------------------
   Kolommen layout — 4 kolommen
------------------------------------------------------- */
.footer-columns {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 48px !important;
    width: 100% !important;
    max-width: 1280px !important;
    margin: 0 auto !important;
    padding: 56px 40px 56px !important;
    box-sizing: border-box !important;
}

/* Precies 4 kolommen — elk 25% minus de gap */
.footer-columns .column {
    flex: 1 1 calc(25% - 36px) !important;
    min-width: 0 !important;
    width: calc(25% - 36px) !important;
    background-color: transparent !important;
}

/* De 5e kolom verbergen als die er nog in zit */
.footer-columns .column:nth-child(5) {
    display: none !important;
}

.page-footer .widget.block.block-static-block,
.page-footer .widget.block-static-block {
    display: block !important;
    width: 100% !important;
}

/* -------------------------------------------------------
   Kolom headers
------------------------------------------------------- */
.page-footer .footer-producten h4,
.page-footer .footer-columns h3,
.page-footer .footer-columns h4 {
    color: #ffffff !important;
    margin: 0 0 20px 0 !important;
    font-size: 0.85rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 2.5px !important;
    border-bottom: 1px solid var(--footer-border) !important;
    padding-bottom: 14px !important;
    position: relative !important;
}

.page-footer .footer-producten h4::after,
.page-footer .footer-columns h4::after {
    content: '' !important;
    position: absolute !important;
    bottom: -1px !important;
    left: 0 !important;
    width: 36px !important;
    height: 2px !important;
    background-color: var(--footer-accent) !important;
}

/* -------------------------------------------------------
   Footer links
------------------------------------------------------- */
.page-footer .footer-producten ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.page-footer .footer-producten ul li {
    margin: 0 !important;
    padding: 0 !important;
}

.page-footer .footer-producten ul li a {
    color: var(--footer-muted) !important;
    text-decoration: none !important;
    font-size: 1rem !important;
    line-height: 1.5 !important;
    display: block !important;
    padding: 7px 0 !important;
    transition: color var(--footer-transition), padding-left var(--footer-transition) !important;
    border-bottom: 1px solid rgba(255,255,255,0.05) !important;
}

.page-footer .footer-producten ul li a:hover {
    color: #ffffff !important;
    padding-left: 8px !important;
}

/* -------------------------------------------------------
   Social icons
------------------------------------------------------- */
.footer-social {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 10px 0 !important;
}

.footer-social a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    border-radius: 50% !important;
    background-color: rgba(255,255,255,0.10) !important;
    border: 1px solid var(--footer-border) !important;
    transition: background-color var(--footer-transition), transform var(--footer-transition) !important;
}

.footer-social a:hover {
    background-color: var(--footer-accent) !important;
    border-color: var(--footer-accent) !important;
    transform: translateY(-3px) !important;
}

.footer-social a i {
    color: #ffffff !important;
    font-size: 1.25rem !important;
}

/* -------------------------------------------------------
   Klantenservice blokjes (elk in eigen 33% kolom)
------------------------------------------------------- */
.icon-text-wrapper {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    margin-bottom: 0 !important;
    transition: background-color var(--footer-transition) !important;
}

.headline-text {
    display: flex !important;
    flex-direction: column !important;
    gap: 3px !important;
}

.headline-text .headline {
    font-weight: 700 !important;
    font-size: 1rem !important;
    line-height: 1.3 !important;
    margin: 0 !important;
    color: #ffffff !important;
}

.headline-text .text {
    font-size: 0.9rem !important;
    line-height: 1.45 !important;
    color: var(--footer-muted) !important;
}

.icon-circle {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 48px !important;
    height: 48px !important;
    background-color: var(--footer-accent) !important;
    border-radius: 50% !important;
    color: #fff !important;
    font-size: 20px !important;
    flex-shrink: 0 !important;
    transition: background-color var(--footer-transition), transform var(--footer-transition) !important;
}

.icon-circle:hover {
    background-color: #c94220 !important;
    transform: scale(1.08) !important;
    cursor: pointer !important;
}

/* Tablet — icoon iets kleiner */
@media (max-width: 900px) {
    .icon-text-wrapper {
        gap: 12px !important;
    }

    .icon-circle {
        width: 42px !important;
        height: 42px !important;
        font-size: 18px !important;
    }

    .headline-text .headline {
        font-size: 0.9rem !important;
    }

    .headline-text .text {
        font-size: 0.82rem !important;
    }
}

/* Mobiel */
@media (max-width: 600px) {
    .icon-text-wrapper {
        padding: 18px 0 !important;
        gap: 14px !important;
        border-bottom: 1px solid var(--footer-border) !important;
    }

    .icon-text-wrapper:last-child {
        border-bottom: none !important;
    }

    .icon-circle {
        width: 44px !important;
        height: 44px !important;
        font-size: 19px !important;
    }

    .headline-text .headline {
        font-size: 0.95rem !important;
    }

    .headline-text .text {
        font-size: 0.875rem !important;
    }
}

/* -------------------------------------------------------
   Betaalmethoden
------------------------------------------------------- */
.page-footer .footer-payment {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    gap: 20px !important;
    padding: 28px 40px !important;
    background-color: var(--footer-bg-deep) !important;
    border-top: 1px solid var(--footer-border) !important;
    font-size: 1.05rem !important;
    font-weight: 600 !important;
    color: #ffffff !important;
}

.page-footer .footer-payment img {
    height: 34px !important;
    opacity: 0.88 !important;
    transition: opacity 0.2s !important;
}

.page-footer .footer-payment img:hover {
    opacity: 1 !important;
}

/* Copyright balk */
.page-footer .footer-bottom,
.page-footer .copyright {
    background-color: var(--footer-bg-deep) !important;
    border-top: 1px solid var(--footer-border) !important;
    padding: 16px 40px !important;
    text-align: center !important;
    font-size: 0.9rem !important;
    color: var(--footer-muted) !important;
}

/* -------------------------------------------------------
   Responsive — tablet
------------------------------------------------------- */
@media (max-width: 1024px) {
    .footer-columns {
        flex-wrap: wrap !important;
        gap: 32px !important;
        padding: 40px 28px !important;
    }

    .footer-columns .column {
        flex: 1 1 calc(50% - 16px) !important;
        width: calc(50% - 16px) !important;
    }

    .footer-columns .column:nth-child(5) {
        display: none !important;
    }

    .footer-service-bar {
        gap: 36px !important;
        padding: 24px 28px !important;
    }
}

/* -------------------------------------------------------
   Responsive — mobiel
------------------------------------------------------- */
@media (max-width: 768px) {
    .footer-columns {
        flex-direction: column !important;
        gap: 32px !important;
        padding: 36px 20px !important;
    }

    .footer-columns .column {
        flex: none !important;
        width: 100% !important;
    }

    .footer-service-bar {
        flex-direction: column !important;
        gap: 20px !important;
        align-items: flex-start !important;
        padding: 24px 20px !important;
    }

    .footer-social {
        justify-content: center !important;
        gap: 14px !important;
    }

    .footer-social a {
        width: 50px !important;
        height: 50px !important;
    }

    .footer-social a i {
        font-size: 1.4rem !important;
    }
}