/*
Theme Name: Koper-ICT Thema
Theme URI: https://www.koper-ict.nl/
Author: Koper-ICT
Author URI: https://www.koper-ict.nl/
Description: Modern B2B IT-theme voor Koper-ICT met vaste homepage lay-out.
Version: 0.1.96
Text Domain: koper-workplace
Update URI: false
*/

:root {
    /* ── Dark mode tokens (default) ── */
    --kp-bg: #06090f;
    --kp-bg-alt: #0f1a26;
    --kp-bg-card: rgba(0,84,126,0.12);
    --kp-bg-header: rgba(20,32,46,0.96);
    --kp-bg-gradient: linear-gradient(to bottom, #24364d 0%, #152030 35%, #06090f 100%);
    --kp-bg-static: linear-gradient(to bottom, #24364d 0%, #152030 35%, #06090f 100%);

    --kp-primary: #00547e;
    --kp-primary-soft: rgba(0, 84, 126, 0.14);
    --kp-primary-light: #b7e0f1;
    --kp-accent: #ec6719;
    --kp-accent-strong: #bd1522;
    --kp-form-accent: #5CA1C7;

    --kp-text: #f5f7ff;
    --kp-text-muted: #c6d0ea;
    --kp-border: rgba(255,255,255,0.08);
    --kp-radius: 18px;
    --kp-max-width: 1200px;
    /* Font-strategie:
       Moderniz is een display-font en oogt optisch groot. Daarom gebruiken we het
       alleen voor koppen/impact. Body-tekst blijft een leesbare sans voor rust.
    */
    --kp-font-display: "Moderniz", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --kp-font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

    /* Overlay kleuren — dark mode defaults */
    --kp-overlay-sm:  rgba(0,0,0,0.22);
    --kp-overlay-md:  rgba(0,0,0,0.55);
    --kp-overlay-lg:  rgba(0,0,0,0.85);
    --kp-glass:       rgba(255,255,255,0.04);
    --kp-glass-border: rgba(255,255,255,0.10);
    --kp-meta-text:   rgba(255,255,255,0.82);
    --kp-shadow:      0 2px 4px rgba(0,0,0,0.85), 0 0 10px rgba(0,0,0,0.60), 0 0 2px rgba(0,0,0,0.95);
    --kp-shadow-sm:   0 2px 4px rgba(0,0,0,0.75), 0 0 8px rgba(0,0,0,0.55);
    --kp-text-shadow: var(--kp-text-shadow);
}

/* ── Light mode tokens ── */
.kp-theme-light,
body.kp-theme-light,
html.kp-theme-light {
    --kp-bg: #eef2f7;
    --kp-bg-alt: #e2e8f0;
    --kp-bg-card: rgba(0,84,126,0.07);
    --kp-bg-header: rgba(238,242,247,0.96);
    --kp-bg-gradient: linear-gradient(to bottom, #d6e8f5 0%, #dff0f8 35%, #eef2f7 100%);
    --kp-bg-static: linear-gradient(to bottom, #d6e8f5 0%, #dff0f8 35%, #eef2f7 100%);

    --kp-primary: #00547e;
    --kp-primary-soft: rgba(0, 84, 126, 0.10);
    --kp-primary-light: #005a8a;
    --kp-accent: #d45e10;
    --kp-accent-strong: #a51020;
    --kp-form-accent: #3a86aa;

    --kp-text: #0f1923;
    --kp-text-muted: #3d5166;
    --kp-border: rgba(0,0,0,0.10);

    /* Overlay kleuren — light mode overrides */
    --kp-overlay-sm:  rgba(0,84,126,0.08);
    --kp-overlay-md:  rgba(0,84,126,0.12);
    --kp-overlay-lg:  rgba(0,84,126,0.18);
    --kp-glass:       rgba(0,0,0,0.04);
    --kp-glass-border: rgba(0,0,0,0.10);
    --kp-meta-text:   rgba(15,25,35,0.80);
    --kp-shadow:      0 2px 4px rgba(0,0,0,0.12), 0 0 10px rgba(0,0,0,0.08), 0 0 2px rgba(0,0,0,0.10);
    --kp-shadow-sm:   0 2px 4px rgba(0,0,0,0.10), 0 0 8px rgba(0,0,0,0.06);
    --kp-text-shadow: none;
}

/* ── Auto: volgt OS instelling ── */
@media (prefers-color-scheme: light) {
    body:not(.kp-theme-dark):not(.kp-theme-light) {
        --kp-bg: #eef2f7;
        --kp-bg-alt: #e2e8f0;
        --kp-bg-card: rgba(0,84,126,0.07);
        --kp-bg-header: rgba(238,242,247,0.96);
        --kp-bg-gradient: linear-gradient(to bottom, #d6e8f5 0%, #dff0f8 35%, #eef2f7 100%);
        --kp-bg-static: linear-gradient(to bottom, #d6e8f5 0%, #dff0f8 35%, #eef2f7 100%);
        --kp-primary: #00547e;
        --kp-primary-soft: rgba(0, 84, 126, 0.10);
        --kp-primary-light: #005a8a;
        --kp-accent: #d45e10;
        --kp-accent-strong: #a51020;
        --kp-form-accent: #3a86aa;
        --kp-text: #0f1923;
        --kp-text-muted: #3d5166;
        --kp-border: rgba(0,0,0,0.10);
        --kp-overlay-sm:  rgba(0,84,126,0.08);
        --kp-overlay-md:  rgba(0,84,126,0.12);
        --kp-overlay-lg:  rgba(0,84,126,0.18);
        --kp-glass:       rgba(0,0,0,0.04);
        --kp-glass-border: rgba(0,0,0,0.10);
        --kp-meta-text:   rgba(15,25,35,0.80);
        --kp-shadow:      0 2px 4px rgba(0,0,0,0.12), 0 0 10px rgba(0,0,0,0.08), 0 0 2px rgba(0,0,0,0.10);
        --kp-shadow-sm:   0 2px 4px rgba(0,0,0,0.10), 0 0 8px rgba(0,0,0,0.06);
        --kp-text-shadow: none;
    }
}

/* Custom theme font */
@font-face {
    font-family: "Moderniz";
    src: url("assets/fonts/Moderniz.otf") format("opentype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}


html {
    background: var(--kp-bg-gradient);
    background-color: var(--kp-bg);
    transition: background 250ms ease, background-color 250ms ease, color 250ms ease;
}

body {
    margin: 0;
    font-family: var(--kp-font-sans);
    background: var(--kp-bg-gradient);
    background-color: var(--kp-bg);
    color: var(--kp-text);
    line-height: 1.6;
    transition: background 250ms ease, color 250ms ease;
}

/* Display-font alleen op koppen/impact (body blijft leesbaar) */
h1, h2, h3, h4, h5, h6,
.kp-hero h1,
.kp-section-title,
.kp-card h3,
.kp-step h3,
.kp-stat strong,
.kp-btn {
    font-family: var(--kp-font-display);
    letter-spacing: 0.01em;
}

a {
    color: inherit;
    text-decoration: none;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* Container */
.kp-container {
    width: 100%;
    max-width: var(--kp-max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
}

/* Header */
.kp-header {
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: blur(14px);
    background: linear-gradient(to bottom, var(--kp-bg-header), color-mix(in srgb, var(--kp-bg) 90%, transparent));
    border-bottom: 1px solid var(--kp-border);
}

.kp-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 72px;
}

.kp-logo {
    display: flex;
    align-items: center;
    gap: .75rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    font-size: .9rem;
}

.kp-logo img {
    max-height: 48px;
    width: auto;
}

.kp-logo-fallback-text {
    background: linear-gradient(120deg, var(--kp-primary), var(--kp-primary-light));
    -webkit-background-clip: text;
    color: transparent;
}

.kp-main-nav {
    display: flex;
    align-items: center;
    gap: 2rem;
    font-size: .9rem;
}

.kp-main-nav a {
    color: var(--kp-text-muted);
    position: relative;
    padding-bottom: 2px;
}

.kp-main-nav a:hover {
    color: var(--kp-text);
}

.kp-main-nav a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -4px;
    width: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--kp-primary), var(--kp-accent));
    transition: width .16s ease-out;
}

.kp-main-nav a:hover::after {
    width: 18px;
}

/* Buttons basis */
.kp-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    padding: .6rem 1.3rem;
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: .9rem;
    font-weight: 500;
    cursor: pointer;
    transition: transform .1s ease, box-shadow .1s ease, background .15s ease, border-color .15s ease;
}

.kp-btn-ghost {
    background: transparent;
    color: var(--kp-text-muted);
    border-color: var(--kp-border);
}

.kp-btn-ghost:hover {
    color: var(--kp-text);
    border-color: var(--kp-primary);
}

/* Secties algemeen */
.kp-section {
    padding: 2.5rem 0;
}

.kp-section-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 1rem;
    margin-bottom: 1.4rem;
}

.kp-section-kicker {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .18em;
    color: var(--kp-text-muted);
}

.kp-section-title {
    font-size: 1.35rem;
}

.kp-section-sub {
    max-width: 26rem;
    font-size: .9rem;
    color: var(--kp-text-muted);
}

/* Hero */
.kp-hero {
    padding: 4.5rem 0 3rem;
}

.kp-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
    gap: 3rem;
    align-items: center;
}

.kp-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .2rem .7rem;
    border-radius: 999px;
    background: var(--kp-glass);
    border: 1px solid var(--kp-border);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--kp-text-muted);
}

.kp-hero-title {
    margin: 1.1rem 0 .6rem;
    font-size: clamp(2.3rem, 3vw + 1rem, 3.1rem);
    line-height: 1.1;
}

/* Improve hero lead readability on bright moving background */
.kp-hero-lead {
  text-shadow: var(--kp-shadow);
}

.kp-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
    margin-top: 1.7rem;
}

