/* ============================================================
   MODNW — De Boer Container Modificaties
   Design system: dark industrial (default) + light theme
   ============================================================ */

/* ---------- 1. Tokens ---------- */
:root {
    --font-display: 'Space Grotesk', system-ui, sans-serif;
    --font-body: 'Inter', system-ui, sans-serif;

    --accent: #F59E0B;
    --accent-strong: #D97706;
    --accent-soft: rgba(245, 158, 11, .12);
    --accent-grad: linear-gradient(135deg, #F59E0B 0%, #D97706 100%);

    --radius-s: 8px;
    --radius-m: 14px;
    --radius-l: 22px;

    --container: 1200px;
    --header-h: 72px;

    --ease: cubic-bezier(.22, .8, .26, .99);
    --shadow-1: 0 2px 8px rgba(0, 0, 0, .25);
    --shadow-2: 0 12px 40px rgba(0, 0, 0, .35);
}

:root[data-theme="dark"] {
    --bg: #0A0D12;
    --bg-raise: #0F141C;
    --surface: #131A24;
    --surface-2: #1A2330;
    --border: #243044;
    --border-soft: #1C2635;
    --text: #E9EDF3;
    --text-soft: #A8B3C2;
    --text-faint: #6B7889;
    --header-bg: rgba(10, 13, 18, .82);
    --hero-glow: radial-gradient(60% 50% at 70% 30%, rgba(245, 158, 11, .14), transparent 70%);
    --card-hover: #182230;
    --input-bg: #0F141C;
    color-scheme: dark;
}

:root[data-theme="light"] {
    --bg: #F4F6F9;
    --bg-raise: #ECEFF4;
    --surface: #FFFFFF;
    --surface-2: #F4F6F9;
    --border: #D9DFE8;
    --border-soft: #E5EAF1;
    --text: #131A24;
    --text-soft: #46546A;
    --text-faint: #8493A8;
    --header-bg: rgba(255, 255, 255, .85);
    --hero-glow: radial-gradient(60% 50% at 70% 30%, rgba(245, 158, 11, .18), transparent 70%);
    --card-hover: #FFFFFF;
    --input-bg: #FFFFFF;
    --shadow-1: 0 2px 8px rgba(19, 26, 36, .08);
    --shadow-2: 0 12px 40px rgba(19, 26, 36, .14);
    color-scheme: light;
}

/* ---------- 2. Base ---------- */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.65;
    color: var(--text);
    background: var(--bg);
    transition: background .35s var(--ease), color .35s var(--ease);
}

img { max-width: 100%; display: block; }

h1, h2, h3, h4 {
    font-family: var(--font-display);
    line-height: 1.15;
    margin: 0 0 .5em;
    font-weight: 700;
    letter-spacing: -.015em;
}

h1 { font-size: clamp(2.1rem, 5vw, 3.6rem); }
h2 { font-size: clamp(1.6rem, 3.4vw, 2.4rem); }
h3 { font-size: 1.25rem; }

p { margin: 0 0 1em; }

a { color: inherit; text-decoration: none; }

.container {
    max-width: var(--container);
    margin-inline: auto;
    padding-inline: clamp(1.1rem, 4vw, 2rem);
}

section { padding-block: clamp(3.2rem, 7vw, 5.5rem); }

.skip-link {
    position: absolute; left: -999px; top: 0;
    background: var(--accent); color: #111; padding: .6rem 1rem; z-index: 200;
}
.skip-link:focus { left: 0; }

.section-head { max-width: 640px; margin-bottom: 2.4rem; }
.section-head.centered { margin-inline: auto; text-align: center; }

.eyebrow {
    display: inline-flex; align-items: center; gap: .5rem;
    font-family: var(--font-display);
    font-size: .8rem; font-weight: 600;
    letter-spacing: .14em; text-transform: uppercase;
    color: var(--accent); margin-bottom: .9rem;
}
.eyebrow::before {
    content: ""; width: 26px; height: 2px; background: var(--accent-grad); border-radius: 2px;
}
.section-head.centered .eyebrow::after {
    content: ""; width: 26px; height: 2px; background: var(--accent-grad); border-radius: 2px;
}

.lead { color: var(--text-soft); font-size: 1.07rem; }

/* ---------- 3. Buttons ---------- */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
    font-family: var(--font-display); font-weight: 600; font-size: .95rem;
    padding: .8rem 1.5rem; border-radius: var(--radius-s);
    border: 1px solid transparent; cursor: pointer;
    transition: transform .2s var(--ease), box-shadow .25s var(--ease), background .25s, border-color .25s, color .25s;
    will-change: transform;
}
.btn:active { transform: translateY(1px) scale(.99); }

.btn-accent {
    background: var(--accent-grad); color: #161002;
    box-shadow: 0 6px 22px rgba(245, 158, 11, .28);
}
.btn-accent:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(245, 158, 11, .4); }

.btn-ghost {
    background: transparent; color: var(--text);
    border-color: var(--border);
}
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-2px); }

.btn-soft {
    background: var(--surface-2); color: var(--text);
    border-color: var(--border-soft);
}
.btn-soft:hover { border-color: var(--accent); color: var(--accent); }

.btn-lg { padding: 1rem 1.9rem; font-size: 1.02rem; }
.btn-sm { padding: .55rem 1.05rem; font-size: .87rem; }

/* ---------- 4. Header ---------- */
.site-header {
    position: sticky; top: 0; z-index: 100;
    height: var(--header-h);
    background: var(--header-bg);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--border-soft);
    transition: background .35s, border-color .35s;
}
.header-inner { display: flex; align-items: center; gap: 1.4rem; height: var(--header-h); }

.brand { display: inline-flex; align-items: center; gap: .7rem; color: var(--text); }
.brand-mark { color: var(--text); display: grid; place-items: center; }
.brand-text { display: flex; flex-direction: column; line-height: 1.06; font-family: var(--font-display); }
.brand-text strong { font-size: 1.04rem; letter-spacing: .045em; font-weight: 700; }
.brand-text em { font-style: normal; font-size: .64rem; letter-spacing: .205em; color: var(--accent); font-weight: 600; margin-top: 1px; }
.brand-text .tld { color: var(--text-faint); letter-spacing: .05em; text-transform: lowercase; }

.main-nav { display: flex; align-items: center; gap: .35rem; margin-left: auto; }
.nav-link {
    position: relative; padding: .55rem .85rem; border-radius: var(--radius-s);
    font-weight: 500; font-size: .95rem; color: var(--text-soft);
    transition: color .2s, background .2s;
}
.nav-link:hover { color: var(--text); background: var(--surface-2); }
.nav-link.is-active { color: var(--accent); }
.nav-link.is-active::after {
    content: ""; position: absolute; left: .85rem; right: .85rem; bottom: .25rem;
    height: 2px; background: var(--accent-grad); border-radius: 2px;
}
.nav-cta { margin-left: .6rem; }
.nav-3d-badge {
    display: inline-block; margin-left: .3rem; padding: .08rem .4rem;
    border-radius: 6px; font-size: .62rem; font-weight: 700; letter-spacing: .06em;
    background: var(--accent-grad); color: #161002; vertical-align: 2px;
}

.header-actions { display: flex; align-items: center; gap: .5rem; }

.theme-toggle {
    width: 40px; height: 40px; border-radius: 50%;
    display: grid; place-items: center;
    background: var(--surface-2); color: var(--text-soft);
    border: 1px solid var(--border-soft); cursor: pointer;
    transition: color .25s, border-color .25s, transform .4s var(--ease);
}
.theme-toggle:hover { color: var(--accent); border-color: var(--accent); transform: rotate(25deg); }
:root[data-theme="dark"] .icon-moon { display: none; }
:root[data-theme="light"] .icon-sun { display: none; }

.nav-burger { display: none; }

/* ---------- 5. Hero ---------- */
.hero {
    position: relative; overflow: hidden;
    padding-block: clamp(3.4rem, 8vw, 6.5rem);
    background: var(--bg);
}
.hero::before {
    content: ""; position: absolute; inset: 0;
    background-image:
        linear-gradient(var(--border-soft) 1px, transparent 1px),
        linear-gradient(90deg, var(--border-soft) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(75% 80% at 50% 20%, black 30%, transparent 75%);
    opacity: .5; pointer-events: none;
}
.hero::after {
    content: ""; position: absolute; inset: 0;
    background: var(--hero-glow); pointer-events: none;
}
.hero-inner {
    position: relative; z-index: 1;
    display: grid; grid-template-columns: 1.05fr .95fr;
    gap: clamp(2rem, 5vw, 4rem); align-items: center;
}

.hero-badge {
    display: inline-flex; align-items: center; gap: .55rem;
    padding: .42rem .95rem; border-radius: 99px;
    background: var(--accent-soft); border: 1px solid rgba(245, 158, 11, .3);
    color: var(--accent); font-size: .83rem; font-weight: 600;
    margin-bottom: 1.4rem;
}
.hero-badge .dot {
    width: 7px; height: 7px; border-radius: 50%; background: var(--accent);
    animation: pulse-dot 2s ease infinite;
}
@keyframes pulse-dot { 50% { opacity: .35; transform: scale(.8); } }

.hero h1 .accent {
    background: var(--accent-grad);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; color: transparent;
}
.hero .lead { font-size: 1.12rem; max-width: 480px; }

.hero-actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 1.9rem; }

