/**
 * Main CSS file for Energieburcht theme.
 *
 * TABLE OF CONTENTS
 * 1. Reset & Global Styles
 * 2. Typography & Buttons
 * 3. Layout & Grid
 * 4. Header Area
 *    4.1. Site Header & Top Bar
 *    4.2. Header Search
 * 5. Navigation (Desktop)
 * 6. Footer Area
 *    6.1. Widgets
 *    6.2. Footer Navigation
 *    6.3. Copyright Bar
 * 7. Components & Utilities
 * 8. Page Settings
 *    8.0. Breadcrumbs
 * 9. Responsive Styles
 *    9.1. Tablet & Mobile (max-width: 991px)
 *    9.2. Medium Screens (max-width: 768px)
 *    9.3. Mobile Screens (max-width: 767px)
 */

 #team, #werkwijze, #certificeringen, #open {
    scroll-margin-top: 90px;
 }


/* ==========================================================================
   3. Layout & Grid
   ========================================================================== */

html {
    scroll-behavior: smooth;
}

.container {
    max-width: var(--wp--style--global--content-size);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--eb-edge-gap, 15px);
    padding-right: var(--eb-edge-gap, 15px);
}

/* Narrow Container — 60 % of the container, used by the "Narrow Container" page template */
.narrow-container {
    max-width: 60%;
    margin-left: auto;
    margin-right: auto;
}

@media (max-width: 768px) {
    .narrow-container {
        max-width: 100%;
    }
}

/* Gutenberg Alignments */
.alignfull {
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	max-width: 100vw;
	width: 100vw;
}

.alignwide {
	margin-left: -100px;
	margin-right: -100px;
	max-width: 100vw;
	width: auto;
}

.boxed-content {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

/* ==========================================================================
   4. Header Area
   ========================================================================== */

/* 4.1. Site Header & Top Bar */
.site-header {
    position: relative;
    z-index: 1000;
    transition: all .2s ease-in-out;
}

.header-top {
    padding: var(--wp--preset--spacing--sm) 0;
    position: relative;
}

.header-top .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 15px;
}

.site-branding .custom-logo-link {
    display: block;
}

.site-branding .custom-logo {
    max-height: var(--eb-logo-width, 60px);
    min-width: var(--eb-logo-width, 60px);
    width: auto;
}

.header-actions {
    display: flex;
    gap: var(--wp--preset--spacing--sm);
    align-items: center;
}

.header-actions .widget {
    margin-bottom: 0;
}

.header-actions ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 1rem;
    align-items: center;
}

/* Header CTAs */
.header-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.5rem;
    border-radius: 0.8rem;
    text-decoration: none;
    font-size: 16px;
    font-weight: 500;
    transition: all 0.3s ease;
    color: var(--cta-color);
    background-color: var(--cta-bg);
    min-width: 220px;
	text-align: center;
}

.header-cta-secondary {
    border: 1px solid currentColor;
}

.header-cta:hover {
    color: var(--cta-hover-color);
    background-color: var(--cta-hover-bg);
}

/* 4.2. Header Search */
.header-search {
    position: relative;
    display: flex;
    align-items: center;
}

/* Form Container */
.header-search .search-form {
    display: flex;
    align-items: center;
    background-color: var(--eb-header-search-bg, var(--eb-off-white));
    border-radius: 50px;
    padding: 2px;
    transition: all 0.3s ease;
    width: 44px; /* Initial circle width */
    height: 44px;
    overflow: hidden;
    position: relative;
    cursor: pointer;
    box-sizing: border-box;
}

/* Hover/Focus Expansion */
.header-search .search-form:hover,
.header-search .search-form:focus-within {
    width: 250px;
    background-color: var(--eb-header-search-bg, var(--eb-off-white));
}