.kp-hero-meta {
    margin-top: 1.8rem;
    display: flex;
    flex-wrap: wrap;
    gap: 1.0rem;
    font-size: .82rem;
    letter-spacing: 0.01em;
}

/* Hero meta badges: beter leesbaar op dynamische achtergrond */
.kp-hero-meta span {
    color: var(--kp-meta-text);
    text-shadow: var(--kp-text-shadow);
    background: var(--kp-overlay-sm);
    border: 1px solid var(--kp-glass-border);
    padding: .35rem .7rem;
    border-radius: 999px;
    backdrop-filter: blur(6px);
}

/* Hero panel rechts */
.kp-hero-panel {
    /* Zelfde “glass” doorzichtigheid als de bouwblokken */
    background: linear-gradient(150deg, var(--kp-bg-card), color-mix(in srgb, var(--kp-bg) 90%, transparent));
    border-radius: 24px;
    border: 1px solid var(--kp-border);
    padding: 1.6rem 1.4rem;
    box-shadow: 0 14px 34px var(--kp-overlay-md);
    position: relative;
    overflow: hidden;
}

/* Subtiele top-left highlight zoals eerder, maar zonder “massief blok” */
.kp-hero-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(circle at 18% 14%, var(--kp-overlay-md), transparent 62%);
    opacity: 0.35;
}