.hero-stats {
    display: flex; gap: clamp(1.4rem, 4vw, 2.8rem);
    margin-top: 2.6rem; padding-top: 1.8rem;
    border-top: 1px solid var(--border-soft);
}
.hero-stat .num {
    font-family: var(--font-display); font-size: 1.7rem; font-weight: 700; color: var(--text);
    display: flex; align-items: baseline; gap: 2px;
}
.hero-stat .num .plus { color: var(--accent); }
.hero-stat .lbl { font-size: .83rem; color: var(--text-faint); }

/* hero visual */
.hero-visual { position: relative; }
.hero-photo {
    display: block; position: relative;
    border-radius: var(--radius-l); overflow: hidden;
    box-shadow: var(--shadow-2);
    border: 1px solid var(--border-soft);
    aspect-ratio: 4 / 3;
}
.hero-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--ease); }
.hero-photo:hover img { transform: scale(1.03); }

/* hero slider */
.hero-slide {
    position: absolute; inset: 0; display: block;
    opacity: 0; transition: opacity .9s var(--ease);
    pointer-events: none;
}
.hero-slide.is-active { opacity: 1; pointer-events: auto; }
.hero-dots {
    position: absolute; top: 1rem; right: 1.1rem; z-index: 3;
    display: flex; gap: .45rem;
}
.hero-dots button {
    width: 9px; height: 9px; border-radius: 50%;
    border: 0; padding: 0; cursor: pointer;
    background: rgba(255, 255, 255, .45);
    transition: background .25s, transform .25s;
}
.hero-dots button:hover { transform: scale(1.3); }
.hero-dots button.is-active { background: var(--accent); }
.hero-caption {
    position: absolute; left: 0; right: 0; bottom: 0;
    padding: 2.2rem 1.4rem 1.1rem;
    background: linear-gradient(180deg, transparent, rgba(8, 10, 14, .82));
    display: flex; flex-direction: column; gap: .15rem;
    color: #fff;
}
.hero-caption .hc-label {
    font-size: .72rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase;
    color: var(--accent);
}
.hero-caption .hc-title {
    font-family: var(--font-display); font-weight: 600; font-size: 1.02rem;
    display: inline-flex; align-items: center; gap: .45rem;
}
.hero-caption svg { transition: transform .25s var(--ease); }
.hero-photo:hover .hero-caption svg { transform: translateX(4px); }

.hero-card {
    position: absolute; display: flex; align-items: center; gap: .7rem;
    background: var(--surface); border: 1px solid var(--border);
    padding: .75rem 1.05rem; border-radius: var(--radius-m);
    box-shadow: var(--shadow-2); font-size: .88rem;
    animation: float 5.5s ease-in-out infinite;
}
.hero-card strong { font-family: var(--font-display); display: block; line-height: 1.2; }
.hero-card span { color: var(--text-faint); font-size: .78rem; }
.hero-card .ico {
    width: 38px; height: 38px; flex: none; border-radius: 10px;
    display: grid; place-items: center; font-size: 1.15rem;
    background: var(--accent-soft); color: var(--accent);
}
.hero-card-1 { top: 8%; left: -7%; animation-delay: 0s; }
.hero-card-2 { bottom: 10%; right: -5%; animation-delay: 1.6s; }
@keyframes float { 50% { transform: translateY(-10px); } }

/* ---------- 6. Trust strip / marquee ---------- */
.trust-strip {
    padding-block: 1.1rem;
    border-block: 1px solid var(--border-soft);
    background: var(--bg-raise);
    overflow: hidden;
}
.marquee { display: flex; gap: 3.2rem; width: max-content; animation: marquee 32s linear infinite; }
.trust-strip:hover .marquee { animation-play-state: paused; }
.marquee span {
    display: inline-flex; align-items: center; gap: .6rem; white-space: nowrap;
    font-family: var(--font-display); font-weight: 500; font-size: .92rem; color: var(--text-soft);
}
.marquee span::before { content: "▰"; color: var(--accent); font-size: .7rem; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ---------- 7. Cards & grids ---------- */
.grid { display: grid; gap: 1.4rem; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

.card {
    background: var(--surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-m);
    overflow: hidden;
    transition: transform .3s var(--ease), border-color .3s, box-shadow .3s, background .3s;
}
.card:hover {
    transform: translateY(-5px);
    border-color: var(--accent);
    box-shadow: var(--shadow-2);
    background: var(--card-hover);
}

/* project card */
.project-card { display: flex; flex-direction: column; }
.project-card .thumb { position: relative; aspect-ratio: 16 / 11; overflow: hidden; }
.project-card .thumb img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .6s var(--ease);
}
.project-card:hover .thumb img { transform: scale(1.06); }
.project-card .thumb::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 55%, rgba(8, 10, 14, .55));
}
.badge {
    position: absolute; z-index: 2; top: .9rem; left: .9rem;
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .3rem .7rem; border-radius: 99px;
    background: rgba(10, 13, 18, .72); color: #fff;
    backdrop-filter: blur(6px);
    font-size: .76rem; font-weight: 600; letter-spacing: .03em;
}
.badge.accent { background: var(--accent-grad); color: #161002; }
.badge.right { left: auto; right: .9rem; }

.project-card .body { padding: 1.15rem 1.25rem 1.35rem; display: flex; flex-direction: column; gap: .45rem; flex: 1; }
.project-card h3 { margin: 0; font-size: 1.08rem; }
.project-card .sub { color: var(--text-faint); font-size: .87rem; min-height: 1.2em; }
.project-card .meta-row {
    display: flex; align-items: center; justify-content: space-between;
    margin-top: auto; padding-top: .8rem; border-top: 1px solid var(--border-soft);
}
.price { font-family: var(--font-display); font-weight: 700; color: var(--accent); font-size: 1.04rem; }
.meta-row .link { font-size: .87rem; color: var(--text-soft); display: inline-flex; align-items: center; gap: .3rem; transition: color .2s, gap .25s; }
.project-card:hover .meta-row .link { color: var(--accent); gap: .55rem; }

/* category card */
.cat-card { padding: 1.5rem 1.4rem; display: flex; flex-direction: column; gap: .55rem; position: relative; }
.cat-card .ico {
    width: 52px; height: 52px; border-radius: 14px;
    display: grid; place-items: center; font-size: 1.5rem;
    background: var(--accent-soft);
    border: 1px solid rgba(245, 158, 11, .22);
    margin-bottom: .4rem;
    transition: transform .3s var(--ease);
}
.cat-card:hover .ico { transform: scale(1.1) rotate(-4deg); }
.cat-card h3 { margin: 0; font-size: 1.05rem; }
.cat-card p { color: var(--text-soft); font-size: .9rem; margin: 0; flex: 1;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.cat-card .from { font-size: .82rem; color: var(--text-faint); }
.cat-card .from b { color: var(--accent); font-family: var(--font-display); }
.cat-card .arrow {
    position: absolute; top: 1.3rem; right: 1.3rem; color: var(--text-faint);
    transition: transform .25s var(--ease), color .25s;
}
.cat-card:hover .arrow { transform: translate(3px, -3px); color: var(--accent); }

/* ---------- 8. Process ---------- */
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.4rem; counter-reset: step; }
.process-step {
    position: relative; padding: 1.6rem 1.4rem;
    background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--radius-m);
}
.process-step::before {
    counter-increment: step; content: "0" counter(step);
    font-family: var(--font-display); font-weight: 700; font-size: 2.6rem;
    background: var(--accent-grad);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; color: transparent;
    display: block; line-height: 1; margin-bottom: .8rem; opacity: .9;
}
.process-step h3 { font-size: 1.05rem; }
.process-step p { color: var(--text-soft); font-size: .9rem; margin: 0; }
.process-step:not(:last-child)::after {
    content: "→"; position: absolute; right: -1.25rem; top: 50%;
    transform: translateY(-50%); color: var(--accent); font-size: 1.2rem; z-index: 1;
}

/* ---------- 9. Stats band ---------- */
.stats-band {
    background: var(--bg-raise);
    border-block: 1px solid var(--border-soft);
}
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; text-align: center; }
.stat-big .num {
    font-family: var(--font-display); font-weight: 700;
    font-size: clamp(2.2rem, 5vw, 3.2rem); color: var(--text);
    display: inline-flex; align-items: baseline;
}
.stat-big .num .plus { color: var(--accent); }
.stat-big .lbl { color: var(--text-faint); font-size: .92rem; }