/* Input Field */
.header-search .search-field {
    background: transparent;
    border: none;
    padding: 0 40px 0 15px; /* Right padding for icon space */
    width: 100%;
    height: 100%;
    font-size: 0.9rem;
    color: var(--eb-header-search-text, #026601);
    opacity: 0;
    cursor: pointer; /* Pointer when closed */
    transition: opacity 0.2s ease 0.1s; /* Delay opacity slightly */
}

.header-search .search-field:focus {
    outline: none;
}

/* Show input when expanded */
.header-search .search-form:hover .search-field,
.header-search .search-form:focus-within .search-field {
    opacity: 1;
    cursor: text;
}

/* Submit Button / Icon */
.header-search .search-submit {
    position: absolute;
    right: 0;
    top: 0;
    width: 44px;
    height: 44px;
    background: transparent;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--eb-header-search-icon, #026601);
    cursor: pointer;
    z-index: 2;
    transition: all 0.3s ease;
    border-radius: 50%;
}

.header-search .search-submit:hover {
    color: var(--eb-header-search-icon-hover, var(--eb-orange));
    background-color: var(--eb-header-search-icon-hover-bg, #efebeb);
}

.header-search .search-submit svg {
    width: 24px;
    min-width: 24px;
}

/* ==========================================================================
   5. Navigation (Desktop)
   ========================================================================== */

.desktop-header-bottom {
    z-index: 90;
    width: 100%;
    transition: box-shadow 0.3s ease;
    padding-left: var(--eb-edge-gap, 15px);
    padding-right: var(--eb-edge-gap, 15px);
}

.is-sticky .desktop-header-bottom {
    position: fixed;
    top: 0;
    left: 0;
    animation: slideDown 0.3s ease forwards;
    margin-top: 20px;
}

@keyframes slideDown {
    from { transform: translateY(-100%); }
    to { transform: translateY(0); }
}

.desktop-header-bottom .container {
    box-shadow: 0 .125em .5em rgba(0,0,0,.15);
    border: 1px solid var(--eb-nav-border);
    border-radius: 0.8rem;
    background: var(--eb-nav-bg);
    padding: 15px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--wp--preset--spacing--lg);
}

.sticky-logo, .sticky-cta {
    display: none;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all .2s ease-in-out;
}



.sticky-logo .custom-logo {
    max-height: var(--eb-logo-width, 60px);
    min-width: var(--eb-logo-width, 60px);
    width: auto;
}

.is-sticky .sticky-logo, .is-sticky .sticky-cta {
    display: block;
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Menu Items Container */
.menu-items {
    display: flex;
    margin: 0;
    padding: 0;
    justify-content: flex-start;
    gap: 15px;
    flex-direction: row;
    align-items: center;
    width: 100%;
}

.menu-items li {
    list-style: none;
    width: 100%;
    position: relative; 
}

.menu-items a {
    display: inline-block;
    font-family: var(--wp--preset--font-family--mic-32-new);
    padding: 9px 15px;
    transition: all .2s ease-in-out;
    text-decoration: none;
    color: var(--eb-nav-link-color, #026601);
    font-weight: 400;
}

.menu-items.desktop-menu a {
    font-weight: 500;
    border-radius: .8rem;
    border: 1px solid var(--eb-nav-bg);
}

.menu-items.desktop-menu a:hover {
    color: var(--eb-nav-link-hover-color, #ED7218);
    border-color: var(--eb-nav-link-hover-border, #ED7218);
}

/* Logic for Sub-menus */
.menu-items .sub-menu {
    position: absolute;
    background-color: var(--eb-nav-dropdown-bg);
    border: 1px solid var(--eb-nav-dropdown-border);
    border-radius: 0.8rem;
    box-shadow: 0 .125em .5em rgba(0,0,0,.15);
    flex-direction: column;
    gap: var(--wp--preset--spacing--lg);
    padding: 15px;
    box-sizing: content-box;
    width: 100%;
    visibility: hidden;
    opacity: 0;
    transition: all .2s ease-in-out;
    min-width: 230px;
}

.menu-items .sub-menu a {
    width: 100%;
    display: block;
    box-sizing: border-box;
    color: var(--eb-nav-dropdown-link-color);
}

.menu-items .sub-menu a:hover {
    background-color: var(--eb-nav-dropdown-hover-bg);
}

.menu-items > li:hover > .sub-menu {
    visibility: visible;
    opacity: 1;
    margin-top: 20px;
}

.menu-items > li > .sub-menu {
    top: 100%;
    left: 0;
}

.menu-items > li > .sub-menu > li > .sub-menu {
    top: 0;
    left: 100%;
    margin-top: 0;
    margin-left: 20px;
}

.menu-items > li > .sub-menu > li:hover > .sub-menu {
    visibility: visible;
    opacity: 1;
}

.menu-items > li.menu-item-has-children > a {
    position: relative;
    align-items: center;
    padding: 9px 15px;
}

.menu-items.desktop-menu > li.menu-item-has-children > a {
    padding: 9px 40px 9px 15px;
}

/* Chevron */
.menu-items.desktop-menu > li.menu-item-has-children > a:after {
    position: absolute;
    top: 50%;
    right: 15px;
    content: "";
    width: 7px;
    height: 7px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: translateY(-70%) rotate(45deg);
    transition: border-color .2s ease-in-out;
}

/* ==========================================================================
   6. Footer Area
   ========================================================================== */

/* 6.1. Widgets */
.footer-widgets-wrapper {
    padding-top: 100px;
    padding-bottom: 100px;
    background-color: var(--footer-bg-color, #022702);
    color: var(--footer-text-color, #a5aab1);
}

.widget-title {
    color: var(--footer-title-color, #fff);
}

.footer-widgets-wrapper a {
    text-decoration: none;
    color: var(--footer-link-color, #a5aab1);
}

.footer-widgets-columns {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--footer-widget-gap, 50px);
}

.footer-widgets-columns.columns-1 {
    grid-template-columns: 1fr;
}

.footer-widgets-columns.columns-2 {
    grid-template-columns: repeat(2, 1fr);
}

.footer-widgets-columns.columns-3 {
    grid-template-columns: repeat(3, 1fr);
}

.footer-widgets-columns.columns-4 {
    grid-template-columns: 2fr repeat(3, 1fr);
}

.footer-widgets-columns.columns-5 {
    grid-template-columns: 2fr repeat(4, 1fr);
}

.footer-column {
    min-width: 0; /* Prevent overflow */
}

.widget-title, .is-style-widget-title {
    font-size: 1.2rem;
    font-weight: 500;
    margin-bottom: 1rem;
}

/* 6.2. Footer Navigation */
.widget_nav_menu ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.widget_nav_menu ul li a {
    color: var(--footer-link-color, #a5aab1);
    font-size: 15px;
}

.widget_nav_menu ul li a:hover {
    color: var(--footer-link-hover-color, #fff);
}


/* 6.3. Copyright Bar */
.site-info {
    background-color: var(--copyright-bg-color, #022702);
    color: var(--copyright-text-color, #9BABAE);
    padding: 20px 0;
    font-size: 14px;
}

.copyright-bar {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 8px;
}

.copyright-text {
    font-weight: 300;
    color: var(--copyright-text-color, #9BABAE);
}

.copyright-menu ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.copyright-menu ul li {
    position: relative;
}

.copyright-menu ul li a {
    color: var(--copyright-text-color, #9BABAE);
    text-decoration: none;
    font-weight: 300;
}

.copyright-menu ul li a:hover {
    color: var(--copyright-link-hover-color, #ffffff);
}

/* Add separator | between menu items */
.copyright-menu ul li:not(:last-child)::after {
    content: '|';
    margin-left: 8px;
    opacity: 0.5;
}

/* ==========================================================================
   7. Components & Utilities
   ========================================================================== */

/* Back to Top Button */
#back-to-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 40px;
    height: 40px;
    background-color: var(--back-to-top-bg, #ffffff);
    color: var(--back-to-top-color, #026601);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: all 0.3s ease-in-out;
    z-index: 999;
    text-decoration: none;
}

#back-to-top.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

#back-to-top:hover {
    transform: translateY(-3px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.3);
}

#back-to-top .dashicons {
    font-size: 20px;
    width: 20px;
    height: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Mobile Nav Toggle (Base - Default Hidden) */
.mobile-nav-toggle {
    display: none;
}

/* Mobile Header Bottom (Base - Default Hidden) */
.mobile-header-bottom {
    display: none;
}

.mobile-header-right {
    padding-left: var(--wp--preset--spacing--md);
    padding-right: var(--wp--preset--spacing--md);
    padding-bottom: var(--wp--preset--spacing--sm);
    display: flex;
    justify-content: flex-end;
}

/* Menu Arrow Icon (Base) */
span.menu-arrow-icon {
    display: none; /* Hidden by default, shown on mobile via JS */
    width: 50px;
    min-width: 50px;
    height: 42px;
    align-items: center;
    justify-content: center;
    border-left: 1px solid rgba(0, 0, 0, .15)
}

span.menu-arrow-icon.active {
    border-left: none;
    border-right: 1px solid rgba(0, 0, 0, .15);
}

span.menu-arrow-icon svg {
    width: 24px;
    height: 24px;
    stroke: var(--eb-mob-nav-icon-color);
}

span.menu-arrow-icon.active svg {
    transform: rotate(180deg);
}

/*
============================================================================
   8. Page Settings
   ====================================================================== */
.page-hero {
    margin-top: 1.5rem;
}

.page-hero-cta {
    margin-top: 1.5rem;
}

/* ==========================================================================
   8.0. Breadcrumbs
   ========================================================================== */

.eb-breadcrumbs-wrap {
    padding: 1rem 0;
    background-color: transparent;
}

.eb-breadcrumbs {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.8125rem;
    color: #6c757d;
}

/* Yoast outputs <span> elements with class="breadcrumb_last" for the active crumb */
.eb-breadcrumbs a {
    color: #6c757d;
    text-decoration: none;
    transition: color 0.15s ease;
}

.eb-breadcrumbs a:hover {
    color: #ED7218;
    text-decoration: underline;
}

/* Separator injected by Yoast between items */
.eb-breadcrumbs .breadcrumb_last {
    color: #026601;
    font-weight: 600;
}

/* ==========================================================================
   8.1. Projecten Archive
   ========================================================================== */
   
/* ── Category filter bar ── */
.projecten-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.projecten-filter-btn {
    display: inline-flex;
    align-items: center;
    padding: 8px 16px;
    border-radius: 0.8rem;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.4;
    cursor: pointer;
    border: 1px solid var(--projecten-filter-border, #EFEFEF);
    background-color: var(--projecten-filter-bg, #f0f4f8);
    color: var(--projecten-filter-color, #026601);
    transition: background-color 0.15s ease-in-out,
                color 0.15s ease-in-out,
                border-color 0.15s ease-in-out;
}

.projecten-filter-btn:hover,
.projecten-filter-btn.is-active {
    background-color: var(--projecten-filter-active-bg, #ED7218);
    color: var(--projecten-filter-active-color, #ffffff);
    border-color: var(--projecten-filter-active-border, #ED7218);
}

/* ── Category tag on card ── */
.projecten-cat-tag {
    display: inline-block;
    align-self: flex-start;
    padding: 4px 8px;
    border-radius: 0.8rem;
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    background-color: var(--projecten-cat-bg, #ffefe4);
    color: var(--projecten-cat-color, #026601);
}

/* ── Grid loading state ── */
.projecten-grid.is-loading {
    opacity: 0.45;
    pointer-events: none;
    transition: opacity 0.2s ease-in-out;
}

/* ── CSS custom-property defaults (overridden per-page via inline <style>) ── */
.archive-projecten {
    --projecten-item-bg:              #ffffff;
    --projecten-title-color:          #026601;
    --projecten-excerpt-color:        #212529;
    --projecten-btn-color:            #ffffff;
    --projecten-btn-bg:               #ED7218;
    --projecten-btn-hover-color:      #ffffff;
    --projecten-btn-hover-bg:         #026601;
    --projecten-cat-color:            #026601;
    --projecten-cat-bg:               #e0f0f5;
    --projecten-filter-color:         #026601;
    --projecten-filter-bg:            #f0f4f8;
    --projecten-filter-border:        #026601;
    --projecten-filter-active-color:  #ffffff;
    --projecten-filter-active-bg:     #ED7218;
    --projecten-filter-active-border: #ED7218;
}

/* ── Project grid ── */
.projecten-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    padding-top: 3rem;
}

/* ── Project card ── */
.projecten-item {
    display: flex;
    flex-direction: column;
    background-color: var(--projecten-item-bg);
    border-radius: 0.5rem;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    transition: box-shadow 0.2s ease-in-out, transform 0.2s ease-in-out;
}

.projecten-item:hover {
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.14);
    transform: translateY(-3px);
}

/* ── Thumbnail ── */
.projecten-thumbnail {
    display: block;
    overflow: hidden;
    aspect-ratio: 16 / 9;
}

.projecten-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.35s ease-in-out;
}

.projecten-item:hover .projecten-thumbnail img {
    transform: scale(1.04);
}

/* ── Content area ── */
.projecten-content {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 1.5rem;
    gap: 0.75rem;
}

/* ── Title ── */
.projecten-title {
    font-size: clamp(1.25rem, 2.5vw, 1.5rem);
    margin: 0;
    line-height: 1.3;
}

.projecten-title a {
    color: var(--projecten-title-color);
    text-decoration: none;
    transition: color 0.15s ease-in-out;
}

.projecten-title a:hover {
    color: var(--projecten-btn-bg);
}

/* ── Excerpt ── */
.projecten-excerpt {
    color: var(--projecten-excerpt-color);
    font-size: var(--eb-typography-body);
    line-height: 1.6;
    flex: 1;
}

.projecten-excerpt p:last-child {
    margin-bottom: 0;
}

/* ── Read-more button ── */
.projecten-read-more {
    align-self: flex-start;
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 0;
    padding: 0.55em 1.1em;
    border-radius: 0.4em;
    font-size: var(--eb-typography-button, 1rem);
    font-weight: 400;
    text-decoration: none;
    background-color: var(--projecten-btn-bg);
    color: var(--projecten-btn-color);
    transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
}

/* Arrow injected after the label — color tracks the button text via currentColor */
.projecten-read-more::after {
    content: '\2192';
    display: inline-block;
    margin-left: 0.45em;
    color: currentColor;
    transition: transform 0.2s ease-in-out;
}

.projecten-read-more:hover {
    background-color: var(--projecten-btn-hover-bg);
    color: var(--projecten-btn-hover-color);
}

.projecten-read-more:hover::after {
    transform: translateX(4px);
}

/* ── Numeric pagination ── */
.projecten-pagination {
    display: flex;
    justify-content: center;
    margin-top: 3rem;
    padding-bottom: 1rem;
    gap: 0.5rem;
}

.projecten-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.25rem;
    height: 2.25rem;
    padding: 0 0.6rem;
    border-radius: 0.35rem;
    font-size: 0.9375rem;
    font-weight: 600;
    text-decoration: none;
    color: var(--projecten-title-color, var(--eb-navy));
    background-color: transparent;
    border: 1px solid transparent;
    transition: background-color 0.15s ease-in-out,
                color 0.15s ease-in-out,
                border-color 0.15s ease-in-out;
}

.projecten-pagination .page-numbers:hover {
    background-color: var(--projecten-btn-bg, var(--eb-orange));
    color: var(--projecten-btn-color, #fff);
    border-color: var(--projecten-btn-bg, var(--eb-orange));
}

.projecten-pagination .page-numbers.current {
    background-color: var(--projecten-btn-bg, var(--eb-orange));
    color: var(--projecten-btn-color, #fff);
    border-color: var(--projecten-btn-bg, var(--eb-orange));
    cursor: default;
}

.projecten-pagination .page-numbers.dots {
    border-color: transparent;
    background: transparent;
    cursor: default;
    letter-spacing: 0.05em;
}

/* Prev / next as icon-only pills */
.projecten-pagination .prev.page-numbers,
.projecten-pagination .next.page-numbers {
    font-size: 1.1rem;
    padding: 0 0.75rem;
    border: 1px solid var(--projecten-btn-bg, var(--eb-orange));
    color: var(--projecten-btn-bg, var(--eb-orange));
}

.projecten-pagination .prev.page-numbers:hover,
.projecten-pagination .next.page-numbers:hover {
    background-color: var(--projecten-btn-bg, var(--eb-orange));
    color: var(--projecten-btn-color, #fff);
}

.projecten-pagination__arrow {
    line-height: 1;
}


/* ==========================================================================
   8.2. Single Projecten
   ========================================================================== */

/* ── CSS variable defaults (card colours reused in related section) ── */
.single-projecten {
    --projecten-item-bg:         #ffffff;
    --projecten-title-color:     #026601;
    --projecten-excerpt-color:   #212529;
    --projecten-btn-color:       #ffffff;
    --projecten-btn-bg:          #ED7218;
    --projecten-btn-hover-color: #ffffff;
    --projecten-btn-hover-bg:    #026601;
    --projecten-cat-color:       #026601;
    --projecten-cat-bg:          #e0f0f5;
}

/* ── Hero — container-width featured image ── */
.single-projecten-hero {
    position: relative;
    border-radius: 0.75rem;
    overflow: hidden;
    background-size: cover;
    background-position: center;
    min-height: 420px;
    display: flex;
    align-items: flex-end;
    margin-top: 2rem;
}

/* Gradient: opaque black at bottom → fully transparent at top */
.single-projecten-hero__gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.80) 0%,
        rgba(0, 0, 0, 0.25) 45%,
        transparent 100%
    );
    z-index: 1;
}

/* Title row anchored to the bottom of the image */
.single-projecten-hero__content {
    position: relative;
    z-index: 2;
    width: 90%;
    margin: 0 auto 15px;
}

.single-projecten-hero__title {
    color: #ffffff;
    margin: 0;
    line-height: 1.2;
}

/* ── Body — narrow content wrapper (~90% of container) ── */
.single-projecten-wrap {
    max-width: 90%;
    margin-left: auto;
    margin-right: auto;
}

/* ── Two-column layout: content 75% + sidebar 25% ── */
.single-projecten-layout {
    display: grid;
    grid-template-columns: 3fr 1fr;
    gap: 3rem;
    align-items: start;
}

/* ── Sidebar widget spacing ── */
.single-projecten-sidebar .widget {
    margin-bottom: 2rem;
}

.single-projecten-sidebar .widget:last-child {
    margin-bottom: 0;
}

.single-projecten-sidebar .widget-title {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--projecten-btn-bg, #ED7218);
}

/* ── Related projects section ── */
.related-projecten {
    /* background-color set inline from Customizer; fallback here */
    background-color: var(--related-bg, #f8f9fa);
    padding: 4rem 0;
}

.related-projecten__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 2rem;
}

.related-projecten__title {
    margin: 0;
    font-size: clamp(1.4rem, 3vw, 2rem);
    color: var(--related-title-color, #026601);
}

.related-projecten__more {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-weight: 600;
    font-size: 0.9375rem;
    color: var(--related-btn-color, #ED7218);
    text-decoration: none;
    white-space: nowrap;
    transition: color 0.15s ease-in-out;
}

.related-projecten__more:hover {
    color: var(--related-btn-hover-color, #026601);
}

.related-projecten__more-arrow {
    font-size: 1.1em;
    line-height: 1;
    transition: transform 0.2s ease-in-out;
}

.related-projecten__more:hover .related-projecten__more-arrow {
    transform: translateX(4px);
}

/* Related grid — header provides spacing so no extra top padding needed */
.related-projecten__grid {
    padding-top: 0;
}


/* ==========================================================================
   8.3. Kennisitems Archive
   ========================================================================== */

/* ── CSS custom-property defaults (overridden per-page via inline <style>) ── */
.archive-kennisitems {
    --kennisitems-item-bg:              #ffffff;
    --kennisitems-title-color:          #026601;
    --kennisitems-excerpt-color:        #212529;
    --kennisitems-btn-color:            #ED7218;
    --kennisitems-btn-hover-color:      #ffffff;
    --kennisitems-btn-hover-bg:         #ED7218;
    --kennisitems-cat-title-color:      #026601;
    --kennisitems-cat-link-color:       #ED7218;
    --kennisitems-cat-link-hover-color: #026601;
}

/* ── Category section — spacing between rows ── */
/* .kennisitems-categorie-section {
    padding-top: 3rem;
} */

.kennisitems-categorie-section + .kennisitems-categorie-section {
    margin-top: 5rem;
}

/* ── Category header — two-column: title left, link right ── */
.kennisitems-categorie-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1.75rem;
}

.kennisitems-cat-title {
    margin: 0;
    font-size: clamp(1.25rem, 2.5vw, 1.75rem);
    color: var(--kennisitems-cat-title-color, #026601);
}

.kennisitems-cat-more {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-weight: 600;
    font-size: 0.9375rem;
    color: var(--kennisitems-cat-link-color, #ED7218);
    text-decoration: none;
    white-space: nowrap;
    transition: color 0.15s ease-in-out;
}

.kennisitems-cat-more:hover {
    color: var(--kennisitems-cat-link-hover-color, #026601);
}

.kennisitems-cat-more__arrow {
    font-size: 1.1em;
    line-height: 1;
    transition: transform 0.2s ease-in-out;
}

.kennisitems-cat-more:hover .kennisitems-cat-more__arrow {
    transform: translateX(4px);
}

/* ── Grid ── */
.kennisitems-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}

/* ── Card ── */
.kennisitems-item {
    display: flex;
    flex-direction: column;
    background-color: var(--kennisitems-item-bg);
    border-radius: 0.5rem;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    transition: box-shadow 0.2s ease-in-out, transform 0.2s ease-in-out;
}

.kennisitems-item:hover {
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.14);
    transform: translateY(-3px);
}

/* ── Thumbnail (optional — only rendered when the post has one) ── */
.kennisitems-thumbnail {
    display: block;
    overflow: hidden;
    aspect-ratio: 16 / 9;
}

.kennisitems-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.35s ease-in-out;
}

.kennisitems-item:hover .kennisitems-thumbnail img {
    transform: scale(1.04);
}

/* ── Content area ── */
.kennisitems-content {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 1.5rem;
    gap: 0.75rem;
}

/* ── Title ── */
.kennisitems-title {
    font-size: clamp(1.1rem, 2vw, 1.35rem);
    margin: 0;
    line-height: 1.3;
}

.kennisitems-title a {
    color: var(--kennisitems-title-color);
    text-decoration: none;
    transition: color 0.15s ease-in-out;
}

.kennisitems-title a:hover {
    color: var(--kennisitems-btn-color);
}

/* ── Excerpt ── */
.kennisitems-excerpt {
    color: var(--kennisitems-excerpt-color);
    font-size: var(--eb-typography-body);
    line-height: 1.6;
    flex: 1;
}

.kennisitems-excerpt p:last-child {
    margin-bottom: 0;
}

/* ── Read-more button (outline style) ── */
.kennisitems-read-more {
    align-self: flex-start;
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 0;
    padding: 0.55em 1.1em;
    border-radius: 0.4em;
    font-size: var(--eb-typography-button, 1rem);
    font-weight: 400;
    text-decoration: none;
    background-color: transparent;
    color: var(--kennisitems-btn-color);
    border: 1px solid var(--kennisitems-btn-color);
    transition: background-color 0.2s ease-in-out,
                color 0.2s ease-in-out,
                border-color 0.2s ease-in-out;
}

/* Arrow injected after label — tracks button text colour via currentColor */
.kennisitems-read-more::after {
    content: '\2192';
    display: inline-block;
    margin-left: 0.45em;
    color: currentColor;
    transition: transform 0.2s ease-in-out;
}

.kennisitems-read-more:hover {
    background-color: var(--kennisitems-btn-hover-bg);
    color: var(--kennisitems-btn-hover-color);
    border-color: var(--kennisitems-btn-hover-bg);
}

.kennisitems-read-more:hover::after {
    transform: translateX(4px);
}


/* ==========================================================================
   8.4. Single Kennisitems
   ========================================================================== */

/* ── CSS variable defaults (overridden by the inline <style> block in template) */
.single-kennisitems {
    --ki-social-color:       #026601;
    --ki-social-bg:          #f0f4f8;
    --ki-social-hover-color: #ffffff;
    --ki-social-hover-bg:    #ED7218;
    --ki-toc-bg:             #f8f9fa;
    --ki-toc-title-color:    #026601;
    --ki-toc-link-color:     #026601;
    --ki-toc-active-color:   #ED7218;
    --ki-author-bg:          #f8f9fa;
    --ki-author-name-color:  #026601;
    --ki-author-bio-color:   #212529;
}

/* ── Outer wrapper — 90 % of the container ── */
.single-kennisitems-wrap {
    max-width: 90%;
    margin-left: auto;
    margin-right: auto;
    padding-top: 3rem;
    padding-bottom: 3rem;
}

/* ── Three-column grid ──────────────────────────────────────────────────── */
.single-kennisitems-body {
    display: grid;
    grid-template-columns: 100px 1fr 300px;
    gap: 4rem;
    align-items: start;
}

/* When social share is hidden — drop first column */
.single-kennisitems-body.no-social {
    grid-template-columns: 1fr 240px;
}

/* When TOC is hidden — drop third column */
.single-kennisitems-body.no-toc {
    grid-template-columns: 56px 1fr;
}

/* Both hidden */
.single-kennisitems-body.no-social.no-toc {
    grid-template-columns: 1fr;
}

/* ── Col 1: Social share ────────────────────────────────────────────────── */
.single-kennisitems-social {
    position: sticky;
    top: 250px; /* below sticky header */
}

.ki-social-share {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    align-items: center;
}

.ki-social-share__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background-color: var(--ki-social-bg);
    color: var(--ki-social-color);
    text-decoration: none;
    transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
    flex-shrink: 0;
}

.ki-social-share__btn:hover {
    background-color: var(--ki-social-hover-bg);
    color: var(--ki-social-hover-color);
    transform: translateY(-2px);
}

.ki-social-share__btn svg {
    display: block;
    pointer-events: none;
}

/* ── Col 2: Main content ────────────────────────────────────────────────── */
.single-kennisitems-content {
    min-width: 0; /* prevent grid blowout */
}

.single-kennisitems-title {
    margin-top: 0;
    margin-bottom: 0.75rem;
    font-size: var(--eb-typography-h1, clamp(2rem, 4vw, 2.75rem));
    line-height: 1.2;
    color: #026601;
}

/* Post meta: category badge + date */
.ki-post-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 2rem;
    font-size: 0.875rem;
}

.ki-post-meta__cat {
    display: inline-block;
    padding: 0.2em 0.75em;
    border-radius: 2em;
    background-color: #e8f4fb;
    color: #026601;
    font-weight: 600;
    font-size: 0.8rem;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.ki-post-meta__date {
    color: #6c757d;
}

/* Featured image */
.ki-featured-image {
    margin-bottom: 2rem;
    border-radius: 0.5rem;
    overflow: hidden;
}

.ki-featured-image__img {
    display: block;
    width: 100%;
    height: auto;
}

/* Entry content */
.ki-entry-content {
    font-size: var(--eb-typography-body, 1rem);
    line-height: 1.75;
    color: #212529;
}

.ki-entry-content h2,
.ki-entry-content h3,
.ki-entry-content h4 {
    scroll-margin-top: 90px; /* for anchor links to account for fixed header */
}

.ki-entry-content p {
    margin-bottom: 1.25rem;
}

.ki-entry-content ul,
.ki-entry-content ol {
    padding-left: 1.5rem;
    margin-bottom: 1.25rem;
}

.ki-entry-content li {
    margin-bottom: 0.4rem;
}

.ki-entry-content a {
    color: #ED7218;
    text-decoration: underline;
}

.ki-entry-content a:hover {
    color: #026601;
}

.ki-entry-content img {
    max-width: 100%;
    height: auto;
    border-radius: 0.375rem;
}

/* ── Author box ─────────────────────────────────────────────────────────── */
.ki-author-box {
    display: flex;
    gap: 1.25rem;
    align-items: flex-start;
    margin-top: 2.5rem;
    padding: 1.5rem;
    background-color: var(--ki-author-bg);
    border-radius: 0.5rem;
}

.ki-author-box__avatar img {
    border-radius: 50%;
    display: block;
    flex-shrink: 0;
}

.ki-author-box__info {
    flex: 1;
    min-width: 0;
}

.ki-author-box__name {
    margin: 0 0 0.4rem;
    font-weight: 700;
    font-size: 1rem;
    color: var(--ki-author-name-color);
}

.ki-author-box__bio {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--ki-author-bio-color);
}

/* ── Col 3: Table of contents ───────────────────────────────────────────── */
.single-kennisitems-toc {
    position: sticky;
    top: 120px;
}

.ki-toc {
    background-color: var(--ki-toc-bg);
    border-radius: 0.5rem;
    padding: 1.25rem 1.5rem;
    overflow: hidden;
}

.ki-toc__title {
    margin: 0 0 0.875rem;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ki-toc-title-color);
}

.ki-toc__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ki-toc__item {
    margin-bottom: 0.3rem;
}

.ki-toc__item--sub {
    padding-left: 1rem;
}

.ki-toc__link {
    display: block;
    font-size: 0.875rem;
    line-height: 1.4;
    color: var(--ki-toc-link-color);
    text-decoration: none;
    padding: 0;
    transition: color 0.15s ease, border-color 0.15s ease;
}

.ki-toc__link:hover {
    color: var(--ki-toc-active-color);
}

.ki-toc__link.is-active {
    color: var(--ki-toc-active-color);
    border-left-color: var(--ki-toc-active-color);
    font-weight: 600;
}

/* ==========================================================================
   Single Post (global single.php)
   ========================================================================== */

.single-post {
    --sp-social-color:       #026601;
    --sp-social-bg:          #f0f4f8;
    --sp-social-hover-color: #ffffff;
    --sp-social-hover-bg:    #ED7218;
    --sp-toc-bg:             #f8f9fa;
    --sp-toc-title-color:    #026601;
    --sp-toc-link-color:     #026601;
    --sp-toc-active-color:   #ED7218;
    --sp-author-bg:          #f8f9fa;
    --sp-author-name-color:  #026601;
    --sp-author-bio-color:   #212529;
}

/* ── Outer wrapper ── */
.single-post-wrap {
    max-width: 90%;
    margin-left: auto;
    margin-right: auto;
    padding-top: 3rem;
    padding-bottom: 3rem;
}

/* ── Three-column grid ── */
.single-post-body {
    display: grid;
    grid-template-columns: 100px 1fr 300px;
    gap: 4rem;
    align-items: start;
}

.single-post-body.no-social {
    grid-template-columns: 1fr 240px;
}

.single-post-body.no-toc {
    grid-template-columns: 56px 1fr;
}

.single-post-body.no-social.no-toc {
    grid-template-columns: 1fr;
}

/* ── Col 1: Social share ── */
.single-post-social {
    position: sticky;
    top: 250px;
}

.sp-social-share {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    align-items: center;
}

.sp-social-share__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background-color: var(--sp-social-bg);
    color: var(--sp-social-color);
    text-decoration: none;
    transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
    flex-shrink: 0;
}

.sp-social-share__btn:hover {
    background-color: var(--sp-social-hover-bg);
    color: var(--sp-social-hover-color);
    transform: translateY(-2px);
}

.sp-social-share__btn svg {
    display: block;
    pointer-events: none;
}

/* ── Col 2: Main content ── */
.single-post-content {
    min-width: 0;
}

.single-post-title {
    margin-top: 0;
    margin-bottom: 0.75rem;
    font-size: var(--eb-typography-h1, clamp(2rem, 4vw, 2.75rem));
    line-height: 1.2;
    color: #026601;
}

.sp-post-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 2rem;
    font-size: 0.875rem;
}

.sp-post-meta__cat {
    display: inline-block;
    padding: 0.2em 0.75em;
    border-radius: 2em;
    background-color: #e8f4fb;
    color: #026601;
    font-weight: 600;
    font-size: 0.8rem;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.sp-post-meta__date {
    color: #6c757d;
}

.sp-featured-image {
    margin-bottom: 2rem;
    border-radius: 0.5rem;
    overflow: hidden;
}

.sp-featured-image__img {
    display: block;
    width: 100%;
    height: auto;
}

.sp-entry-content {
    font-size: var(--eb-typography-body, 1rem);
    line-height: 1.75;
    color: #212529;
}

.sp-entry-content h2,
.sp-entry-content h3,
.sp-entry-content h4 {
    scroll-margin-top: 90px;
}

.sp-entry-content p {
    margin-bottom: 1.25rem;
}

.sp-entry-content ul,
.sp-entry-content ol {
    padding-left: 1.5rem;
    margin-bottom: 1.25rem;
}

.sp-entry-content li {
    margin-bottom: 0.4rem;
}

.sp-entry-content a {
    color: #ED7218;
    text-decoration: underline;
}

.sp-entry-content a:hover {
    color: #026601;
}

.sp-entry-content img {
    max-width: 100%;
    height: auto;
    border-radius: 0.375rem;
}

/* ── Author box ── */
.sp-author-box {
    display: flex;
    gap: 1.25rem;
    align-items: flex-start;
    margin-top: 2.5rem;
    padding: 1.5rem;
    background-color: var(--sp-author-bg);
    border-radius: 0.5rem;
}

.sp-author-box__avatar img {
    border-radius: 50%;
    display: block;
    flex-shrink: 0;
}

.sp-author-box__info {
    flex: 1;
    min-width: 0;
}

.sp-author-box__name {
    margin: 0 0 0.4rem;
    font-weight: 700;
    font-size: 1rem;
    color: var(--sp-author-name-color);
}

.sp-author-box__bio {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--sp-author-bio-color);
}

/* ── Col 3: Table of contents ── */
.single-post-toc {
    position: sticky;
    top: 120px;
}

.sp-toc {
    background-color: var(--sp-toc-bg);
    border-radius: 0.5rem;
    padding: 1.25rem 1.5rem;
    overflow: hidden;
}

.sp-toc__title {
    margin: 0 0 0.875rem;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--sp-toc-title-color);
}

.sp-toc__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.sp-toc__item {
    margin-bottom: 0.3rem;
}

.sp-toc__item--sub {
    padding-left: 1rem;
}

.sp-toc__link {
    display: block;
    font-size: 0.875rem;
    line-height: 1.4;
    color: var(--sp-toc-link-color);
    text-decoration: none;
    padding: 0.2rem 0.6rem;
    border-left: 2px solid transparent;
    transition: color 0.15s ease, border-color 0.15s ease;
}

.sp-toc__link:hover {
    color: var(--sp-toc-active-color);
}

.sp-toc__link.is-active {
    color: var(--sp-toc-active-color);
    border-left-color: var(--sp-toc-active-color);
    font-weight: 600;
}

/* ── Related kennisitems section ────────────────────────────────────────── */
.related-kennisitems {
    padding: 4rem 0;
    margin-top: 2rem;
}

.related-kennisitems__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 2rem;
}

.related-kennisitems__title {
    margin: 0;
    font-size: clamp(1.4rem, 3vw, 2rem);
    color: var(--ki-related-title-color, #026601);
    line-height: 1.2;
}

.related-kennisitems__more {
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--ki-related-btn-color, #ED7218);
    text-decoration: none;
    white-space: nowrap;
    transition: color 0.2s ease;
}

.related-kennisitems__more:hover {
    color: var(--ki-related-btn-hover-color, #026601);
}

.related-kennisitems__more-arrow {
    display: inline-block;
    transition: transform 0.2s ease;
}

.related-kennisitems__more:hover .related-kennisitems__more-arrow {
    transform: translateX(4px);
}

.related-kennisitems__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
}

/* ==========================================================================
   8.3. Taxonomy Archive
   ========================================================================== */

/* ── CSS variable defaults ── */
.archive-taxonomy {
    --tax-item-bg:          #ffffff;
    --tax-title-color:      #026601;
    --tax-excerpt-color:    #212529;
    --tax-btn-color:        #ffffff;
    --tax-btn-bg:           #ED7218;
    --tax-btn-hover-color:  #ffffff;
    --tax-btn-hover-bg:     #026601;
    --tax-pag-color:        #026601;
    --tax-pag-active-color: #ffffff;
    --tax-pag-active-bg:    #ED7218;
}

/* ── Archive meta row (result count) ── */
.tax-archive-meta {
    display: flex;
    align-items: center;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--eb-off-white, #efefef);
    margin-bottom: 0;
}

.tax-archive-count {
    font-size: 0.9375rem;
    color: var(--tax-excerpt-color);
    font-weight: 500;
}

/* ── 3-column grid ── */
.tax-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    padding-top: 2rem;
}

/* ── Card ── */
.tax-item {
    display: flex;
    flex-direction: column;
    background-color: var(--tax-item-bg);
    border-radius: 0.5rem;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    transition: box-shadow 0.2s ease-in-out, transform 0.2s ease-in-out;
}

.tax-item:hover {
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.14);
    transform: translateY(-3px);
}

/* ── Thumbnail ── */
.tax-thumbnail {
    display: block;
    overflow: hidden;
    aspect-ratio: 16 / 9;
}

.tax-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.35s ease-in-out;
}

.tax-item:hover .tax-thumbnail img {
    transform: scale(1.04);
}

/* ── Content area ── */
.tax-content {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 1.5rem;
    gap: 0.75rem;
}

/* ── Title ── */
.tax-title {
    font-size: clamp(1.25rem, 2.5vw, 1.5rem);
    margin: 0;
    line-height: 1.3;
}

.tax-title a {
    color: var(--tax-title-color);
    text-decoration: none;
    transition: color 0.15s ease-in-out;
}

.tax-title a:hover {
    color: var(--tax-btn-bg);
}

/* ── Excerpt ── */
.tax-excerpt {
    color: var(--tax-excerpt-color);
    font-size: var(--eb-typography-body);
    line-height: 1.6;
    flex: 1;
}

.tax-excerpt p:last-child {
    margin-bottom: 0;
}

/* ── Read-more button ── */
.tax-read-more {
    align-self: flex-start;
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 0;
    padding: 0.55em 1.1em;
    border-radius: 0.4em;
    font-size: var(--eb-typography-button, 1rem);
    font-weight: 400;
    text-decoration: none;
    background-color: var(--tax-btn-bg);
    color: var(--tax-btn-color);
    transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
}

.tax-read-more::after {
    content: '\2192';
    display: inline-block;
    margin-left: 0.45em;
    color: currentColor;
    transition: transform 0.2s ease-in-out;
}

.tax-read-more:hover {
    background-color: var(--tax-btn-hover-bg);
    color: var(--tax-btn-hover-color);
}

.tax-read-more:hover::after {
    transform: translateX(4px);
}

/* ── Numeric pagination ── */
.tax-pagination {
    display: flex;
    justify-content: center;
    margin-top: 3rem;
    padding-bottom: 1rem;
    gap: 0.5rem;
}

.tax-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.25rem;
    height: 2.25rem;
    padding: 0 0.6rem;
    border-radius: 0.35rem;
    font-size: 0.9375rem;
    font-weight: 600;
    text-decoration: none;
    color: var(--tax-pag-color, var(--eb-navy));
    background-color: transparent;
    border: 1px solid transparent;
    transition: background-color 0.15s ease-in-out,
                color 0.15s ease-in-out,
                border-color 0.15s ease-in-out;
}

.tax-pagination .page-numbers:hover {
    background-color: var(--tax-pag-active-bg, var(--eb-orange));
    color: var(--tax-pag-active-color, #fff);
    border-color: var(--tax-pag-active-bg, var(--eb-orange));
}

.tax-pagination .page-numbers.current {
    background-color: var(--tax-pag-active-bg, var(--eb-orange));
    color: var(--tax-pag-active-color, #fff);
    border-color: var(--tax-pag-active-bg, var(--eb-orange));
    cursor: default;
}

.tax-pagination .page-numbers.dots {
    border-color: transparent;
    background: transparent;
    cursor: default;
    letter-spacing: 0.05em;
}

.tax-pagination .prev.page-numbers,
.tax-pagination .next.page-numbers {
    font-size: 1.1rem;
    padding: 0 0.75rem;
    border: 1px solid var(--tax-pag-active-bg, var(--eb-orange));
    color: var(--tax-pag-active-bg, var(--eb-orange));
}

.tax-pagination .prev.page-numbers:hover,
.tax-pagination .next.page-numbers:hover {
    background-color: var(--tax-pag-active-bg, var(--eb-orange));
    color: var(--tax-pag-active-color, #fff);
}

.tax-pagination__arrow {
    line-height: 1;
}

/* ── Pagination wrapper with total count ── */
.tax-pagination-wrap {
    margin-top: 3rem;
    padding-bottom: 1rem;
}

.tax-pagination-info {
    text-align: center;
    font-size: 0.875rem;
    color: var(--tax-excerpt-color);
    margin: 0 0 0.75rem;
}

/* Reset spacing on the nav when it lives inside the wrap */
.tax-pagination-wrap .tax-pagination {
    margin-top: 0;
    padding-bottom: 0;
}

/* ==========================================================================
   9. Responsive Styles
   ========================================================================== */

/* 9.1. Tablet & Mobile (max-width: 991px) */
@media (max-width: 991px) {

    /* Projecten grid — 2 columns on tablet */
    .projecten-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Kennisitems grid — 2 columns on tablet */
    .kennisitems-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Taxonomy archive grid — 2 columns on tablet */
    .tax-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Single Projecten — stack sidebar below content on tablet */
    .single-projecten-layout {
        grid-template-columns: 1fr;
    }

    .single-projecten-wrap {
        max-width: 100%;
    }

    .single-projecten-hero {
        min-height: 320px;
    }

    /* Single Post — hide social + TOC, show full-width content */
    .single-post-body,
    .single-post-body.no-social,
    .single-post-body.no-toc,
    .single-post-body.no-social.no-toc {
        grid-template-columns: 1fr;
    }

    .single-post-social,
    .single-post-toc {
        display: none;
    }

    .single-post-wrap {
        max-width: 100%;
    }

    /* Single Kennisitems — hide social + TOC, show full-width content */
    .single-kennisitems-body,
    .single-kennisitems-body.no-social,
    .single-kennisitems-body.no-toc,
    .single-kennisitems-body.no-social.no-toc {
        grid-template-columns: 1fr;
    }

    .single-kennisitems-social,
    .single-kennisitems-toc {
        display: none;
    }

    .single-kennisitems-wrap {
        max-width: 100%;
    }

    /* Related kennisitems — 2 columns on tablet */
    .related-kennisitems__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Footer Columns */
    .footer-widgets-columns {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--footer-widget-gap-tablet, 30px);
    }
    
    .footer-widgets-columns.columns-1 {
        grid-template-columns: 1fr;
    }

    /* Header Logic */
    .desktop-header-bottom {
        display: none;
    }

    .header-actions {
        gap: 0.5rem;
    }

    /* Header Widgets & Search */
    /* Hide top bar widgets on mobile */
    .header-top .header-actions .widget, .header-top .header-search, .header-top .header-actions .header-cta-secondary {
        display: none;
    }

    /* Show widgets inside mobile menu */
    .mobile-header-widget {
        display: block;
        margin-bottom: 2rem;
        border-bottom: 1px solid #ffffff;
        padding-bottom: 1rem;
    }
    
    .mobile-header-widget ul {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.5rem;
    }

    /* Mobile Header Panel */
    .mobile-header-bottom {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        background-color: var(--eb-mob-nav-bg);
        transform: translateY(100%);
        opacity: 0;
        visibility: hidden;
        transition: all 0.3s cubic-bezier(0.77, 0.2, 0.05, 1.0);
        z-index: 90;
        overflow-x: hidden; /* Prevent horizontal scroll from sliding menus */
        overflow-y: auto;
        
        border-bottom: none;
        display: flex;
        flex-direction: column;
    }

    .mobile-header-bottom.toggled {
        transform: translateY(0);
        opacity: 1;
        visibility: visible;
    }

    /* Mobile Menu Header (Label) */
    .mobile-menu-header {
        padding: 0 20px;
        color: rgba(0,0,0,.3);
        text-align: center;
        font-size: 1rem;
        border-top: 1px solid rgba(0, 0, 0, .15);
        border-bottom: 1px solid rgba(0, 0, 0, .15);
        min-height: 50px;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: all 0.3s ease;
        
    }

    .mobile-menu-header.active {
        display: none;
    }

    /* Drill-down Menu container */
    .main-navigation .menu-items {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        padding: 0;
        width: 100%;
        position: relative;
        transition: transform 0.3s ease;
    }

    /* Mobile Menu Links */
    span.menu-arrow-icon {
        display: inline-flex;
    }
    
    .menu-items.mobile-menu a {
        width: 100%;
        display: block;
        color: var(--eb-mob-nav-link-color);
    }
    
    .menu-items.mobile-menu a:hover, 
    .menu-items.mobile-menu .menu-arrow-icon:hover {
        background: rgba(0,0,0,.03);
        cursor: pointer;
    }

    /* List Items */
    .main-navigation .menu-items li {
        border-bottom: 1px solid var(--eb-mob-nav-item-border);
        width: 100%;
    }
    
    .menu-items.mobile-menu > li.menu-item-has-children {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    
    .menu-items.mobile-menu > li.menu-item-has-children.active {
        flex-direction: row-reverse;
        border-top: 1px solid rgba(0, 0, 0, .15);
    }
    
    .menu-items.mobile-menu > li.menu-item-has-children.active > a {
        opacity: .5;
    }

    .mobile-menu.child-nav-open > li {display: none;}

    .mobile-menu.child-nav-open > li.menu-item-has-children {
        display: none;
    }
    
    .mobile-menu.child-nav-open > li.menu-item-has-children.active {
        display: flex;
    }
    
    /* Arrow Icon (SVG) */
    .menu-arrow-icon {
        width: 24px;
        height: 24px;
        fill: none;
        stroke: var(--eb-mob-nav-icon-color);
        stroke-width: 2;
        transition: transform 0.2s;
    }

    /* Submenu (Hidden/Slid out by default) */
    .main-navigation .mobile-menu .sub-menu {
        margin-top: 1px !important;
        height: calc(100vh - 80px);
        background-color: var(--eb-mob-nav-submenu-bg);
        z-index: 100;
        padding: 0;
        box-sizing: border-box;
        transform: translateX(100%);
        transition: transform 0.3s ease;
        opacity: 1;
        visibility: visible;
        display: block;
        border: none;
        box-shadow: none;
        overflow-y: auto;
    }
    
    /* Active Submenu */
    .main-navigation .sub-menu.active {
        transform: translateX(0);
    }

    /* Back Button */
    .menu-back-btn {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        width: 100%;
        padding: 1rem 0;
        margin-bottom: 1rem;
        border-bottom: 1px solid var(--eb-mob-nav-item-border);
        background: transparent;
        border: none;
        color: var(--eb-mob-nav-link-color);
        font-weight: 600;
        font-size: 1rem;
        cursor: pointer;
        text-align: left;
    }

    .menu-back-btn svg {
        transform: rotate(180deg); /* Rotate arrow to point left */
        width: 20px;
        height: 20px;
        stroke: var(--eb-mob-nav-icon-color);
    }

    /* Floating Hamburger Button (Fixed Bottom Center) */
    .mobile-nav-toggle {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        position: fixed;
        bottom: 30px;
        left: 50%;
        transform: translateX(-50%);
        width: 60px;
        height: 60px;
        border-radius: 50%;
        background-color: var(--eb-mob-nav-toggle-bg);
        border: none;
        box-shadow: 0 4px 20px rgba(0,0,0,0.15);
        z-index: 10000;
        cursor: pointer;
        transition: all 0.3s ease;
    }

    .mobile-nav-toggle:hover {
        background-color: var(--eb-mob-nav-toggle-bg);
    }

    /* Bars (Hamburger) */
    .mobile-nav-toggle .icon-bar {
        width: 24px;
        height: 2px;
        background-color: var(--eb-mob-nav-toggle-icon-color);
        margin: 2px 0;
        transition: all 0.3s ease;
        position: relative;
    }

    /* Open State: Button becomes Blue X */
    .mobile-nav-toggle[aria-expanded="true"] {
        background-color: var(--eb-mob-nav-toggle-open-bg);
        box-shadow: none;
        border: 1px solid #eee;
    }

    /* Transform bars to X */
    .mobile-nav-toggle[aria-expanded="true"] .icon-bar:nth-child(2) {
        transform: rotate(45deg);
        top: 6px;
        background-color: var(--eb-mob-nav-toggle-icon-color);
    }

    .mobile-nav-toggle[aria-expanded="true"] .icon-bar:nth-child(3) {
        opacity: 0;
    }

    .mobile-nav-toggle[aria-expanded="true"] .icon-bar:nth-child(4) {
        transform: rotate(-45deg);
        top: -6px;
        background-color: var(--eb-mob-nav-toggle-icon-color);
    }
}

/* 9.2. Medium Screens (max-width: 768px) */
@media (max-width: 768px) {
	.alignwide {
		margin-left: 0;
		margin-right: 0;
		width: 100%;
	}
}

/* 9.3. Mobile Screens (max-width: 767px) */
@media (max-width: 767px) {

    /* Projecten grid — single column on mobile */
    .projecten-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    /* Kennisitems grid — single column on mobile */
    .kennisitems-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    /* Taxonomy archive grid — single column on mobile */
    .tax-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .tax-archive-hero {
        padding: 60px 0;
    }

    .kennisitems-categorie-section {
        padding-top: 2rem;
    }

    .projecten-archive-hero {
        padding: 60px 0;
    }

    /* Single Projecten — compact hero on mobile */
    .single-projecten-hero {
        min-height: 240px;
        border-radius: 0.4rem;
    }

    .related-projecten {
        padding: 2.5rem 0;
    }

    /* Related kennisitems — single column on mobile */
    .related-kennisitems__grid {
        grid-template-columns: 1fr;
    }

    .related-kennisitems {
        padding: 2.5rem 0;
    }

    .related-kennisitems__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .footer-widgets-wrapper {
        padding-top: 50px;
        padding-bottom: 50px;
    }
    /* Footer Vertical Stack */
    .footer-widgets-columns, 
    .footer-widgets-columns.columns-2,
    .footer-widgets-columns.columns-3,
    .footer-widgets-columns.columns-4,
    .footer-widgets-columns.columns-5
    {
        grid-template-columns: 1fr;
        gap: var(--footer-widget-gap-mobile, 20px);
    }

    /* Copyright Vertical Stack */
    .copyright-bar {
        flex-direction: column;
        text-align: center;
        justify-content: center;
    }
    
    .copyright-menu ul {
        justify-content: center;
    }

    .ki-author-box {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

}

/* ==========================================================================
   10. Search Results (search.php)
   ========================================================================== */

/* ── Hero ── */
.search-results-hero {
    background-color: #026601;
    padding: 80px 0;
    position: relative;
}

.search-results-hero .page-hero-title {
    color: #ffffff;
    margin-bottom: 1.5rem;
}

.search-results-hero__query {
    color: #ED7218;
}

.search-form label {
    flex: 1;
}

input.search-field {
    width: 100%;
}

/* Reuse the header search form inside the hero with a wider, lighter look */
.search-results-hero__form .search-form {
    display: flex;
    align-items: center;
    background-color: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: 50px;
    padding: 0.35rem 0.35rem 0.35rem 1.25rem;
    max-width: 540px;
    gap: 0.5rem;
}

.search-results-hero__form .search-field {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: #ffffff;
    font-size: 1rem;
    padding: 0.5rem 0;
}

.search-results-hero__form .search-field::placeholder {
    color: rgba(255, 255, 255, 0.55);
}

.search-results-hero__form .search-submit {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: #ED7218;
    color: #ffffff;
    border: none;
    border-radius: 50px;
    padding: 0.55rem 1.25rem;
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.2s ease-in-out;
}

.search-results-hero__form .search-submit:hover {
    background-color: #026601;
}

/* ── Results count ── */
.search-results-count {
    font-size: 0.9rem;
    color: #6c757d;
    margin-bottom: 1.5rem;
}

/* ── Results grid (3 columns, mirrors kennisitems-grid) ── */
.search-results-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}

/* ── Single result card (mirrors kennisitems-item) ── */
.search-result-item {
    display: flex;
    flex-direction: column;
    background-color: #ffffff;
    border-radius: 0.5rem;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    transition: box-shadow 0.2s ease-in-out, transform 0.2s ease-in-out;
}

.search-result-item:hover {
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.14);
    transform: translateY(-3px);
}

/* ── Thumbnail ── */
.search-result-thumbnail {
    display: block;
    overflow: hidden;
    aspect-ratio: 16 / 9;
}

.search-result-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.35s ease-in-out;
}

.search-result-item:hover .search-result-thumbnail img {
    transform: scale(1.04);
}

/* ── Content ── */
.search-result-content {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 1.5rem;
    gap: 0.75rem;
}

/* ── Post-type badge (mirrors projecten-cat-tag) ── */
.search-result-type-tag {
    display: inline-block;
    align-self: flex-start;
    padding: 4px 8px;
    border-radius: 0.8rem;
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    background-color: #e0f0f5;
    color: #026601;
}

/* ── Title ── */
.search-result-title {
    font-size: clamp(1.1rem, 2vw, 1.35rem);
    margin: 0;
    line-height: 1.3;
}

.search-result-title a {
    color: #026601;
    text-decoration: none;
    transition: color 0.15s ease-in-out;
}

.search-result-title a:hover {
    color: #ED7218;
}

/* ── Excerpt ── */
.search-result-excerpt {
    color: #212529;
    font-size: var(--eb-typography-body);
    line-height: 1.6;
    flex: 1;
}

.search-result-excerpt p:last-child {
    margin-bottom: 0;
}

/* ── Read-more link (outline, mirrors kennisitems-read-more) ── */
.search-result-read-more {
    align-self: flex-start;
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    padding: 0.55em 1.1em;
    border-radius: 0.4em;
    font-size: var(--eb-typography-button, 1rem);
    font-weight: 400;
    text-decoration: none;
    background-color: transparent;
    color: #ED7218;
    border: 1px solid #ED7218;
    transition: background-color 0.2s ease-in-out,
                color 0.2s ease-in-out,
                border-color 0.2s ease-in-out;
}

.search-result-read-more::after {
    content: '\2192';
    display: inline-block;
    margin-left: 0.45em;
    color: currentColor;
    transition: transform 0.2s ease-in-out;
}

.search-result-read-more:hover {
    background-color: #ED7218;
    color: #ffffff;
    border-color: #ED7218;
}

.search-result-read-more:hover::after {
    transform: translateX(4px);
}

/* ── Pagination (mirrors projecten-pagination) ── */
.search-results-pagination {
    margin-top: 2.5rem;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.search-results-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 38px;
    height: 38px;
    padding: 0 0.6rem;
    border-radius: 0.4rem;
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    color: #026601;
    background-color: #f0f4f8;
    border: 1px solid #e0e6ec;
    transition: background-color 0.15s ease-in-out, color 0.15s ease-in-out;
}

.search-results-pagination .page-numbers:hover,
.search-results-pagination .page-numbers.current {
    background-color: #ED7218;
    color: #ffffff;
    border-color: #ED7218;
}

.search-results-pagination__arrow {
    font-size: 1rem;
}

/* ── No-results state ── */
.search-no-results {
    margin: 0 auto;
    padding: 2rem 0;
}

.search-no-results__message {
    font-size: 1rem;
    color: #6c757d;
    margin-bottom: 1.5rem;
}

.search-no-results .search-form {
    display: flex;
    align-items: center;
    background-color: #f0f4f8;
    border: 1px solid #e0e6ec;
    border-radius: 50px;
    padding: 0.35rem 0.35rem 0.35rem 1.25rem;
    gap: 0.5rem;
}

.search-no-results .search-field {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: #026601;
    font-size: 1rem;
    padding: 0.5rem 0;
}

.search-no-results .search-submit {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: #ED7218;
    color: #ffffff;
    border: none;
    border-radius: 50px;
    padding: 0.55rem 1.25rem;
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.2s ease-in-out;
}

.search-no-results .search-submit:hover {
    background-color: #026601;
}

/* ==========================================================================
   11. 404 Page (404.php)
   ========================================================================== */

/* ── Hero ── */
.error-404-hero {
    background-color: #026601;
    padding: 80px 0;
}

.error-404-hero__code {
    font-size: clamp(5rem, 10vw, 10rem);
    font-weight: 800;
    line-height: 1;
    color: rgba(0, 172, 221, 0.25);
    margin: 0 0 0.25rem;
    letter-spacing: -0.04em;
}

.error-404-hero__title {
    color: #ffffff;
    margin: 0 0 1rem;
}

.error-404-hero__subtitle {
    color: rgba(255, 255, 255, 0.75);
    font-size: 1.05rem;
    margin: 0;
    max-width: 520px;
}

/* ── Body ── */
.error-404-body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    padding-top: 1rem;
}

/* ── Search box ── */
.error-404-search__heading,
.error-404-links__heading {
    font-size: 1.2rem;
    color: #026601;
    margin: 0 0 0.5rem;
}

.error-404-search__description {
    color: #6c757d;
    font-size: 0.95rem;
    margin: 0 0 1.25rem;
}

.error-404-search .search-form {
    display: flex;
    align-items: center;
    background-color: #f0f4f8;
    border: 1px solid #e0e6ec;
    border-radius: 50px;
    padding: 0.35rem 0.35rem 0.35rem 1.25rem;
    gap: 0.5rem;
}

.error-404-search .search-field {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: #026601;
    font-size: 1rem;
    padding: 0.5rem 0;
}

.error-404-search .search-field::placeholder {
    color: #adb5bd;
}

.error-404-search .search-submit {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: #ED7218;
    color: #ffffff;
    border: none;
    border-radius: 50px;
    padding: 0.55rem 1.25rem;
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.2s ease-in-out;
}

.error-404-search .search-submit:hover {
    background-color: #026601;
}

/* ── Quick links ── */
.error-404-links__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.error-404-links__list li a {
    display: inline-flex;
    align-items: center;
    color: #026601;
    text-decoration: none;
    font-size: 0.95rem;
    transition: color 0.15s ease-in-out;
}

.error-404-links__list li a::before {
    content: '\2192';
    margin-right: 0.5em;
    color: #ED7218;
    transition: transform 0.2s ease-in-out;
}

.error-404-links__list li a:hover {
    color: #ED7218;
}

.error-404-links__list li a:hover::before {
    transform: translateX(4px);
}

/* ── Responsive overrides for sections 10 & 11 ──
   These must live AFTER the base rules to win the cascade.        */
@media (max-width: 991px) {
    .search-results-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 767px) {
    .search-results-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .search-results-hero,
    .error-404-hero {
        padding: 60px 0;
    }

    .error-404-body {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }

    .error-404-hero__code {
        font-size: clamp(5rem, 20vw, 8rem);
    }
	
	.wp-block-energieburcht-carousel .kt-blocks-info-box-media {
		margin-right: 0 !important;
	}
}