.kp-hero-panel > * {
    position: relative;
    z-index: 1;
}

.kp-hero-panel-text {
    margin-top: .7rem;
    font-size: .85rem;
    color: var(--kp-text);
    text-shadow: var(--kp-text-shadow);
}

.kp-hero-panel-tag {
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .16em;
    color: var(--kp-text-muted);
    margin-bottom: .7rem;
}

.kp-hero-panel-title {
    font-size: 1.05rem;
    margin-bottom: .4rem;
}

.kp-hero-panel-metric {
    font-size: 1.8rem;
    font-weight: 700;
}

.kp-hero-panel-metric span {
    font-size: .8rem;
    font-weight: 400;
    color: var(--kp-text-muted);
    margin-left: .3rem;
}

.kp-hero-panel-footer {
    margin-top: 1.2rem;
    padding-top: 1.1rem;
    border-top: 1px dashed var(--kp-border);
    font-size: .8rem;
    color: var(--kp-text-muted);
    text-shadow: var(--kp-text-shadow);
}

/* Service / bouwblokken */
.kp-service-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.1rem;
}

.kp-service-card {
    padding: 1.1rem;
    border-radius: var(--kp-radius);
    border: 1px solid var(--kp-border);
    background: linear-gradient(150deg, var(--kp-bg-card), color-mix(in srgb, var(--kp-bg) 90%, transparent));
    /* Subtiele “zweef”-schaduw in rust */
    box-shadow: 0 14px 34px var(--kp-overlay-md);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 145px;
}

.kp-service-label {
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--kp-text-muted);
    margin-bottom: .35rem;
}

.kp-service-title {
    font-weight: 600;
    margin-bottom: .35rem;
}

.kp-service-text {
    font-size: .85rem;
    color: var(--kp-text-muted);
}

.kp-service-link {
    margin-top: .7rem;
    font-size: .78rem;
    color: var(--kp-accent);
}

/* Proces / stappen */
.kp-process-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.kp-process-step {
    padding: 1rem;
    border-radius: var(--kp-radius);
    border: 1px dashed var(--kp-border);
    background: var(--kp-bg-alt);
    font-size: .86rem;
}

.kp-process-badge {
    font-size: .75rem;
    color: var(--kp-text-muted);
    text-transform: uppercase;
    letter-spacing: .18em;
}

.kp-process-title {
    margin: .4rem 0 .2rem;
    font-weight: 600;
}

/* Testimonials */
.kp-testimonials {
    display: grid;
    grid-template-columns: 1.2fr .9fr;
    gap: 1.7rem;
    align-items: flex-start;
}