/* ---------- 10. CTA band & footer ---------- */
.cta-band {
    margin-block: 0; position: relative; overflow: hidden;
    background:
        radial-gradient(70% 110% at 85% 10%, rgba(245, 158, 11, .22), transparent 60%),
        var(--surface);
    border-block: 1px solid var(--border-soft);
}
.cta-band-inner {
    display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap;
}
.cta-band h2 { margin-bottom: .3rem; }
.cta-band p { color: var(--text-soft); margin: 0; }
.cta-band-actions { display: flex; gap: .9rem; flex-wrap: wrap; }

.site-footer { background: var(--bg); padding-top: 3.4rem; }
.footer-grid {
    display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 2.2rem;
    padding-bottom: 2.6rem;
}
.footer-col h4 { font-size: .95rem; margin-bottom: 1rem; }
.footer-col a, .footer-col span { display: block; color: var(--text-soft); font-size: .92rem; padding-block: .28rem; }
.footer-col a:hover { color: var(--accent); }
.footer-brand p { color: var(--text-soft); font-size: .92rem; margin-top: 1rem; max-width: 280px; }
/* footer-col span-regels mogen het logo niet slopen */
.footer-brand .brand { display: inline-flex; align-items: center; gap: .7rem; }
.footer-brand .brand-text { display: flex !important; flex-direction: column; padding: 0; }
.footer-brand .brand-text .tld { display: inline !important; padding: 0; }
.footer-brand .brand-mark { display: grid !important; padding: 0; color: var(--text); }
.footer-bottom {
    display: flex; justify-content: space-between; flex-wrap: wrap; gap: .6rem;
    padding-block: 1.4rem; border-top: 1px solid var(--border-soft);
    color: var(--text-faint); font-size: .85rem;
}
.footer-bottom a:hover { color: var(--accent); }

/* ---------- 11. Page hero (subpages) ---------- */
.page-hero {
    position: relative; overflow: hidden;
    padding-block: clamp(2.8rem, 6vw, 4.4rem);
    background: var(--bg-raise);
    border-bottom: 1px solid var(--border-soft);
}
.page-hero::before {
    content: ""; position: absolute; inset: 0;
    background: var(--hero-glow); opacity: .65; pointer-events: none;
}
.page-hero .container { position: relative; }
.breadcrumbs { font-size: .85rem; color: var(--text-faint); margin-bottom: 1rem; display: flex; gap: .45rem; flex-wrap: wrap; }
.breadcrumbs a:hover { color: var(--accent); }
.breadcrumbs .sep { opacity: .5; }

/* ---------- 12. Filters ---------- */
.filter-bar {
    display: flex; flex-wrap: wrap; gap: .55rem; align-items: center;
    margin-bottom: 2rem;
}
.filter-bar .lbl { font-size: .85rem; color: var(--text-faint); margin-right: .3rem; font-weight: 600; }
.chip {
    display: inline-flex; align-items: center; gap: .4rem;
    padding: .45rem 1rem; border-radius: 99px;
    background: var(--surface); border: 1px solid var(--border);
    font-size: .87rem; font-weight: 500; color: var(--text-soft);
    cursor: pointer; transition: all .2s var(--ease);
}
.chip:hover { border-color: var(--accent); color: var(--accent); }
.chip.is-active { background: var(--accent-grad); border-color: transparent; color: #161002; font-weight: 600; }

/* ---------- 13. Detail pages ---------- */
.detail-grid {
    display: grid; grid-template-columns: 1.15fr .85fr;
    gap: clamp(2rem, 4.5vw, 3.5rem); align-items: start;
}

.gallery { display: grid; gap: .8rem; }
.gallery-main {
    border-radius: var(--radius-m); overflow: hidden; cursor: zoom-in;
    aspect-ratio: 4 / 3; border: 1px solid var(--border-soft);
    position: relative;
}
.gallery-main img { width: 100%; height: 100%; object-fit: cover; }
.gallery-main .zoom-hint {
    position: absolute; right: .9rem; bottom: .9rem;
    background: rgba(10, 13, 18, .7); color: #fff; border-radius: 99px;
    padding: .35rem .8rem; font-size: .78rem; display: flex; gap: .35rem; align-items: center;
    backdrop-filter: blur(6px);
}
.gallery-thumbs { display: grid; grid-template-columns: repeat(5, 1fr); gap: .8rem; }
.gallery-thumbs button {
    border: 2px solid transparent; border-radius: var(--radius-s); overflow: hidden;
    padding: 0; cursor: pointer; background: none; aspect-ratio: 1;
    transition: border-color .2s, opacity .2s; opacity: .75;
}
.gallery-thumbs button img { width: 100%; height: 100%; object-fit: cover; }
.gallery-thumbs button:hover { opacity: 1; }
.gallery-thumbs button.is-active { border-color: var(--accent); opacity: 1; }

.detail-info .tagline { color: var(--accent); font-weight: 600; font-size: .95rem; }
.detail-price-row {
    display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap;
    padding: 1.1rem 1.3rem; margin-block: 1.4rem;
    background: var(--surface); border: 1px solid var(--border-soft);
    border-radius: var(--radius-m);
}
.detail-price-row .big-price { font-family: var(--font-display); font-size: 1.85rem; font-weight: 700; color: var(--accent); }
.detail-price-row .note { font-size: .83rem; color: var(--text-faint); }

.spec-table { width: 100%; border-collapse: collapse; margin-block: 1rem; }
.spec-table td { padding: .65rem .2rem; border-bottom: 1px solid var(--border-soft); font-size: .94rem; }
.spec-table td:first-child { color: var(--text-faint); width: 42%; }
.spec-table td:last-child { font-weight: 500; }

.feature-list { list-style: none; padding: 0; margin: 1rem 0; display: grid; gap: .55rem; }
.feature-list li { display: flex; gap: .65rem; align-items: flex-start; font-size: .95rem; color: var(--text-soft); }
.feature-list li::before {
    content: "✓"; flex: none; width: 22px; height: 22px; border-radius: 7px;
    background: var(--accent-soft); color: var(--accent);
    display: grid; place-items: center; font-size: .8rem; font-weight: 700; margin-top: .1rem;
}

.tag-row { display: flex; flex-wrap: wrap; gap: .5rem; margin-block: 1.2rem; }
.tag {
    padding: .35rem .85rem; border-radius: 99px; font-size: .82rem; font-weight: 500;
    background: var(--surface-2); border: 1px solid var(--border-soft); color: var(--text-soft);
    transition: all .2s;
}
.tag:hover { border-color: var(--accent); color: var(--accent); }

.prose { color: var(--text-soft); }
.prose h2, .prose h3 { color: var(--text); margin-top: 1.6em; }

/* ---------- 14. Offerte configurator ---------- */
.wizard {
    max-width: 860px; margin-inline: auto;
    background: var(--surface); border: 1px solid var(--border-soft);
    border-radius: var(--radius-l); overflow: hidden;
    box-shadow: var(--shadow-1);
}
.wizard-progress { display: flex; border-bottom: 1px solid var(--border-soft); }
.wizard-progress .wp-step {
    flex: 1; padding: .95rem .5rem; text-align: center;
    font-family: var(--font-display); font-size: .82rem; font-weight: 600;
    color: var(--text-faint); position: relative;
    transition: color .25s;
}
.wizard-progress .wp-step::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px;
    background: var(--accent-grad); transform: scaleX(0); transition: transform .35s var(--ease);
}
.wizard-progress .wp-step.is-active { color: var(--accent); }
.wizard-progress .wp-step.is-done { color: var(--text-soft); }
.wizard-progress .wp-step.is-active::after,
.wizard-progress .wp-step.is-done::after { transform: scaleX(1); }

.wizard-body { padding: clamp(1.5rem, 4vw, 2.5rem); }
.wizard-pane { display: none; animation: pane-in .4s var(--ease); }
.wizard-pane.is-active { display: block; }
@keyframes pane-in { from { opacity: 0; transform: translateY(10px); } }

.wizard h3 { margin-bottom: .4rem; }
.wizard .hint { color: var(--text-faint); font-size: .9rem; margin-bottom: 1.4rem; }

.option-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: .8rem; }
.option-tile {
    position: relative; padding: 1.05rem .9rem; border-radius: var(--radius-m);
    background: var(--input-bg); border: 1.5px solid var(--border);
    cursor: pointer; text-align: center;
    transition: all .2s var(--ease);
    user-select: none;
}
.option-tile:hover { border-color: var(--accent); transform: translateY(-2px); }
.option-tile input { position: absolute; opacity: 0; pointer-events: none; }
.option-tile .t-ico { font-size: 1.55rem; display: block; margin-bottom: .35rem; }
.option-tile .t-lbl { font-weight: 600; font-size: .9rem; font-family: var(--font-display); display: block; }
.option-tile .t-sub { font-size: .76rem; color: var(--text-faint); }
.option-tile.is-selected {
    border-color: var(--accent); background: var(--accent-soft);
    box-shadow: 0 0 0 1px var(--accent);
}
.option-tile.is-selected::after {
    content: "✓"; position: absolute; top: .5rem; right: .6rem;
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--accent-grad); color: #161002;
    font-size: .72rem; font-weight: 700; display: grid; place-items: center;
}