.kp-testimonial-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.kp-testimonial-card {
    padding: 1rem;
    border-radius: var(--kp-radius);
    border: 1px solid var(--kp-border);
    background: color-mix(in srgb, var(--kp-bg) 92%, transparent);
    font-size: .85rem;
}

.kp-testimonial-name {
    margin-top: .6rem;
    font-weight: 600;
}

.kp-testimonial-org {
    font-size: .78rem;
    color: var(--kp-text-muted);
}

/* Page content */
.kp-page-content {
    font-size: .95rem;
    color: var(--kp-text);
}

.kp-page-content p {
    margin-bottom: 1rem;
}

/* Footer */
.kp-footer {
    border-top: 1px solid var(--kp-border);
    padding: 2.2rem 0 1.4rem;
    font-size: .8rem;
    color: var(--kp-text-muted);
}

.kp-footer-top {
    display: flex;
    justify-content: space-between;
    gap: 2rem;
    margin-bottom: 1.4rem;
}

.kp-footer-col-title {
    font-size: .85rem;
    font-weight: 600;
    margin-bottom: .6rem;
}

.kp-footer-links {
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

.kp-footer-links .kp-footer-menu {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

.kp-footer-links .kp-footer-menu li {
    margin: 0;
    padding: 0;
}

.kp-footer-links .kp-footer-menu a {
    color: inherit;
    text-decoration: none;
}

.kp-footer-links .kp-footer-menu a:hover {
    color: var(--kp-text);
}

/* Footer submenu support (always visible, stacked) */
.kp-footer-links .kp-footer-menu .sub-menu {
    margin: .35rem 0 0 .9rem;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

.kp-footer-links .kp-footer-menu .sub-menu a {
    font-size: .95em;
    opacity: .9;
}

/* Responsive */
@media (max-width: 900px) {
    .kp-main-nav {
        display: none;
    }
    .kp-hero-grid {
        grid-template-columns: minmax(0, 1fr);
    }
    .kp-service-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .kp-process-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .kp-testimonials {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 600px) {
    .kp-service-grid,
    .kp-process-grid,
    .kp-testimonial-list {
        grid-template-columns: minmax(0, 1fr);
    }
    .kp-header-inner {
        justify-content: space-between;
    }
}


/* ===== Custom overrides from Extra CSS ===== */

/* Header CTA tekst exact centreren */
.kp-header .kp-btn {
    line-height: 1;
    padding-top: 0.6rem;
    padding-bottom: 0.6rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
/* --- KOPER-ICT PREMIUM CTA BUTTON --- */

/* Basis CTA */
.kp-btn-primary {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;

    padding: 0.65rem 1.6rem;
    border-radius: 999px;
    font-size: 0.92rem;
    font-weight: 500;

    color: #ffffff !important;
    border: none;

    /* NIEUWE GRADIENT: geen wit meer aan de rand */
    background: linear-gradient(135deg,
        #004568 0%,
        #006a98 40%,
        #b7e0f1 100%
    );

    /* zachte glow */
    box-shadow: 0 6px 18px rgba(0, 110, 165, 0.45);

    /* animaties */
    transition:
        transform .18s ease,
        box-shadow .22s ease,
        background-position .35s ease;
    background-size: 140% 140%;
}

/* Hover animatie */
.kp-btn-primary:hover {
    transform: translateY(-2px);

    /* dynamische glow */
    box-shadow:
        0 12px 28px rgba(0,110,165,0.55),
        0 0 24px rgba(183,224,241,0.4);

    /* licht schuiven voor bewegend effect */
    background-position: 100% 0%;
}

/* Active (klik) effect */
.kp-btn-primary:active {
    transform: translateY(0);
    box-shadow: 0 4px 10px rgba(0,110,165,0.45);
}

/* Header-knop: gecentreerde tekst */
.kp-header .kp-btn-primary {
    line-height: 1 !important;
    padding-top: 0.70rem !important;
    padding-bottom: 0.70rem !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Fix voor wit puntje aan de rand */
.kp-btn-primary::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;

    /* extra subtiele overlay die de linkerhoek donkerder maakt */
    background: radial-gradient(circle at left center,
        rgba(0,0,0,0.25) 0%,
        rgba(0,0,0,0) 35%
    );
}
/* Verwijder het gekleurde menu-hover streepje onder de header CTA */
.kp-header .kp-btn-primary::after {
    content: none !important;
}

/* Extra: zorg dat de CTA nooit dezelfde underline hover krijgt als menulinks */
.kp-header .kp-btn-primary,
.kp-header .kp-btn-primary:hover,
.kp-header .kp-btn-primary:focus {
    box-shadow: 0 12px 30px rgba(0, 84, 126, .45); /* behoud glow */
    border-bottom: none !important;
}
/* --- Hover effect voor de 4 service-kaarten --- */
.kp-service-card {
    position: relative;
    transition:
        transform .25s ease,
        box-shadow .35s ease,
        border-color .25s ease,
        background .35s ease;
    cursor: pointer;
}

/* Hover stijl */
.kp-service-card:hover {
    transform: translateY(-6px);
    box-shadow:
        0 18px 40px rgba(0, 84, 126, 0.25),
        0 0 22px rgba(0, 84, 126, 0.10);
    border-color: rgba(183, 224, 241, 0.25);
    background: linear-gradient(
        150deg,
        rgba(0,84,126,0.20),
        color-mix(in srgb, var(--kp-bg) 92%, transparent)
    );
}

/* Subtiele animated highlight */
.kp-service-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: var(--kp-radius);
    background: radial-gradient(
        circle at top right,
        rgba(255,255,255,0.07),
        rgba(255,255,255,0) 45%
    );
    opacity: 0;
    transition: opacity .35s ease;
}

.kp-service-card:hover::after {
    opacity: 1;
}

/* Accent-lijn onderaan tijdens hover */
.kp-service-card::before {
    content: "";
    position: absolute;
    left: 28px;
    right: 28px;
    bottom: 0;
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--kp-accent), var(--kp-primary-light));
    opacity: 0;
    transform: scaleX(0.4);
    transition:
        opacity .35s ease,
        transform .35s ease;
}

.kp-service-card:hover::before {
    opacity: 1;
    transform: scaleX(1);
}
/* Hele kaart klikbaar maken */
.kp-service-card {
    position: relative;
    cursor: pointer;
}

/* Onzichtbare klikbare overlay */
.kp-service-card > a.kp-service-link {
    position: absolute !important;
    inset: 0;
    z-index: 10;
    opacity: 0;
}

/* Zorg dat tekst-links niet zichtbaar zijn (maar blijven bestaan voor SEO) */
.kp-service-card .kp-service-link {
    display: block;
    height: 100%;
    width: 100%;
}
/* (Fade removed) */
/* ===== Logo schaal (300x80 weergave, retina-safe) ===== */
.kp-header .custom-logo,
.kp-header .custom-logo-link img,
.kp-logo img {
    width: 300px !important;
    height: auto !important;
    max-height: 80px !important;
    object-fit: contain !important;
}
/* ===== Ultra-Glass Header (Variant A iOS/VisionOS style) ===== */
.kp-header {
    backdrop-filter: blur(26px) saturate(180%);
    -webkit-backdrop-filter: blur(26px) saturate(180%);

    background: color-mix(in srgb, var(--kp-bg) 38%, transparent);
    border-bottom: 1px solid var(--kp-border);

    position: sticky;
    top: 0;
    z-index: 999;
}

/* Licht glanzende glas-sheen */
.kp-header::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    border-radius: inherit;
    background: linear-gradient(
        to bottom,
        rgba(255, 255, 255, 0.12),
        rgba(255, 255, 255, 0.02)
    );
    opacity: 0.35;
}

/* Subtiele inner shadow voor extra diepte */
.kp-header::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    border-radius: inherit;
    box-shadow: inset 0 0 40px rgba(0, 0, 0, 0.25);
    opacity: 0.25;
}