.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-field { display: flex; flex-direction: column; gap: .35rem; }
.form-field.full { grid-column: 1 / -1; }
.form-field label { font-size: .87rem; font-weight: 600; }
.form-field label .req { color: var(--accent); }
.form-field input, .form-field textarea, .form-field select {
    font: inherit; color: var(--text);
    background: var(--input-bg);
    border: 1.5px solid var(--border); border-radius: var(--radius-s);
    padding: .75rem .95rem;
    transition: border-color .2s, box-shadow .2s;
}
.form-field input:focus, .form-field textarea:focus, .form-field select:focus {
    outline: none; border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-soft);
}
.form-field .err { color: #EF4444; font-size: .8rem; display: none; }
.form-field.has-error input, .form-field.has-error textarea { border-color: #EF4444; }
.form-field.has-error .err { display: block; }

.wizard-nav {
    display: flex; justify-content: space-between; gap: 1rem;
    padding: 1.2rem clamp(1.5rem, 4vw, 2.5rem);
    border-top: 1px solid var(--border-soft); background: var(--surface-2);
}

.wizard-summary {
    background: var(--input-bg); border: 1px dashed var(--border);
    border-radius: var(--radius-m); padding: 1.1rem 1.3rem; margin-bottom: 1.4rem;
    font-size: .92rem;
}
.wizard-summary h4 { margin-bottom: .6rem; font-size: .95rem; }
.wizard-summary .row { display: flex; justify-content: space-between; gap: 1rem; padding-block: .3rem; border-bottom: 1px solid var(--border-soft); }
.wizard-summary .row:last-child { border-bottom: 0; }
.wizard-summary .row .k { color: var(--text-faint); }

.wizard-success { text-align: center; padding: 3rem 1.5rem; }
.wizard-success .check {
    width: 76px; height: 76px; margin: 0 auto 1.4rem; border-radius: 50%;
    background: var(--accent-grad); color: #161002;
    display: grid; place-items: center; font-size: 2.1rem;
    animation: pop-in .5s var(--ease);
}
@keyframes pop-in { from { transform: scale(.4); opacity: 0; } }

.ref-banner {
    display: flex; align-items: center; gap: 1rem;
    background: var(--accent-soft); border: 1px solid rgba(245,158,11,.3);
    border-radius: var(--radius-m); padding: .9rem 1.2rem; margin-bottom: 1.6rem;
    font-size: .92rem;
}
.ref-banner img { width: 64px; height: 48px; object-fit: cover; border-radius: 8px; }

/* ---------- 15. Lightbox ---------- */
.lightbox[hidden] { display: none !important; }
.lightbox {
    position: fixed; inset: 0; z-index: 300;
    background: rgba(5, 7, 10, .93);
    display: flex; align-items: center; justify-content: center;
    animation: fade-in .25s ease;
}
@keyframes fade-in { from { opacity: 0; } }
.lightbox img {
    max-width: min(92vw, 1400px); max-height: 88vh;
    border-radius: var(--radius-s); object-fit: contain;
    box-shadow: 0 20px 80px rgba(0,0,0,.6);
}
.lightbox button {
    position: absolute; background: rgba(255,255,255,.08); color: #fff;
    border: 1px solid rgba(255,255,255,.15); border-radius: 50%;
    width: 48px; height: 48px; font-size: 1.5rem; cursor: pointer;
    display: grid; place-items: center; transition: background .2s;
}
.lightbox button:hover { background: var(--accent); color: #161002; }
.lightbox-close { top: 1.2rem; right: 1.2rem; }
.lightbox-prev { left: 1.2rem; top: 50%; transform: translateY(-50%); }
.lightbox-next { right: 1.2rem; top: 50%; transform: translateY(-50%); }
.lightbox-counter {
    position: absolute; bottom: 1.4rem; left: 50%; transform: translateX(-50%);
    color: rgba(255,255,255,.75); font-size: .9rem; font-family: var(--font-display);
}

/* ---------- 16. Contact ---------- */
.contact-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(2rem, 4vw, 3.5rem); align-items: start; }
.contact-card {
    display: flex; gap: 1rem; align-items: flex-start;
    background: var(--surface); border: 1px solid var(--border-soft);
    border-radius: var(--radius-m); padding: 1.25rem 1.4rem; margin-bottom: 1rem;
    transition: border-color .25s, transform .25s var(--ease);
}
.contact-card:hover { border-color: var(--accent); transform: translateX(4px); }
.contact-card .ico {
    width: 46px; height: 46px; flex: none; border-radius: 12px;
    background: var(--accent-soft); color: var(--accent);
    display: grid; place-items: center;
}
.contact-card strong { font-family: var(--font-display); display: block; }
.contact-card span, .contact-card a.val { color: var(--text-soft); font-size: .93rem; }
.contact-card a.val:hover { color: var(--accent); }

/* ---------- 17. Reveal animations ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }
.reveal-stagger > * { opacity: 0; transform: translateY(22px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal-stagger.is-visible > * { opacity: 1; transform: none; }
.reveal-stagger.is-visible > *:nth-child(2) { transition-delay: .08s; }
.reveal-stagger.is-visible > *:nth-child(3) { transition-delay: .16s; }
.reveal-stagger.is-visible > *:nth-child(4) { transition-delay: .24s; }
.reveal-stagger.is-visible > *:nth-child(5) { transition-delay: .32s; }
.reveal-stagger.is-visible > *:nth-child(6) { transition-delay: .4s; }
.reveal-stagger.is-visible > *:nth-child(n+7) { transition-delay: .48s; }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
    html { scroll-behavior: auto; }
    .reveal, .reveal-stagger > * { opacity: 1; transform: none; }
}

/* ---------- 18. 404 ---------- */
.error-page { text-align: center; padding-block: clamp(4rem, 10vw, 8rem); }
.error-page .code {
    font-family: var(--font-display); font-weight: 700; font-size: clamp(5rem, 16vw, 9rem);
    background: var(--accent-grad);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; color: transparent;
    line-height: 1;
}

/* ============================================================
   UITBREIDING — topbar, USP's, solutions, kennisbank, accordion,
   contact-redesign, content-band, mobile CTA
   ============================================================ */

/* ---------- Topbar ---------- */
.topbar {
    background: var(--bg-raise);
    border-bottom: 1px solid var(--border-soft);
    font-size: .8rem;
}
.topbar-inner { display: flex; align-items: center; gap: 1.4rem; padding-block: .45rem; }
.topbar-item { display: inline-flex; align-items: center; gap: .4rem; color: var(--text-faint); }
.topbar-item svg { color: var(--accent); }
.topbar-item.strong { color: var(--text); font-weight: 600; }
a.topbar-item:hover { color: var(--accent); }
.topbar-spacer { flex: 1; }

/* ---------- Icon-chips (gedeeld) ---------- */
.usp-card .ico, .solution-card .ico, .article-card .ico, .side-card.cta.big .ico {
    width: 52px; height: 52px; border-radius: 14px; flex: none;
    display: grid; place-items: center;
    background: var(--accent-soft); color: var(--accent);
    border: 1px solid rgba(245, 158, 11, .22);
}
.cat-card .ico { color: var(--accent); font-size: 0; }

/* ---------- USP cards ---------- */
.usp-card {
    background: var(--surface); border: 1px solid var(--border-soft);
    border-radius: var(--radius-m); padding: 1.5rem 1.4rem;
    transition: transform .3s var(--ease), border-color .3s;
}
.usp-card:hover { transform: translateY(-4px); border-color: var(--accent); }
.usp-card .ico { margin-bottom: .9rem; }
.usp-card h3 { font-size: 1.05rem; }
.usp-card p { color: var(--text-soft); font-size: .92rem; margin: 0; }

/* ---------- Solution cards ---------- */
.solution-card { padding: 1.6rem 1.5rem; display: flex; flex-direction: column; gap: .5rem; }
.solution-card .ico { margin-bottom: .5rem; transition: transform .3s var(--ease); }
.solution-card:hover .ico { transform: scale(1.08) rotate(-3deg); }
.solution-card h3 { margin: 0; font-size: 1.12rem; }
.solution-card .tagline { color: var(--accent); font-size: .88rem; font-weight: 600; margin: 0; }
.solution-card p { color: var(--text-soft); font-size: .92rem; margin: 0; flex: 1; }
.solution-card .link {
    display: inline-flex; align-items: center; gap: .4rem;
    color: var(--text-soft); font-size: .88rem; font-weight: 500;
    margin-top: .7rem; transition: color .2s, gap .25s;
}
.solution-card:hover .link { color: var(--accent); gap: .65rem; }

/* ---------- Artikel cards (kennisbank) ---------- */
.article-card { padding: 1.6rem 1.5rem; display: flex; flex-direction: column; gap: .55rem; }
.article-card .ico { margin-bottom: .5rem; }
.article-card h3 { margin: 0; font-size: 1.08rem; }
.article-card p { color: var(--text-soft); font-size: .92rem; flex: 1; margin: 0; }
.article-card .meta-row {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: .9rem; padding-top: .9rem; border-top: 1px solid var(--border-soft);
}
.read-time { display: inline-flex; align-items: center; gap: .4rem; color: var(--text-faint); font-size: .83rem; }
.article-card .link { display: inline-flex; align-items: center; gap: .4rem; color: var(--text-soft); font-size: .88rem; transition: color .2s, gap .25s; }
.article-card:hover .link { color: var(--accent); gap: .65rem; }

/* ---------- Accordion ---------- */
.accordion { display: grid; gap: .65rem; }
.acc-item {
    background: var(--surface); border: 1px solid var(--border-soft);
    border-radius: var(--radius-m); overflow: hidden;
    transition: border-color .25s;
}
.acc-item[open] { border-color: var(--accent); }
.acc-item summary {
    list-style: none; cursor: pointer;
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
    padding: 1rem 1.25rem;
    font-family: var(--font-display); font-weight: 600; font-size: .98rem;
    transition: color .2s;
}
.acc-item summary::-webkit-details-marker { display: none; }
.acc-item summary:hover { color: var(--accent); }
.acc-chevron { color: var(--text-faint); transition: transform .3s var(--ease); flex: none; display: grid; place-items: center; }
.acc-item[open] .acc-chevron { transform: rotate(180deg); color: var(--accent); }
.acc-body { padding: 0 1.25rem 1.15rem; color: var(--text-soft); font-size: .95rem; }
.acc-body p { margin: 0; }
.faq-group { margin-bottom: 2.4rem; }
.faq-group h2 { font-size: 1.3rem; margin-bottom: 1rem; }

/* ---------- Side cards (asides) ---------- */
.side-card {
    background: var(--surface); border: 1px solid var(--border-soft);
    border-radius: var(--radius-m); padding: 1.4rem 1.45rem; margin-bottom: 1.2rem;
}
.side-card h3 { font-size: 1.05rem; margin-bottom: .8rem; }
.side-card.cta { border-color: rgba(245, 158, 11, .35); background:
    radial-gradient(120% 140% at 90% 0%, rgba(245, 158, 11, .1), transparent 55%), var(--surface); }
.side-card.cta p { color: var(--text-soft); font-size: .92rem; }
.side-card.cta.big .ico { margin-bottom: 1rem; }

.side-links { display: grid; gap: .35rem; }
.side-link {
    display: flex; align-items: center; gap: .75rem;
    padding: .6rem .65rem; border-radius: var(--radius-s);
    color: var(--text-soft); font-size: .92rem;
    transition: background .2s, color .2s;
}
.side-link > span:nth-child(2) { flex: 1; }
.side-link .ico { color: var(--accent); display: grid; place-items: center; flex: none; }
.side-link > svg:last-child { color: var(--text-faint); flex: none; }
.side-link:hover { background: var(--surface-2); color: var(--text); }
.side-link:hover > svg:last-child { color: var(--accent); }
.side-link.static:hover { background: none; color: var(--text-soft); }
.side-link.kb { align-items: flex-start; padding-block: .75rem; }
.side-link.kb strong { display: block; font-family: var(--font-display); font-size: .94rem; color: var(--text); line-height: 1.35; }
.side-link.kb em { font-style: normal; font-size: .8rem; color: var(--text-faint); }

.stats-card .stat-row {
    display: flex; align-items: baseline; gap: .9rem;
    padding-block: .7rem; border-bottom: 1px solid var(--border-soft);
    color: var(--text-soft); font-size: .92rem;
}
.stats-card .stat-row:last-child { border-bottom: 0; }
.stats-card .num {
    font-family: var(--font-display); font-weight: 700; font-size: 1.6rem;
    color: var(--accent); min-width: 64px; text-align: right;
}

/* ---------- Artikel / FAQ layout ---------- */
.article-layout {
    display: grid; grid-template-columns: 1.5fr .85fr;
    gap: clamp(2rem, 4.5vw, 3.5rem); align-items: start;
}
.article-body { font-size: 1.02rem; }

/* ---------- Rich prose ---------- */
.prose.rich h2 { font-size: 1.45rem; margin-top: 1.9em; }
.prose.rich h3 { font-size: 1.12rem; margin-top: 1.6em; }
.prose.rich ul, .prose.rich ol { padding-left: 1.3rem; color: var(--text-soft); }
.prose.rich li { margin-bottom: .45rem; }
.prose.rich a { color: var(--accent); text-decoration: underline; text-decoration-color: rgba(245, 158, 11, .35); text-underline-offset: 3px; transition: text-decoration-color .2s; }
.prose.rich a:hover { text-decoration-color: var(--accent); }
.prose.rich strong { color: var(--text); }
.prose.rich table { width: 100%; border-collapse: collapse; margin-block: 1.2rem; font-size: .94rem; }
.prose.rich th, .prose.rich td { text-align: left; padding: .6rem .8rem; border-bottom: 1px solid var(--border-soft); }
.prose.rich th { font-family: var(--font-display); color: var(--text); background: var(--surface-2); }
.prose.rich .lead { font-size: 1.1rem; color: var(--text-soft); }

/* ---------- Content band (home SEO blok) ---------- */
.content-band { background: var(--bg); }
.content-band-inner {
    display: grid; grid-template-columns: 1.5fr .85fr;
    gap: clamp(2rem, 4.5vw, 3.5rem); align-items: start;
}

/* ---------- Info banner ---------- */
.info-banner {
    margin-top: 2.6rem;
    display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap;
    background: var(--surface); border: 1px dashed var(--border);
    border-radius: var(--radius-m); padding: 1.4rem 1.7rem;
}
.info-banner h3 { margin-bottom: .25rem; font-size: 1.1rem; }
.info-banner p { margin: 0; color: var(--text-soft); font-size: .94rem; }

/* ---------- Contact redesign ---------- */
.contact-wrap {
    display: grid; grid-template-columns: .95fr 1.05fr;
    gap: clamp(1.6rem, 3.5vw, 2.8rem); align-items: stretch;
}
.contact-panel {
    background: linear-gradient(160deg, var(--surface) 0%, var(--bg-raise) 100%);
    border: 1px solid var(--border-soft); border-radius: var(--radius-l);
    overflow: hidden; display: flex; flex-direction: column;
}
.cp-block { padding: 1.8rem 1.9rem; }
.cp-block + .cp-block { border-top: 1px solid var(--border-soft); }
.phone-hero {
    background:
        radial-gradient(110% 150% at 90% -10%, rgba(245, 158, 11, .16), transparent 60%);
}
.cp-label {
    display: block; font-size: .82rem; font-weight: 600; letter-spacing: .12em;
    text-transform: uppercase; color: var(--accent); margin-bottom: .5rem;
}
.cp-phone {
    font-family: var(--font-display); font-weight: 700;
    font-size: clamp(1.7rem, 4vw, 2.4rem); letter-spacing: -.01em;
    display: inline-block; transition: color .2s;
}
.cp-phone:hover { color: var(--accent); }
.cp-sub { display: flex; align-items: center; gap: .45rem; color: var(--text-faint); font-size: .88rem; margin-top: .5rem; }
.cp-table { border-collapse: collapse; width: 100%; }
.cp-table td { padding: .8rem 0; vertical-align: top; font-size: .93rem; color: var(--text-soft); border-bottom: 1px solid var(--border-soft); }
.cp-table tr:last-child td { border-bottom: 0; }
.cp-table td:first-child { width: 40px; color: var(--accent); padding-top: .95rem; }
.cp-table strong { color: var(--text); font-family: var(--font-display); }
.cp-table a { color: var(--accent); }

.contact-form-card {
    background: var(--surface); border: 1px solid var(--border-soft);
    border-radius: var(--radius-l); padding: clamp(1.6rem, 3.5vw, 2.4rem);
    position: relative;
}
.contact-form-card h2 { font-size: 1.45rem; margin-bottom: .3rem; }
.contact-form-card .hint { color: var(--text-faint); font-size: .92rem; margin-bottom: 1.5rem; }
.form-note { text-align: center; color: var(--text-faint); font-size: .8rem; margin-top: .9rem; }
.contact-success { text-align: center; padding: 3rem 1rem; }
.contact-success .check {
    width: 64px; height: 64px; margin: 0 auto 1.2rem; border-radius: 50%;
    background: var(--accent-grad); color: #161002;
    display: grid; place-items: center; font-size: 1.8rem;
    animation: pop-in .5s var(--ease);
}

/* ---------- Wizard extra's ---------- */
.tile-group-label { font-size: .95rem; margin-bottom: .7rem; }
.option-tile .t-ico { display: grid; place-items: center; margin-bottom: .45rem; color: var(--text-soft); transition: color .2s; }
.option-tile.is-selected .t-ico, .option-tile:hover .t-ico { color: var(--accent); }
.trust-row {
    display: flex; flex-wrap: wrap; gap: 1rem 2rem; justify-content: center;
    margin-top: 1.6rem; color: var(--text-faint); font-size: .88rem;
}
.trust-row span { display: inline-flex; align-items: center; gap: .45rem; }
.trust-row svg { color: var(--accent); }
.trust-row a { color: var(--accent); }

/* ---------- Footer extra's ---------- */
.footer-contact-mini { display: grid; gap: .4rem; margin-top: 1.1rem; }
.footer-contact-mini a, .footer-contact-mini span {
    display: inline-flex; align-items: center; gap: .55rem;
    color: var(--text-soft); font-size: .9rem;
}
.footer-contact-mini svg { color: var(--accent); flex: none; }
.footer-contact-mini a:hover { color: var(--accent); }
.footer-col .more { color: var(--accent); font-weight: 500; }

/* ---------- Foto-categorie cards ---------- */
.cat-photo-card { display: flex; flex-direction: column; }
.cat-photo-card .thumb { position: relative; aspect-ratio: 16 / 10; overflow: hidden; }
.cat-photo-card .thumb img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .6s var(--ease);
}
.cat-photo-card:hover .thumb img { transform: scale(1.06); }
.cat-photo-card .thumb::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(8, 10, 14, .5));
}
.cat-chip {
    position: absolute; z-index: 2; left: .9rem; bottom: .9rem;
    width: 44px; height: 44px; border-radius: 12px;
    display: grid; place-items: center;
    background: var(--accent-grad); color: #161002;
    box-shadow: 0 6px 18px rgba(0, 0, 0, .35);
}
.cat-photo-card .body { padding: 1.15rem 1.25rem 1.3rem; display: flex; flex-direction: column; gap: .45rem; flex: 1; }
.cat-photo-card h3 { margin: 0; font-size: 1.1rem; }
.cat-photo-card .tagline { color: var(--accent); font-size: .86rem; font-weight: 600; margin: 0; }
.cat-photo-card p { color: var(--text-soft); font-size: .92rem; margin: 0; flex: 1; }
.cat-photo-card .meta-row {
    display: flex; align-items: center; justify-content: space-between;
    margin-top: .8rem; padding-top: .8rem; border-top: 1px solid var(--border-soft);
}
.cat-photo-card .from { font-size: .84rem; color: var(--text-faint); }
.cat-photo-card .from b { color: var(--accent); font-family: var(--font-display); }
.cat-photo-card .link { font-size: .87rem; color: var(--text-soft); display: inline-flex; align-items: center; gap: .35rem; transition: color .2s, gap .25s; }
.cat-photo-card:hover .link { color: var(--accent); gap: .6rem; }

/* ---------- Toepassingen-strip (op projecten) ---------- */
.solutions-strip {
    display: flex; flex-wrap: wrap; align-items: center; gap: .55rem;
    padding: 1rem 1.2rem; margin-bottom: 1.8rem;
    background: var(--surface); border: 1px dashed var(--border);
    border-radius: var(--radius-m);
}
.solutions-strip .lbl {
    display: inline-flex; align-items: center; gap: .45rem;
    font-family: var(--font-display); font-weight: 600; font-size: .88rem;
    color: var(--text-soft); margin-right: .4rem;
}
.solutions-strip .lbl svg { color: var(--accent); }
.solutions-strip .chip { display: inline-flex; align-items: center; gap: .4rem; }
.solutions-strip .chip svg { opacity: .8; }
.solutions-strip .chip.accent { border-color: rgba(245, 158, 11, .45); color: var(--accent); }
.solutions-strip .chip.accent:hover { background: var(--accent-soft); }

/* ---------- Kennisbank zoeker ---------- */
.kb-search {
    display: flex; align-items: center; gap: .7rem;
    max-width: 520px; margin-top: 1.6rem;
    background: var(--surface); border: 1.5px solid var(--border);
    border-radius: var(--radius-m); padding: .35rem .55rem .35rem 1rem;
    transition: border-color .2s, box-shadow .2s;
}
.kb-search:focus-within { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.kb-search svg { color: var(--text-faint); flex: none; }
.kb-search input {
    flex: 1; border: 0; background: none; color: var(--text);
    font: inherit; padding: .55rem 0; outline: none; min-width: 0;
}
.kb-search-count { font-size: .82rem; color: var(--accent); white-space: nowrap; padding-right: .5rem; font-family: var(--font-display); font-weight: 600; }

/* ---------- RAL kleurenwaaier ---------- */
.ral-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; }
.ral-card { overflow: hidden; display: flex; flex-direction: column; }
.ral-swatch {
    aspect-ratio: 16 / 9; position: relative;
    display: flex; align-items: flex-end; padding: .8rem .95rem;
}
.ral-code {
    font-family: var(--font-display); font-weight: 700; font-size: .92rem;
    color: #fff; text-shadow: 0 1px 6px rgba(0,0,0,.55);
    background: rgba(0,0,0,.28); padding: .2rem .6rem; border-radius: 7px;
    backdrop-filter: blur(4px);
}
.ral-card .body { padding: 1rem 1.1rem 1.15rem; display: flex; flex-direction: column; gap: .35rem; flex: 1; }
.ral-card h3 { margin: 0; font-size: 1rem; }
.ral-card p { color: var(--text-soft); font-size: .86rem; margin: 0; flex: 1; }
.ral-proof {
    display: flex; align-items: center; gap: .6rem;
    margin-top: .7rem; padding-top: .7rem; border-top: 1px solid var(--border-soft);
    font-size: .8rem; color: var(--text-soft);
}
.ral-proof img { width: 56px; height: 40px; object-fit: cover; border-radius: 7px; flex: none; }
.ral-proof span { display: inline-flex; align-items: center; gap: .3rem; }
.ral-proof:hover { color: var(--accent); }
@media (max-width: 1024px) { .ral-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px) { .ral-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .ral-grid { grid-template-columns: 1fr; } }