/* Achtergrond via CSS variabelen (dark/light mode) */
body {
    background: var(--kp-bg-gradient) !important;
    background-color: var(--kp-bg) !important;
}
/* Logo scaling: 300x60 max in header */
.kp-header .custom-logo,
.kp-header .custom-logo-link img,
.kp-logo img {
    width: 300px !important;
    height: auto !important;
    max-height: 60px !important;
    object-fit: contain !important;
}

/* Fix lichte rand rechts/onder hero-panel, behoud schaduw */
.kp-hero-panel {
    position: relative;
    border: 1px solid var(--kp-border);
    background-clip: padding-box;
    overflow: hidden;
}
/* Mouse-follow glow op service-kaarten */
.kp-service-card {
    position: relative;
    overflow: hidden;
    --kp-glow-x: 50%;
    --kp-glow-y: 0%;
}

.kp-service-card::after {
    content: "";
    position: absolute;
    inset: -40%;
    pointer-events: none;
    border-radius: inherit;
    background: radial-gradient(
        circle at var(--kp-glow-x) var(--kp-glow-y),
        rgba(255, 255, 255, 0.10),
        rgba(255, 255, 255, 0.02) 45%,
        transparent 60%
    );
    opacity: 0;
    transition: opacity .25s ease;
}

.kp-service-card:hover::after {
    opacity: 1;
}
/* Hero titel — gewone tekstkleur, geen gradient */
.kp-hero-title-gradient {
    color: var(--kp-text);
    text-shadow: none;
}

/* Sticky footer: footer altijd onderaan het scherm */
html,
body {
    min-height: 100%;
}

#page {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: transparent;
}

.site-content {
    flex: 1 0 auto;
}

.site-footer,
#colophon {
    margin-top: auto;
}
/* Footer-transparant zodat de pagina-gradient doorloopt */
.site-footer,
#colophon,
.kp-footer {
    background: transparent !important;
    box-shadow: none !important;
    border-top: 0 !important;
}
/* (cursor glow verwijderd) */



/* ---------------------------------
   RESPONSIVE LAYOUT
   --------------------------------- */

/* Tablet landscape & down */
@media (max-width: 1024px) {
    .kp-container {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }

    .kp-header-inner {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
        height: auto;
        padding-top: 0.5rem;
        padding-bottom: 0.9rem;
    }

    .kp-main-nav {
        flex-wrap: wrap;
        justify-content: flex-start;
        row-gap: 0.35rem;
    }

    .kp-main-nav > .kp-btn {
        margin-left: auto;
    }

    .kp-hero {
        padding-top: 3.5rem;
        padding-bottom: 2.5rem;
    }

    .kp-hero-grid {
        grid-template-columns: minmax(0, 1fr);
        gap: 2.5rem;
    }

    .kp-hero-main {
        max-width: 40rem;
    }

    .kp-hero-panel {
        max-width: 32rem;
        margin: 0 auto;
    }

    .kp-service-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .kp-process-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .kp-testimonial-list {
        grid-template-columns: minmax(0, 1fr);
    }

    .kp-footer-top {
        flex-direction: column;
        align-items: flex-start;
        gap: 1.75rem;
    }

    .kp-footer-about {
        max-width: 26rem;
    }
}

/* Mobile / small screens */
@media (max-width: 640px) {
    .kp-container {
        padding-left: 1.1rem;
        padding-right: 1.1rem;
    }

    .kp-header-inner {
        align-items: center;
    }

    .kp-logo img,
    .kp-header .custom-logo,
    .kp-header .custom-logo-link img {
        max-width: 220px;
        height: auto;
    }

    .kp-main-nav {
        flex-direction: column;
        align-items: center;
        gap: 0.6rem;
    }

    .kp-main-nav > .kp-btn {
        width: 100%;
        text-align: center;
        justify-content: center;
    }

    .kp-hero {
        padding-top: 2.6rem;
        padding-bottom: 2.2rem;
    }

    .kp-hero-title {
        font-size: 2.1rem;
    }

    /* Improve hero lead readability on bright moving background */
.kp-hero-lead {
  text-shadow: var(--kp-shadow);
}

    .kp-hero-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .kp-hero-actions .kp-btn {
        width: 100%;
        justify-content: center;
    }

    .kp-service-grid,
    .kp-process-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .kp-testimonial-card {
        font-size: 0.82rem;
    }

    .kp-footer-top {
        align-items: flex-start;
    }

    .kp-footer-bottom {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.6rem;
    }
}

.hero-description {
  text-shadow: var(--kp-shadow-sm);
}


/* Readability: keep small/light text readable over moving background */
.kp-section-kicker,
.kp-section-sub,
.kp-footer,
.kp-footer p,
.kp-footer span,
.kp-footer a,
.kp-footer-col-title,
.kp-logo-fallback-text {
  text-shadow: var(--kp-shadow);
}

/* PJAX transition: fade only the page content (not header) */
main[data-kp-swap] {
  transition: opacity 200ms ease-in-out;
  will-change: opacity;
}
/* Hidden during navigation AND during initial fade-in frame */
html.kp-is-navigating main[data-kp-swap],
html.kp-swap-in main[data-kp-swap] {
  opacity: 0 !important;
  transition: none !important;
}