/* ---------- Kennisbank thema's ---------- */
.kb-theme { margin-bottom: 3.2rem; scroll-margin-top: 120px; }
.kb-theme:last-child { margin-bottom: 0; }

/* ---------- Begrippenlijst ---------- */
.letter-nav {
    display: flex; flex-wrap: wrap; gap: .4rem; margin-bottom: 2rem;
    position: sticky; top: calc(var(--header-h) + .8rem); z-index: 5;
    background: var(--bg); padding-block: .5rem;
}
.letter-nav a {
    width: 36px; height: 36px; display: grid; place-items: center;
    border-radius: var(--radius-s); font-family: var(--font-display); font-weight: 600;
    background: var(--surface); border: 1px solid var(--border-soft); color: var(--text-soft);
    transition: all .2s;
}
.letter-nav a:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-2px); }
.glossary-group { margin-bottom: 2rem; scroll-margin-top: 130px; }
.glossary-letter {
    font-size: 2rem;
    background: var(--accent-grad);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; color: transparent;
    border-bottom: 1px solid var(--border-soft); padding-bottom: .3rem;
}
.glossary { margin: 0; display: grid; gap: .7rem; }
.glossary-item {
    background: var(--surface); border: 1px solid var(--border-soft);
    border-radius: var(--radius-m); padding: 1rem 1.25rem;
    transition: border-color .25s;
}
.glossary-item:hover { border-color: var(--accent); }
.glossary-item dt { font-family: var(--font-display); font-weight: 600; margin-bottom: .25rem; }
.glossary-item dd { margin: 0; color: var(--text-soft); font-size: .93rem; }

/* ---------- E-mail gate (checklists) ---------- */
.gate-overlay[hidden] { display: none !important; }
.gate-overlay {
    position: fixed; inset: 0; z-index: 250;
    background: rgba(5, 7, 10, .8);
    backdrop-filter: blur(6px);
    display: flex; align-items: center; justify-content: center;
    padding: 1rem; animation: fade-in .25s ease;
}
.gate-card {
    position: relative; max-width: 420px; width: 100%;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--radius-l); padding: 2rem;
    box-shadow: var(--shadow-2);
}
.gate-card .ico {
    width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center;
    background: var(--accent-soft); color: var(--accent);
    border: 1px solid rgba(245,158,11,.22); margin-bottom: 1rem;
}
.gate-card h3 { margin-bottom: .4rem; }
.gate-card p { color: var(--text-soft); font-size: .92rem; }
.gate-card .form-field { margin-bottom: .8rem; }
.gate-close {
    position: absolute; top: .9rem; right: .9rem;
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--surface-2); border: 1px solid var(--border-soft);
    color: var(--text-soft); font-size: 1.2rem; cursor: pointer;
}
.gate-close:hover { color: var(--accent); border-color: var(--accent); }

/* ---------- Checklists ---------- */
.cl-section { margin-bottom: 1.8rem; }
.cl-section h2 {
    font-size: 1.15rem; padding-bottom: .5rem; margin-bottom: .8rem;
    border-bottom: 2px solid var(--accent);
    display: inline-block;
}
.cl-items { list-style: none; padding: 0; margin: 0; display: grid; gap: .4rem; }
.cl-items label {
    display: flex; gap: .75rem; align-items: flex-start;
    padding: .55rem .8rem; border-radius: var(--radius-s);
    background: var(--surface); border: 1px solid var(--border-soft);
    cursor: pointer; transition: border-color .2s;
}
.cl-items label:hover { border-color: var(--accent); }
.cl-items input[type="checkbox"] {
    width: 18px; height: 18px; margin-top: .15rem; accent-color: var(--accent); flex: none;
}
.cl-items input:checked + span { text-decoration: line-through; opacity: .55; }
.print-head { display: none; }