/* ── Theme toggle button ─────────────────────────────────────────────── */
.kp-theme-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 10px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.6);
  cursor: pointer;
  transition: background 140ms ease, color 140ms ease, border-color 140ms ease;
  flex-shrink: 0;
}
.kp-theme-toggle:hover {
  background: rgba(255,255,255,.12);
  color: #fff;
  border-color: rgba(255,255,255,.28);
}
/* Light mode stijl voor de toggle knop */
.kp-theme-light .kp-theme-toggle {
  border-color: rgba(0,0,0,.15);
  background: rgba(0,0,0,.06);
  color: rgba(0,0,0,.5);
}
.kp-theme-light .kp-theme-toggle:hover {
  background: rgba(0,0,0,.10);
  color: rgba(0,0,0,.85);
  border-color: rgba(0,0,0,.25);
}
@media (prefers-color-scheme: light) {
  body:not(.kp-theme-dark):not(.kp-theme-light) .kp-theme-toggle {
    border-color: rgba(0,0,0,.15);
    background: rgba(0,0,0,.06);
    color: rgba(0,0,0,.5);
  }
  body:not(.kp-theme-dark):not(.kp-theme-light) .kp-theme-toggle:hover {
    background: rgba(0,0,0,.10);
    color: rgba(0,0,0,.85);
  }
}

/* Welk icoon zichtbaar is per theme-state */
.kp-theme-icon--dark,
.kp-theme-icon--light { display: none; }

body.kp-theme-dark  .kp-theme-icon--auto  { display: none; }
body.kp-theme-dark  .kp-theme-icon--dark  { display: block; }
body.kp-theme-light .kp-theme-icon--auto  { display: none; }
body.kp-theme-light .kp-theme-icon--light { display: block; }

/* WordPress admin bar compatibility (prevents header shift when logged in) */
body.admin-bar .kp-header,
body.admin-bar header.site-header,
body.admin-bar header#masthead,
body.admin-bar .site-header {
  top: 32px !important;
}

@media (max-width: 782px) {
  body.admin-bar .kp-header,
  body.admin-bar header.site-header,
  body.admin-bar header#masthead,
  body.admin-bar .site-header {
    top: 46px !important;
  }
}

/* Ensure WP admin bar stays above the site header */
#wpadminbar { z-index: 999999 !important; }
body.admin-bar .kp-header,
body.admin-bar header.site-header,
body.admin-bar header#masthead,
body.admin-bar .site-header {
  z-index: 99998 !important; /* below wpadminbar */
}

/* Remove extra top gap caused by WP's default html margin-top when admin bar is present */
html { margin-top: 0 !important; }
body.admin-bar { padding-top: 32px; }
@media (max-width: 782px) {
  body.admin-bar { padding-top: 46px; }
  /* WP admin bar height is 46px on small screens */
}
#wpadminbar { top: 0 !important; }

/* Admin bar regression fix (restore 0.1.31 top layout, but keep header below admin bar) */
#wpadminbar{
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 999999 !important;
}

/* Let WordPress manage html margin-top; do not add extra padding that creates a gap */
html{ margin-top: inherit !important; }
body.admin-bar{ padding-top: 0 !important; }

/* Place fixed header below the admin bar using WP's CSS variable when available */
body.admin-bar .kp-header,
body.admin-bar header.site-header,
body.admin-bar header#masthead,
body.admin-bar .site-header{
  top: var(--wp-admin--admin-bar--height, 32px) !important;
  z-index: 99998 !important;
}


/* === Hamburger dropdown (liquid glass) === */
.kp-main-nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}

.kp-nav-left{
  position:relative;
  display:flex;
  align-items:center;
  gap:8px;
}

.kp-hamburger{
  width:42px;
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--kp-border);
  border-radius:12px;
  background: var(--kp-glass);
  color: var(--kp-text);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 10px 30px var(--kp-overlay-sm);
  cursor:pointer;
  position:relative;
}

.kp-hamburger-line{
  position:absolute;
  width:18px;
  height:2px;
  background: currentColor;
  border-radius:2px;
  transition: transform 180ms ease, opacity 180ms ease, top 180ms ease;
}

.kp-hamburger-line:nth-child(1){ top:14px; }
.kp-hamburger-line:nth-child(2){ top:20px; }
.kp-hamburger-line:nth-child(3){ top:26px; }

/* Hamburger -> X */
.kp-hamburger.is-open .kp-hamburger-line:nth-child(1){
  top:20px;
  transform: rotate(45deg);
}
.kp-hamburger.is-open .kp-hamburger-line:nth-child(2){
  opacity:0;
}
.kp-hamburger.is-open .kp-hamburger-line:nth-child(3){
  top:20px;
  transform: rotate(-45deg);
}

.kp-hamburger-menu{
  position:absolute;
  top:52px;
  left:0;
  min-width:220px;
  padding:10px;
  border-radius:16px;
  border:1px solid var(--kp-border);
  background: color-mix(in srgb, var(--kp-bg-alt) 85%, transparent);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  box-shadow: 0 20px 60px var(--kp-overlay-md), inset 0 1px 0 var(--kp-glass);
  color: var(--kp-text);
  opacity:0;
  visibility:hidden;
  transform: translateY(-6px);
  transition: opacity 160ms ease, transform 160ms ease, visibility 160ms ease;
  overflow:hidden;
  z-index: 999;
}

/* subtle sheen */
.kp-hamburger-menu::before{
  content:"";
  position:absolute;
  inset:-40% -30%;
  background: radial-gradient(circle at 30% 20%, var(--kp-glass), transparent 55%);
  transform: rotate(12deg);
  pointer-events:none;
}

.kp-hamburger-menu.is-open{
  opacity:1;
  visibility:visible;
  transform: translateY(0);
}

/* Light mode menu */
body.kp-theme-light .kp-hamburger-menu,
html.kp-theme-light .kp-hamburger-menu {
  background: rgba(238,242,247,0.95);
  border-color: rgba(0,0,0,.10);
  box-shadow: 0 20px 60px rgba(0,0,0,.15), inset 0 1px 0 rgba(255,255,255,.8);
  color: #0f1923;
}
@media (prefers-color-scheme: light) {
  body:not(.kp-theme-dark):not(.kp-theme-light) .kp-hamburger-menu {
    background: rgba(238,242,247,0.95);
    border-color: rgba(0,0,0,.10);
    box-shadow: 0 20px 60px rgba(0,0,0,.15), inset 0 1px 0 rgba(255,255,255,.8);
    color: #0f1923;
  }
}

.kp-hamburger-list{
  list-style:none;
  margin:0;
  padding:0;
  position:relative;
}

.kp-hamburger-list li{
  margin:0;
}

.kp-hamburger-list a{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:12px;
  text-decoration:none;
  color: inherit;
  background: rgba(255,255,255,0);
  transition: background 140ms ease, transform 140ms ease;
}

/* Bullet dot before each dropdown item */
.kp-hamburger-list a::before{
  content: "•";
  font-size: 14px;
  line-height: 1;
  opacity: .70;
}

.kp-hamburger-list a:hover::before{
  opacity: .95;
}

.kp-hamburger-list a:hover{
  background: var(--kp-primary-soft);
  transform: translateX(2px);
}

.kp-hamburger-list a:hover::before{
  opacity: .95;
}

/* ── Herbruikbare content-blok klassen (gebruikt op pagina's) ───────── */

/* Pill/info container — vervangt inline rgba(0,0,0,0.4) */
.kp-info-block {
  background: color-mix(in srgb, var(--kp-bg-alt) 80%, transparent);
  border-radius: var(--kp-radius);
  padding: 1.2rem 1.4rem;
  border: 1px solid var(--kp-border);
}

/* CTA blok onderaan pagina's — vervangt inline gradient met rgba(5,7,11,0.9) */
.kp-cta-block {
  padding: 1.5rem;
  border-radius: var(--kp-radius);
  border: 1px solid var(--kp-border);
  background: linear-gradient(150deg, var(--kp-primary-soft), color-mix(in srgb, var(--kp-bg) 95%, transparent));
}

/* Pill item — vervangt inline rgba(0,0,0,0.4) op individuele pills */
.kp-pill {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  padding: .75rem 1.2rem;
  border-radius: 999px;
  border: 1px solid var(--kp-border);
  font-size: .85rem;
  color: var(--kp-text-muted);
  line-height: 1.3;
  white-space: normal;
  text-align: center;
  background: var(--kp-bg-alt);
  flex: 1 1 140px;
  min-width: 140px;
}

/* Light mode: expliciete achtergrond voor info-block en pills */
body.kp-theme-light .kp-info-block,
html.kp-theme-light .kp-info-block {
  background: #e2e8f0;
}
body.kp-theme-light .kp-pill,
html.kp-theme-light .kp-pill {
  background: #d4dce8;
  border-color: rgba(0,0,0,.12);
}
body.kp-theme-light .kp-cta-block,
html.kp-theme-light .kp-cta-block {
  background: linear-gradient(150deg, rgba(0,84,126,0.10), #dde8f2);
}
@media (prefers-color-scheme: light) {
  body:not(.kp-theme-dark):not(.kp-theme-light) .kp-info-block { background: #e2e8f0; }
  body:not(.kp-theme-dark):not(.kp-theme-light) .kp-pill { background: #d4dce8; border-color: rgba(0,0,0,.12); }
  body:not(.kp-theme-dark):not(.kp-theme-light) .kp-cta-block { background: linear-gradient(150deg, rgba(0,84,126,0.10), #dde8f2); }
}