@media print {
    .site-header, .topbar, .site-footer, .cta-band, .mobile-cta, .no-print,
    .gate-overlay, .lightbox { display: none !important; }
    body { background: #fff !important; color: #000 !important; padding: 0 !important; }
    .checklist-print-area { padding: 0; }
    .print-head {
        display: block; font-family: var(--font-display);
        border-bottom: 2px solid #000; padding-bottom: 6pt; margin-bottom: 14pt;
        font-size: 11pt; color: #000;
    }
    .cl-section h2 { color: #000; border-color: #000; }
    .cl-items label { border: 1px solid #bbb; background: #fff; color: #000; break-inside: avoid; }
    .cl-items input[type="checkbox"] { accent-color: #000; }
}

/* ---------- 3D-configurator: tekening 2/3, wizard 1/3 ---------- */
.cfg-layout {
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-template-areas:
        "stage tools"
        "summary summary";
    gap: 1.4rem; align-items: start;
}
.cfg-stage { grid-area: stage; }
.cfg-tools { grid-area: tools; }
.cfg-summary { grid-area: summary; }
.cfg-group {
    background: var(--surface); border: 1px solid var(--border-soft);
    border-radius: var(--radius-m); padding: 1.1rem 1.2rem; margin-bottom: 1rem;
}
.cfg-group h3 { font-size: .98rem; display: flex; align-items: center; gap: .5rem; margin-bottom: .8rem; }
.cfg-group h3 svg { color: var(--accent); }
.cfg-hint { font-size: .8rem; color: var(--text-faint); margin: 0 0 .7rem; }
.cfg-bases { display: grid; grid-template-columns: repeat(3, 1fr); gap: .45rem; }
.cfg-bases button {
    padding: .5rem .3rem; border-radius: var(--radius-s); cursor: pointer;
    background: var(--input-bg); border: 1.5px solid var(--border);
    color: var(--text-soft); font-family: var(--font-display); font-weight: 600; font-size: .82rem;
    transition: all .15s;
}
.cfg-bases button:hover { border-color: var(--accent); color: var(--accent); }
.cfg-bases button.is-active { background: var(--accent-grad); border-color: transparent; color: #161002; }
.cfg-dims { font-size: .8rem; color: var(--text-faint); margin: .8rem 0; line-height: 1.5; }
.cfg-dims strong { color: var(--text); }
.cfg-radio { display: grid; gap: .3rem; }
.cfg-radio label, .cfg-check { display: flex; align-items: center; gap: .55rem; font-size: .88rem; color: var(--text-soft); cursor: pointer; padding: .25rem 0; }
.cfg-radio input, .cfg-check input { accent-color: var(--accent); width: 16px; height: 16px; }
.cfg-colors { display: grid; grid-template-columns: repeat(6, 1fr); gap: .45rem; }
.cfg-colors button {
    aspect-ratio: 1; border-radius: 9px; cursor: pointer;
    border: 2px solid var(--border); transition: transform .15s, border-color .15s;
}
.cfg-colors button:hover { transform: scale(1.12); }
.cfg-colors button.is-active { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }
.cfg-items { display: grid; gap: .45rem; }
.cfg-items button {
    display: flex; align-items: center; gap: .6rem;
    padding: .55rem .8rem; border-radius: var(--radius-s); cursor: pointer;
    background: var(--input-bg); border: 1.5px solid var(--border);
    color: var(--text-soft); font-size: .88rem; font-weight: 500; text-align: left;
    transition: all .15s;
}
.cfg-items button svg { color: var(--text-faint); }
.cfg-items button:hover { border-color: var(--accent); color: var(--accent); }
.cfg-items button.is-active { background: var(--accent-soft); border-color: var(--accent); color: var(--accent); }
.cfg-items button.is-active svg { color: var(--accent); }

.cfg-stage { min-width: 0; }
.cfg-canvas-wrap {
    position: relative; border-radius: var(--radius-l); overflow: hidden;
    border: 1px solid var(--border-soft); background: #272e38;
    height: clamp(480px, 78vh, 860px);
    box-shadow: var(--shadow-2);
}
.cfg-canvas-wrap canvas { width: 100%; height: 100%; display: block; touch-action: none; }
.cfg-loading {
    position: absolute; inset: 0; display: grid; place-items: center;
    color: #8B97A8; font-family: var(--font-display);
}
.cfg-measure {
    position: absolute; left: 50%; bottom: .9rem; transform: translateX(-50%);
    background: rgba(10, 13, 18, .72); color: #fff;
    padding: .45rem 1rem; border-radius: 99px; font-size: .85rem;
    backdrop-filter: blur(6px); white-space: nowrap;
}
.cfg-measure strong { color: #F59E0B; }
.cfg-stage-tip {
    position: absolute; bottom: .9rem; left: .9rem;
    color: rgba(255, 255, 255, .45); font-size: .72rem;
}

/* toolbar boven de tekening */
.cfg-toolbar {
    position: absolute; top: .8rem; right: .9rem;
    display: flex; gap: .45rem;
}
.cfg-toolbar button {
    display: inline-flex; align-items: center; gap: .4rem;
    padding: .45rem .8rem; border-radius: 9px; cursor: pointer;
    background: rgba(16, 21, 28, .85); color: #fff;
    border: 1px solid rgba(255, 255, 255, .12);
    font-size: .78rem; font-weight: 600; font-family: var(--font-display);
    backdrop-filter: blur(6px);
    transition: background .2s, color .2s;
}
.cfg-toolbar button:hover { background: var(--accent); color: #161002; }
.cfg-toolbar button.is-active { background: var(--accent); color: #161002; border-color: transparent; }

/* item-paneel (maat & positie) */
.cfg-item-panel {
    position: absolute; top: .8rem; left: .9rem;
    width: 250px; padding: .9rem 1rem;
    background: rgba(16, 21, 28, .92); color: #e9edf3;
    border: 1px solid rgba(255, 255, 255, .12); border-radius: 12px;
    backdrop-filter: blur(8px);
    font-size: .82rem;
}
.cip-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: .35rem; }
.cip-head strong { font-family: var(--font-display); font-size: .95rem; }
.cip-head button {
    width: 26px; height: 26px; border-radius: 50%; border: 0; cursor: pointer;
    background: rgba(255, 255, 255, .1); color: #fff; font-size: 1rem;
}
.cip-meta { color: #8B97A8; font-size: .75rem; }
.cip-pos { margin: .5rem 0; line-height: 1.5; }
.cip-pos strong { color: #F59E0B; }
.cip-size label { display: block; margin: .45rem 0; color: #aab4c0; font-size: .75rem; }
.cip-size input[type="range"] { width: 100%; accent-color: #F59E0B; }
/* tussenwand-opties in het paneel */
.cip-tw { margin: .55rem 0 .2rem; padding-top: .55rem; border-top: 1px solid rgba(255, 255, 255, .12); }
.cip-lbl { display: block; font-size: .72rem; color: #8B97A8; margin-bottom: .3rem; }
.cip-radio { display: flex; gap: .7rem; margin-bottom: .45rem; }
.cip-radio-wrap { flex-wrap: wrap; gap: .3rem .7rem; }
.cip-radio label, .cip-chk { display: flex; align-items: center; gap: .35rem; font-size: .78rem; color: #e9edf3; cursor: pointer; }
.cip-chk { padding: .15rem 0; }
.cip-radio input, .cip-chk input { accent-color: #F59E0B; }

.cip-delete {
    width: 100%; margin-top: .5rem; padding: .5rem;
    background: rgba(239, 68, 68, .15); color: #f87171;
    border: 1px solid rgba(239, 68, 68, .4); border-radius: 8px;
    cursor: pointer; font-size: .78rem; font-weight: 600;
    transition: background .2s;
}
.cip-delete:hover { background: rgba(239, 68, 68, .3); }

/* maatwerk-lengte slider */
.cfg-slider { margin-top: .7rem; }
.cfg-slider label { display: block; font-size: .82rem; color: var(--text-soft); margin-bottom: .3rem; }
.cfg-slider strong { color: var(--accent); }
.cfg-slider input[type="range"] { width: 100%; accent-color: var(--accent); }
.cfg-sumlist { list-style: none; padding: 0; margin: 0; }
.cfg-sumlist li {
    display: flex; justify-content: space-between; gap: 1rem;
    padding: .4rem 0; border-bottom: 1px solid var(--border-soft);
    font-size: .88rem; color: var(--text-soft);
}
.cfg-sumlist li:last-child { border-bottom: 0; }
.cfg-sumlist strong { color: var(--text); text-align: right; }
.cfg-summary .form-field { margin-bottom: .6rem; }

/* kennisbank: rond icoon-knopje rechts (zoals de thema-knop); tekstlink alleen in het mobiele menu */
.kb-btn { text-decoration: none; }
.kb-btn:hover { transform: none; }
@media (min-width: 861px) {
    .nav-kb-m { display: none; }
}
@media (max-width: 860px) {
    .kb-btn { display: none; }
}

/* voorbeeld-ontwerpen: nette gelijke grid */
.cfg-presets { display: grid; grid-template-columns: repeat(auto-fill, minmax(235px, 1fr)); gap: .5rem; margin-bottom: 1.2rem; align-items: stretch; }
.cfg-presets > span { grid-column: 1 / -1; font-size: .85rem; color: var(--text-faint); margin-bottom: .1rem; }
.cfg-presets button {
    display: inline-flex; align-items: center; gap: .6rem; width: 100%;
    padding: .5rem .95rem; border-radius: var(--radius-s); cursor: pointer;
    background: var(--surface); border: 1.5px solid var(--border-soft);
    color: var(--text-soft); font-family: var(--font-display);
    transition: all .15s; text-align: left;
}
.cfg-presets button svg { color: var(--accent); flex: 0 0 auto; }
.cfg-presets button span { display: grid; line-height: 1.25; }
.cfg-presets button b { font-size: .85rem; font-weight: 700; }
.cfg-presets button i { font-style: normal; font-size: .7rem; color: var(--text-faint); }
.cfg-presets button:hover { border-color: var(--accent); transform: translateY(-1px); }
.cfg-presets button:hover b { color: var(--accent); }

/* wizard-rail rechts: 5 stappen, één paneel tegelijk */
.cfg-tools { display: grid; grid-template-columns: 1fr; gap: .8rem; align-content: start; }
.cfg-tools .cfg-group { margin-bottom: 0; }
.cfg-steps { display: grid; grid-template-columns: repeat(5, 1fr); gap: .35rem; }
.cfg-steps button {
    display: grid; justify-items: center; gap: .25rem;
    padding: .55rem .2rem .5rem; border-radius: var(--radius-s); cursor: pointer;
    background: var(--surface); border: 1.5px solid var(--border-soft);
    color: var(--text-faint); transition: all .15s;
}
.cfg-steps button b {
    width: 26px; height: 26px; display: grid; place-items: center;
    border-radius: 50%; font-size: .82rem; font-family: var(--font-display);
    background: var(--surface-2); border: 1.5px solid var(--border); color: var(--text-soft);
    transition: all .15s;
}
.cfg-steps button span { font-size: .68rem; font-weight: 600; letter-spacing: .02em; }
.cfg-steps button:hover { border-color: var(--accent); color: var(--accent); }
.cfg-steps button.is-active { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
.cfg-steps button.is-active b { background: var(--accent-grad); border-color: transparent; color: #161002; }
.cfg-steps button.is-done b { border-color: var(--accent); color: var(--accent); }
.cfg-panel { display: none; }
.cfg-panel.is-active { display: block; }
.cfg-stepnav { display: flex; justify-content: space-between; gap: .6rem; }
.cfg-stepnav .btn { flex: 1; }
.cfg-subhead {
    display: flex; align-items: center; gap: .45rem;
    font-size: .88rem; margin: 1rem 0 .35rem;
    padding-top: .8rem; border-top: 1px dashed var(--border-soft);
}
.cfg-subhead svg { color: var(--accent); }

/* RAL-code invoer */
.cfg-ral-custom { margin-top: .9rem; padding-top: .8rem; border-top: 1px dashed var(--border-soft); }
.cfg-ral-custom > label { display: block; font-size: .82rem; color: var(--text-soft); margin-bottom: .35rem; }
.cfg-ral-row { display: flex; gap: .5rem; align-items: stretch; margin-bottom: .4rem; }
.cfg-ral-row input[type="text"] {
    flex: 1; min-width: 0; padding: .5rem .7rem;
    background: var(--input-bg); border: 1.5px solid var(--border);
    border-radius: var(--radius-s); color: var(--text); font-size: .88rem;
}
.cfg-ral-row input[type="text"]:focus { outline: none; border-color: var(--accent); }
.cfg-ral-row input[type="color"] {
    width: 46px; padding: 3px; cursor: pointer;
    background: var(--input-bg); border: 1.5px solid var(--border); border-radius: var(--radius-s);
}

/* samenvattingsband onder de tekening */
.cfg-summary { display: grid; grid-template-columns: 1fr 1.25fr; gap: 1.4rem; align-items: start; }
.cfg-summary > a { grid-column: 1 / -1; }
.cfg-summary .side-card { margin-bottom: 0; }

/* elektra-samenstelbox */
.cfg-sub { margin: .4rem 0 .6rem 1.6rem; padding: .7rem .9rem; border-left: 2px solid var(--accent); background: var(--input-bg); border-radius: 0 10px 10px 0; }
.cfg-steppers { margin-top: .6rem; display: grid; gap: .35rem; }
.cfg-step { display: flex; align-items: center; justify-content: space-between; gap: .6rem; font-size: .84rem; color: var(--text-soft); }
.cfg-step > div { display: flex; align-items: center; gap: .45rem; }
.cfg-step button {
    width: 26px; height: 26px; border-radius: 7px; cursor: pointer;
    background: var(--surface-2); border: 1px solid var(--border); color: var(--text);
    font-size: 1rem; line-height: 1;
}
.cfg-step button:hover { border-color: var(--accent); color: var(--accent); }
.cfg-step b { min-width: 1.4em; text-align: center; color: var(--accent); font-family: var(--font-display); }

@media (max-width: 980px) {
    .cfg-layout { grid-template-columns: 1fr; grid-template-areas: "stage" "tools" "summary"; }
    .cfg-stage, .cfg-tools { position: static; }
    .cfg-canvas-wrap { height: 62vh; }
    .cfg-summary { grid-template-columns: 1fr; }
}

/* ---------- Sticky mobiele CTA ---------- */
.mobile-cta {
    display: none;
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 90;
    padding: .7rem .9rem calc(.7rem + env(safe-area-inset-bottom));
    background: var(--header-bg);
    backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
    border-top: 1px solid var(--border);
    gap: .7rem;
}
.mobile-cta .btn { flex: 1; }

/* ---------- 19. Responsive ---------- */
@media (max-width: 1024px) {
    .grid-4 { grid-template-columns: repeat(3, 1fr); }
    .process-grid { grid-template-columns: repeat(2, 1fr); }
    .process-step:not(:last-child)::after { display: none; }
    .hero-card-1 { left: 0; }
    .hero-card-2 { right: 0; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 860px) {
    .hero-inner { grid-template-columns: 1fr; }
    .hero-visual { order: -1; }
    .detail-grid { grid-template-columns: 1fr; }
    .contact-grid { grid-template-columns: 1fr; }
    .contact-wrap { grid-template-columns: 1fr; }
    .article-layout { grid-template-columns: 1fr; }
    .content-band-inner { grid-template-columns: 1fr; }
    .grid-3 { grid-template-columns: repeat(2, 1fr); }
    .stats-grid { grid-template-columns: repeat(2, 1fr); }
    .topbar-item:not(.strong):not(.topbar-spacer) { display: none; }
    .mobile-cta { display: flex; }
    body { padding-bottom: 64px; }

    .nav-burger {
        display: inline-flex; flex-direction: column; justify-content: center; gap: 5px;
        width: 42px; height: 42px; padding: 0 9px;
        background: var(--surface-2); border: 1px solid var(--border-soft);
        border-radius: var(--radius-s); cursor: pointer;
    }
    .nav-burger span { height: 2px; background: var(--text); border-radius: 2px; transition: transform .3s var(--ease), opacity .2s; }
    .nav-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .nav-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
    .nav-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    .main-nav {
        position: fixed; top: var(--header-h); left: 0; right: 0;
        flex-direction: column; align-items: stretch; gap: .3rem;
        background: var(--bg); border-bottom: 1px solid var(--border);
        padding: 1.1rem clamp(1.1rem, 4vw, 2rem) 1.5rem;
        transform: translateY(-130%); opacity: 0; pointer-events: none;
        transition: transform .35s var(--ease), opacity .3s;
        box-shadow: var(--shadow-2); z-index: 99;
    }
    .main-nav.is-open { transform: none; opacity: 1; pointer-events: auto; }
    .nav-link { padding: .85rem 1rem; font-size: 1.02rem; }
    .nav-cta { margin: .5rem 0 0; }
}

@media (max-width: 580px) {
    .grid-3, .grid-4 { grid-template-columns: 1fr; }
    .process-grid { grid-template-columns: 1fr; }
    .form-grid { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr; }
    .hero-stats { flex-wrap: wrap; gap: 1.2rem 2rem; }
    .gallery-thumbs { grid-template-columns: repeat(4, 1fr); }
    .cta-band-inner { flex-direction: column; align-items: flex-start; }
    .hero-card-1 { display: none; }
}
