/* ============================================================
   Secrotec.nl — Design System (v3, "Dutch Secure Audit Premium")
   Premium cybersecurity look: donkerblauw + levendig blauw + teal,
   veel witruimte, symmetrische grids, dashboards & glow.
   WCAG AA contrast · 8px spacing grid · responsive.
   ============================================================ */

/* ---------- 1. Design tokens ---------- */
:root {
  /* Navy schaal */
  --navy-950: #061A33;
  --navy-900: #081D38;
  --navy-850: #0B2445;
  --navy-800: #102F55;
  --navy:     #0B1D38; /* primary / autoriteit (alias) */

  /* Blauw / accent */
  --blue-700: #0E3C68; /* hover / dieper */
  --blue-600: #134A80;
  --blue-500: #168BFF; /* vivid — alleen voor hero-dashboards op navy */
  --blue-300: #6BB8FF;
  --blue:     #15518C; /* CTA / links / accent — diep vertrouwensblauw */
  --blue-050: #EAF1F8; /* zachte sectieachtergrond (alias) */

  --cyan-400: #20D7F5;
  --teal-500: #10B981;
  --green:    #10B981; /* compliance / akkoord (alias) */
  --green-600:#0E9E6E;
  --amber:    #F59E0B; /* ALLEEN risico / gap / aandachtspunt */

  /* Neutraal */
  --white:    #FFFFFF;
  --off-white:#F7FAFF;
  --soft-blue:#EEF6FF;
  --ice:      #F5F7FA; /* achtergrond (alias) */
  --ink:      #07172F; /* tekst (alias) */
  --ink-600:  #52627A; /* secundair (alias text-muted) */
  --ink-400:  #7A8AA3;
  --border:   #D9E6F5;

  /* Vorm & schaduw */
  --shadow:    0 8px 24px rgba(8,29,56,.08);
  --shadow-lg: 0 16px 44px rgba(8,29,56,.14);
  --shadow-glow: 0 0 40px rgba(22,139,255,.35);
  --radius-lg: 18px;
  --radius:    14px;
  --radius-sm: 10px;
  --maxw:      1280px;

  /* Ruimte (8px grid) */
  --s-1:.25rem; --s-2:.5rem; --s-3:.75rem; --s-4:1rem;
  --s-5:1.5rem; --s-6:2rem; --s-7:3rem; --s-8:4rem; --s-9:6rem;

  --font-sans: "Inter", "Manrope", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* ---------- 2. Reset & basis ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0; font-family: var(--font-sans);
  font-size: 1.0625rem; line-height: 1.6; color: var(--ink);
  background: var(--white); -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--blue); text-decoration: none; }
a:hover { text-decoration: underline; }
:focus-visible { outline: 3px solid rgba(32,215,245,.75); outline-offset: 3px; border-radius: 6px; }

/* ---------- 3. Typografie ---------- */
h1, h2, h3, h4 { font-family: var(--font-sans); color: var(--navy); line-height: 1.15; margin: 0 0 var(--s-4); font-weight: 800; letter-spacing: -.02em; }
h1 { font-size: clamp(2.25rem, 4.5vw, 3.5rem); line-height: 1.08; }
h2 { font-size: clamp(1.6rem, 3vw, 2.25rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.4rem); font-weight: 700; }
p { margin: 0 0 var(--s-4); }
.lead { font-size: 1.2rem; color: var(--ink-600); }
.eyebrow { display: inline-block; font-size: .82rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--blue); margin-bottom: var(--s-3); }
ul, ol { padding-left: 1.25rem; }
li { margin-bottom: var(--s-2); }

/* ---------- 4. Layout ---------- */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: 32px; }
.section { padding-block: var(--s-9); }
.section--tint { background: var(--soft-blue); }
.section--ice { background: var(--ice); }
.section__head { max-width: 720px; margin-bottom: var(--s-7); }
.grid { display: grid; gap: var(--s-5); }
.grid--2 { grid-template-columns: repeat(2,1fr); }
.grid--3 { grid-template-columns: repeat(3,1fr); }
.grid--4 { grid-template-columns: repeat(4,1fr); }
@media (max-width: 980px){ .grid--3,.grid--4{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px){ .grid--2,.grid--3,.grid--4{ grid-template-columns: 1fr; } }

/* ---------- 5. Buttons ---------- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .55rem; font-weight: 700; font-size: 1rem; line-height: 1; min-height: 52px; padding: .95rem 1.6rem; border-radius: var(--radius); border: 2px solid transparent; cursor: pointer; transition: .18s ease; text-decoration: none; }
.btn svg { width: 18px; height: 18px; flex: 0 0 18px; }
.btn--primary { background: var(--blue); color: #fff; box-shadow: 0 8px 20px rgba(21,81,140,.28); }
.btn--primary:hover { background: var(--blue-700); transform: translateY(-2px); text-decoration: none; box-shadow: 0 12px 26px rgba(21,81,140,.36); }
.btn--green { background: var(--teal-500); color: #fff; box-shadow: 0 8px 20px rgba(16,185,129,.28); }
.btn--green:hover { background: var(--green-600); transform: translateY(-2px); text-decoration: none; }
.btn--ghost { background: rgba(255,255,255,.06); color: #fff; border-color: rgba(255,255,255,.5); }
.btn--ghost:hover { background: rgba(255,255,255,.14); text-decoration: none; transform: translateY(-2px); }
.btn--outline { background: transparent; color: var(--blue); border-color: var(--blue); }
.btn--outline:hover { background: var(--blue-050); text-decoration: none; }

/* ---------- 6. Header / navigatie ---------- */
.site-header { position: sticky; top: 0; z-index: 60; background: rgba(255,255,255,.94); backdrop-filter: blur(10px); border-bottom: 1px solid var(--border); transition: box-shadow .2s ease; }
.site-header.is-scrolled { box-shadow: 0 6px 22px rgba(8,29,56,.10); }
.nav { display: flex; align-items: center; gap: var(--s-5); min-height: 82px; }
.brand { display: inline-flex; align-items: center; margin-right: auto; }
.brand:hover { text-decoration: none; }
.brand__logo { height: 52px; width: auto; display: block; }
@media (max-width: 600px){ .brand__logo{ height: 42px; } }
.brand__icon { width: 40px; height: 40px; display: block; }
.nav__links { display: flex; align-items: center; gap: var(--s-6); list-style: none; margin: 0; padding: 0; }
.nav__links a { color: var(--navy); font-weight: 600; font-size: .98rem; position: relative; padding: .25rem 0; }
.nav__links a:hover { color: var(--blue); text-decoration: none; }
.nav__links a:not(.btn)::after { content: ""; position: absolute; left: 0; bottom: -4px; width: 0; height: 2px; background: var(--blue); transition: width .2s ease; }
.nav__links a:not(.btn):hover::after, .nav__links a[aria-current="page"]::after { width: 100%; }
.nav__links .btn { min-height: 46px; padding: .62rem 1.2rem; font-size: .95rem; border-radius: var(--radius-sm); }
.nav__links .btn svg { width: 17px; height: 17px; }
.nav__toggle { display: none; background: none; border: 0; cursor: pointer; padding: .5rem; margin-left: auto; }
.nav__toggle span { display: block; width: 26px; height: 2px; background: var(--navy); margin: 6px 0; transition: .2s; border-radius: 2px; }
@media (max-width: 980px){
  .nav__toggle { display: block; }
  .nav__links { position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; align-items: stretch; background: #fff; border-bottom: 1px solid var(--border); padding: var(--s-4) 32px var(--s-5); gap: var(--s-3); display: none; box-shadow: var(--shadow); }
  .nav__links.is-open { display: flex; }
  .nav__links .btn { width: 100%; }
}

/* ---------- 6b. Diensten dropdown / mega-menu ---------- */
.nav__item--has-menu { position: relative; display: flex; align-items: center; }
.nav__dropbtn { display: inline-flex; align-items: center; gap: .35rem; background: none; border: 0; cursor: pointer; font-family: inherit; color: var(--navy); font-weight: 600; font-size: .98rem; padding: .25rem 0; }
.nav__dropbtn:hover { color: var(--blue); }
.nav__dropbtn .caret { width: 14px; height: 14px; transition: transform .2s ease; }
.nav__item--has-menu:hover .nav__dropbtn .caret,
.nav__dropbtn[aria-expanded="true"] .caret { transform: rotate(180deg); }
.nav__dropdown { position: absolute; top: calc(100% + 8px); left: 50%; transform: translateX(-50%) translateY(6px); display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-5); min-width: 540px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow-lg); padding: var(--s-5); opacity: 0; visibility: hidden; transition: opacity .18s ease, transform .18s ease; z-index: 70; }
/* onzichtbare brug over het gat knop↔menu zodat hover niet wegvalt */
.nav__dropdown::before { content: ""; position: absolute; left: 0; right: 0; top: -16px; height: 16px; background: transparent; }
/* hover-intentie: knop heeft wat onderruimte zodat de muis het menu haalt */
.nav__item--has-menu .nav__dropbtn { padding-bottom: .5rem; margin-bottom: -.25rem; }
.nav__item--has-menu:hover .nav__dropdown,
.nav__item--has-menu:focus-within .nav__dropdown,
.nav__item--has-menu.is-open .nav__dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.nav__dropcol { display: flex; flex-direction: column; gap: .1rem; }
.nav__drophead { font-size: .72rem; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; color: var(--ink-400); margin-bottom: .4rem; }
.nav__dropdown a { color: var(--ink); font-weight: 500; font-size: .92rem; padding: .45rem .55rem; border-radius: 8px; }
.nav__dropdown a::after { display: none; }
.nav__dropdown a:hover { background: var(--blue-050); color: var(--blue); text-decoration: none; }
.nav__dropall { color: var(--blue) !important; font-weight: 700 !important; margin-top: .4rem; }
@media (max-width: 980px){
  .nav__item--has-menu { display: block; }
  .nav__dropbtn { width: 100%; justify-content: space-between; padding: .5rem 0; }
  .nav__dropdown { position: static; transform: none; min-width: 0; grid-template-columns: 1fr; box-shadow: none; border: 0; padding: .25rem 0 .5rem .75rem; opacity: 1; visibility: visible; display: none; gap: var(--s-4); }
  .nav__item--has-menu.is-open .nav__dropdown { display: grid; }
}

/* ---------- 7. Hero ---------- */
.hero { position: relative; color: #E8F0FB; background: radial-gradient(circle at 72% 42%, rgba(22,139,255,.30), transparent 38%), radial-gradient(circle at 12% 18%, rgba(32,215,245,.12), transparent 32%), linear-gradient(135deg, var(--navy-950) 0%, var(--navy-900) 46%, var(--navy-850) 100%); overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px); background-size: 46px 46px; opacity: .5; pointer-events: none; }
.hero .container { position: relative; z-index: 1; padding-block: var(--s-9); }
.hero h1 { color: #fff; max-width: 16ch; }
.hero p { font-size: 1.2rem; color: #C6D6EC; max-width: 58ch; }
.hero .eyebrow { color: var(--cyan-400); }
.hero__cta { display: flex; gap: var(--s-4); flex-wrap: wrap; margin-top: var(--s-6); }
.hero__benefits { display: flex; flex-wrap: wrap; gap: var(--s-4) var(--s-6); margin-top: var(--s-6); list-style: none; padding: 0; }
.hero__benefits li { display: inline-flex; align-items: center; gap: .55rem; font-weight: 600; color: #DCE8F7; margin: 0; }
.hero__benefits svg { width: 22px; height: 22px; flex: 0 0 22px; color: var(--teal-500); }

/* Homepage hero grid + visual */
.hero--home .hero__grid { display: grid; grid-template-columns: minmax(0,1.05fr) minmax(380px,.95fr); gap: 56px; align-items: center; }
@media (max-width: 980px){ .hero--home .hero__grid { grid-template-columns: 1fr; gap: var(--s-7); } }

.hero-visual { position: relative; min-height: 420px; display: grid; place-items: center; }
.hero-visual__shield { width: min(320px, 70%); filter: drop-shadow(0 24px 60px rgba(22,139,255,.45)); animation: floaty 6s ease-in-out infinite; }
@keyframes floaty { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-12px); } }
.dash { position: absolute; background: rgba(11,36,69,.82); border: 1px solid rgba(107,184,255,.30); border-radius: var(--radius); padding: .85rem 1rem; box-shadow: 0 12px 30px rgba(0,0,0,.35); backdrop-filter: blur(6px); color: #DCE8F7; font-size: .8rem; width: 220px; }
.dash__label { display: block; font-size: .68rem; letter-spacing: .06em; text-transform: uppercase; color: var(--blue-300); font-weight: 800; margin-bottom: .5rem; }
.dash--score { top: 6%; right: -4%; }
.dash--results { bottom: 30%; right: -8%; width: 200px; }
.dash--top { bottom: 2%; left: -6%; width: 210px; }
.dash__score { display: flex; align-items: center; gap: .8rem; }
.score-ring { width: 56px; height: 56px; flex: 0 0 56px; border-radius: 50%; display: grid; place-items: center; font-weight: 800; color: #fff; font-size: .95rem; background: conic-gradient(var(--cyan-400) 0% 92%, rgba(255,255,255,.12) 92% 100%); }
.score-ring span { background: var(--navy-900); width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; }
.dash__list { list-style: none; margin: 0; padding: 0; }
.dash__list li { display: flex; align-items: center; gap: .4rem; margin: 0 0 .25rem; }
.dash__list li::before { content: "✓"; color: var(--teal-500); font-weight: 800; }
.dash--top ol { margin: 0; padding-left: 1.1rem; }
.dash--top li { margin-bottom: .2rem; }
.dash--top li::marker { color: var(--cyan-400); font-weight: 700; }
.mini-bars { display: flex; align-items: flex-end; gap: 5px; height: 46px; }
.mini-bars i { flex: 1; background: linear-gradient(var(--blue-500), var(--blue-700)); border-radius: 3px 3px 0 0; }
@media (max-width: 980px){
  .hero-visual { min-height: 360px; }
  .dash--score { right: 0; } .dash--results { right: 0; } .dash--top { left: 0; }
}
@media (max-width: 520px){ .dash { display: none; } .hero-visual__shield { width: 200px; } }

/* ---------- 8. Standards / trust strip ---------- */
.standards-strip { background: #fff; border-bottom: 1px solid var(--border); }
.standards-grid { display: grid; grid-template-columns: repeat(6,1fr); }
.standard-item { display: flex; flex-direction: column; gap: .15rem; padding: var(--s-5) var(--s-4); position: relative; }
.standard-item + .standard-item::before { content: ""; position: absolute; left: 0; top: 22%; bottom: 22%; width: 1px; background: var(--border); }
.standard-item svg { width: 26px; height: 26px; color: var(--blue); margin-bottom: .4rem; }
.standard-item strong { color: var(--navy); font-size: 1rem; }
.standard-item small { color: var(--ink-400); font-size: .82rem; }
@media (max-width: 980px){ .standards-grid { grid-template-columns: repeat(3,1fr); } .standard-item:nth-child(3n+1)::before{ display:none; } }
@media (max-width: 560px){ .standards-grid { grid-template-columns: repeat(2,1fr); } .standard-item::before{ display:none !important; } }

/* ---------- 9. Cards ---------- */
.card { background: #fff; border: 1px solid #E6EEF8; border-radius: var(--radius); padding: 24px; box-shadow: var(--shadow); transition: .18s ease; display: block; }
.card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); border-color: var(--blue-300); text-decoration: none; }
.card__head { display: flex; align-items: center; gap: .85rem; margin-bottom: var(--s-3); }
.card__head h3 { margin: 0; font-size: 1.2rem; }
.card h3 { margin-bottom: var(--s-2); }
.card p { color: var(--ink-600); margin-bottom: var(--s-3); line-height: 1.55; }
.card__icon { width: 46px; height: 46px; flex: 0 0 46px; border-radius: 50%; background: var(--blue); color: #fff; display: grid; place-items: center; box-shadow: 0 6px 16px rgba(21,81,140,.28); }
.card__icon svg { width: 22px; height: 22px; }
.card__link { font-weight: 700; color: var(--blue); display: inline-flex; align-items: center; gap: .35rem; }
.card__link::after { content: "→"; transition: transform .18s ease; }
.card:hover .card__link::after { transform: translateX(4px); }

/* ---------- 10. Probleemblok / proces ---------- */
.problem { border-left: 4px solid var(--amber); background: #FFF8EC; padding: var(--s-5) var(--s-6); border-radius: var(--radius); }
.problem p { color: #7c5b12; font-weight: 600; margin: 0; }
.steps { counter-reset: step; display: grid; gap: var(--s-5); grid-template-columns: repeat(5,1fr); }
@media (max-width: 900px){ .steps{ grid-template-columns: 1fr; } }
.step { position: relative; padding-top: var(--s-6); }
.step::before { counter-increment: step; content: counter(step); position: absolute; top: 0; left: 0; width: 40px; height: 40px; border-radius: 50%; background: var(--blue); color: #fff; display: grid; place-items: center; font-weight: 800; box-shadow: 0 6px 16px rgba(21,81,140,.3); }
.step h3 { font-size: 1.1rem; }
.step p { color: var(--ink-600); font-size: .95rem; }

/* ---------- 11. FAQ ---------- */
.faq { max-width: 820px; }
.faq__item { border-bottom: 1px solid var(--border); }
.faq__q { width: 100%; text-align: left; background: none; border: 0; cursor: pointer; padding: var(--s-5) 2.5rem var(--s-5) 0; font-size: 1.1rem; font-weight: 700; color: var(--navy); position: relative; font-family: inherit; }
.faq__q::after { content: "+"; position: absolute; right: 0; top: 50%; transform: translateY(-50%); font-size: 1.5rem; color: var(--blue); }
.faq__q[aria-expanded="true"]::after { content: "−"; }
.faq__a { display: none; padding-bottom: var(--s-5); color: var(--ink-600); }
.faq__a.is-open { display: block; }

/* ---------- 12. CTA-band (inner) + CTA-banner (home) ---------- */
.cta-band { background: linear-gradient(135deg, var(--blue), var(--blue-700)); color: #fff; border-radius: var(--radius-lg); padding: var(--s-7); text-align: center; box-shadow: var(--shadow-lg); }
.cta-band h2 { color: #fff; }
.cta-band p { color: #DCE8F7; max-width: 50ch; margin-inline: auto; }

.cta-banner { background: var(--soft-blue); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--s-6) var(--s-7); display: flex; align-items: center; gap: var(--s-5); }
.cta-banner__icon { width: 56px; height: 56px; flex: 0 0 56px; border-radius: 14px; background: var(--blue); color: #fff; display: grid; place-items: center; box-shadow: 0 8px 20px rgba(21,81,140,.3); }
.cta-banner__icon svg { width: 28px; height: 28px; }
.cta-banner__text { flex: 1; }
.cta-banner__text h2 { margin: 0 0 .3rem; font-size: 1.5rem; }
.cta-banner__text p { margin: 0; color: var(--ink-600); }
.cta-banner .btn { flex: 0 0 auto; }
@media (max-width: 760px){ .cta-banner { flex-direction: column; align-items: flex-start; text-align: left; } .cta-banner .btn{ width: 100%; } }

/* ---------- 12b. Klanten / vertrouwd-door strip ---------- */
.clients { background: #fff; padding: var(--s-8) 0 var(--s-2); }
.clients__inner { background: #EEF1FB; border-radius: 28px; padding: 26px 28px; }
.clients__title { text-align: center; font-size: .78rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-400); margin: 0 0 var(--s-5); }
.clients__row { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 26px 44px; }
.clients__row img { height: 32px; width: auto; display: block; }
@media (max-width: 600px){ .clients__inner { border-radius: 20px; padding: 20px 16px; } .clients__row { gap: 20px 28px; } .clients__row img { height: 24px; } }

/* ---------- 13. Premium footer ---------- */
.site-footer { position: relative; overflow: hidden; color: #fff; background: radial-gradient(circle at 50% 100%, rgba(22,139,255,.28), transparent 24%), radial-gradient(circle at 8% 20%, rgba(22,139,255,.12), transparent 28%), linear-gradient(135deg, var(--navy-950) 0%, var(--navy-900) 55%, var(--navy-950) 100%); }
.site-footer::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px); background-size: 44px 44px; opacity: .18; pointer-events: none; }
.site-footer::after { content: ""; position: absolute; left: 50%; bottom: 70px; width: 260px; height: 2px; transform: translateX(-50%); background: linear-gradient(90deg, transparent, var(--blue-500), transparent); box-shadow: 0 0 22px rgba(22,139,255,.9); pointer-events: none; }
.footer-main { position: relative; z-index: 1; padding: 58px 0 34px; }
.footer-grid { display: grid; grid-template-columns: 1.3fr .95fr .95fr .95fr 1.05fr; gap: 40px; align-items: start; }
.footer-grid > * + * { border-left: 1px solid rgba(255,255,255,.16); padding-left: 42px; }
.footer-brand .brand { margin: 0; }
.footer-brand .brand__icon { width: 40px; height: 40px; }
.footer-brand .brand__name { color: #fff; font-weight: 800; font-size: 1.2rem; margin-left: .5rem; }
.footer-brand p { margin: 22px 0; max-width: 340px; color: rgba(255,255,255,.82); line-height: 1.7; font-size: .95rem; }
.footer-socials { display: flex; gap: 12px; }
.footer-socials a { width: 40px; height: 40px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; color: #fff; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); transition: 180ms ease; }
.footer-socials a:hover { background: rgba(22,139,255,.35); border-color: rgba(107,184,255,.7); box-shadow: 0 0 18px rgba(22,139,255,.35); transform: translateY(-2px); text-decoration: none; }
.footer-socials svg { width: 18px; height: 18px; }
.footer-column h4 { margin: 0 0 20px; color: #fff; font-size: 14px; letter-spacing: .06em; text-transform: uppercase; font-weight: 800; }
.footer-column ul { list-style: none; margin: 0; padding: 0; }
.footer-column li { margin: 0 0 11px; }
.footer-column ul a { color: rgba(255,255,255,.82); font-size: .95rem; transition: 180ms ease; }
.footer-column ul a::before { content: "›"; margin-right: 10px; color: var(--cyan-400); font-weight: 800; }
.footer-column ul a:hover { color: #fff; text-decoration: none; }
.footer-contact { font-style: normal; }
.contact-row { display: flex; align-items: flex-start; gap: 14px; padding: 9px 0; color: rgba(255,255,255,.88); }
.contact-row:hover { text-decoration: none; color: #fff; }
.contact-icon { width: 38px; height: 38px; flex: 0 0 38px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; color: #fff; background: rgba(22,139,255,.14); border: 1px solid rgba(107,184,255,.35); }
.contact-icon svg { width: 17px; height: 17px; }
.footer-bottom { position: relative; z-index: 1; border-top: 1px solid rgba(255,255,255,.14); padding: 20px 0; }
.footer-bottom-inner { display: flex; justify-content: space-between; align-items: center; gap: 24px; }
.footer-bottom p { margin: 0; color: rgba(255,255,255,.72); font-size: 14px; }
.footer-bottom nav { display: flex; align-items: center; gap: 14px; }
.footer-bottom nav a { color: rgba(255,255,255,.84); font-size: 14px; }
.footer-bottom nav a:hover { color: #fff; }
.footer-bottom nav a + a::before { content: "•"; margin-right: 14px; color: var(--blue-500); }
@media (max-width: 1100px){
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
  .footer-grid > * + * { border-left: 0; padding-left: 0; }
  .footer-grid > * { border-top: 1px solid rgba(255,255,255,.12); padding-top: 24px; }
  .footer-brand { border-top: 0; padding-top: 0; }
}
@media (max-width: 700px){
  .footer-main { padding: 44px 0 28px; }
  .footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .footer-brand p { max-width: none; }
  .footer-bottom-inner { flex-direction: column; text-align: center; }
  .footer-bottom nav { flex-wrap: wrap; justify-content: center; }
}

/* ---------- 13b. Portfolio ---------- */
.portfolio-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-6); }
@media (max-width: 700px){ .portfolio-grid { grid-template-columns: 1fr; } }
.portfolio-card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow); transition: .18s ease; }
.portfolio-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.portfolio-card__shot { display: block; aspect-ratio: 16 / 10; overflow: hidden; border-bottom: 1px solid var(--border); background: var(--ice); }
.portfolio-card__shot img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; transition: transform .4s ease; }
.portfolio-card:hover .portfolio-card__shot img { transform: scale(1.03); }
.portfolio-card__body { padding: var(--s-5); }
.portfolio-card__tag { display: inline-block; font-size: .72rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: var(--blue); background: var(--blue-050); padding: .25rem .55rem; border-radius: 6px; margin-bottom: .6rem; }
.portfolio-card__body h3 { margin: 0 0 .4rem; font-size: 1.25rem; }
.portfolio-card__body p { color: var(--ink-600); margin-bottom: .7rem; }
.portfolio-card__link { font-weight: 700; color: var(--blue); }
.portfolio-card__link::after { content: " ↗"; }

/* ---------- 13c. Blog (2-koloms: kaarten + sidebar) ---------- */
.blog-layout { display: grid; grid-template-columns: minmax(0,1fr) 320px; gap: var(--s-6); align-items: start; }
@media (max-width: 980px){ .blog-layout { grid-template-columns: 1fr; } }
.blog-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-5); }
@media (max-width: 640px){ .blog-list { grid-template-columns: 1fr; } }
.blog-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow); transition: .18s ease; }
.blog-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); border-color: var(--blue-300); }
.blog-card__media { display: block; overflow: hidden; }
.blog-card__media img { width: 100%; aspect-ratio: 1080 / 630; object-fit: cover; display: block; transition: transform .4s ease; }
.blog-card:hover .blog-card__media img { transform: scale(1.03); }
.blog-card__body { padding: var(--s-5); display: flex; flex-direction: column; flex: 1; }
.blog-cat { align-self: flex-start; font-size: .7rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; color: var(--blue); background: var(--blue-050); padding: .25rem .6rem; border-radius: 999px; margin-bottom: .6rem; }
.blog-card__body h3 { margin: 0 0 .4rem; font-size: 1.2rem; line-height: 1.25; }
.blog-card__body h3 a { color: var(--navy); }
.blog-card__body h3 a:hover { color: var(--blue); text-decoration: none; }
.blog-excerpt { color: var(--ink-600); font-size: .95rem; margin: 0 0 var(--s-4); display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.blog-meta { margin-top: auto; display: flex; align-items: center; gap: var(--s-4); color: var(--ink-400); font-size: .82rem; }
.blog-meta span { display: inline-flex; align-items: center; gap: .35rem; }
.blog-meta svg { width: 15px; height: 15px; }
.blog-readmore { margin-left: auto; font-weight: 700; color: var(--blue); }
.blog-readmore::after { content: " →"; }
.blog-empty { padding: var(--s-6); text-align: center; color: var(--ink-400); border: 1px dashed var(--border); border-radius: var(--radius); display: none; }
/* sidebar */
.blog-sidebar { display: grid; gap: var(--s-5); position: sticky; top: 100px; }
@media (max-width: 980px){ .blog-sidebar { position: static; } }
.widget { background: #fff; border: 1px solid var(--border); border-radius: var(--radius); padding: var(--s-5); box-shadow: var(--shadow); }
.widget h3 { font-size: 1rem; margin: 0 0 var(--s-4); }
.blog-search { display: flex; align-items: center; gap: .5rem; border: 1px solid var(--border); border-radius: 10px; padding: .15rem .15rem .15rem .7rem; transition: .15s ease; }
.blog-search:focus-within { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(21,81,140,.15); }
.blog-search svg { width: 18px; height: 18px; color: var(--ink-400); flex: 0 0 18px; }
.blog-search input { border: 0; outline: 0; flex: 1; font: inherit; padding: .55rem .2rem; background: transparent; color: var(--ink); }
.cat-list { list-style: none; margin: 0; padding: 0; }
.cat-list li { margin: 0; }
.cat-list a { display: flex; justify-content: space-between; align-items: center; padding: .5rem 0; color: var(--ink); border-bottom: 1px solid var(--border); }
.cat-list li:last-child a { border-bottom: 0; }
.cat-list a:hover { color: var(--blue); text-decoration: none; }
.cat-count { background: var(--blue-050); color: var(--blue); font-size: .75rem; font-weight: 700; border-radius: 999px; padding: .05rem .5rem; }
.cat-btn { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: .5rem; padding: .5rem 0; background: none; border: 0; border-bottom: 1px solid var(--border); color: var(--ink); font: inherit; cursor: pointer; text-align: left; transition: .15s ease; }
.cat-list li:last-child .cat-btn { border-bottom: 0; }
.cat-btn:hover { color: var(--blue); }
.cat-btn.is-active { color: var(--blue); font-weight: 700; }
.cat-btn.is-active .cat-count { background: var(--blue); color: #fff; }
/* Paginering */
.pagination { display: flex; flex-wrap: wrap; gap: .4rem; justify-content: center; margin-top: var(--s-7); }
.pagination button { min-width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--border); border-radius: 10px; color: var(--navy); font: inherit; font-weight: 700; background: #fff; cursor: pointer; transition: .15s ease; padding: 0 .6rem; }
.pagination button:hover:not(:disabled) { border-color: var(--blue); color: var(--blue); }
.pagination button.is-current { background: var(--blue); color: #fff; border-color: var(--blue); }
.pagination button:disabled { opacity: .4; cursor: default; }
.pop-list { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--s-4); }
.pop-item { display: flex; gap: .7rem; align-items: center; }
.pop-item img { width: 56px; height: 40px; flex: 0 0 56px; object-fit: cover; border-radius: 8px; }
.pop-item a { color: var(--navy); font-weight: 600; font-size: .88rem; line-height: 1.3; }
.pop-item a:hover { color: var(--blue); text-decoration: none; }
.widget--cta { background: linear-gradient(135deg, var(--navy), var(--navy-850)); color: #fff; }
.widget--cta h3 { color: #fff; }
.widget--cta p { color: #c6d6ec; font-size: .9rem; margin-bottom: var(--s-4); }

/* ---------- 14. Breadcrumb & utilities ---------- */
.breadcrumb { font-size: .85rem; color: var(--ink-400); padding-block: var(--s-4); }
.breadcrumb a { color: var(--ink-400); }
.prose { max-width: 760px; }
.prose h2 { margin-top: var(--s-7); }
.prose ul li::marker { color: var(--teal-500); }
.figure-diagram { margin: var(--s-6) 0; padding: var(--s-5); background: var(--soft-blue); border: 1px solid var(--border); border-radius: var(--radius); }
.figure-diagram img { width: 100%; height: auto; display: block; }
.figure-diagram figcaption { margin-top: var(--s-3); font-size: .9rem; color: var(--ink-600); text-align: center; }
.prose table { width: 100%; border-collapse: collapse; margin: var(--s-5) 0; font-size: .95rem; }
.prose th, .prose td { text-align: left; padding: .6rem .7rem; border-bottom: 1px solid var(--border); }
.prose thead th { border-bottom: 2px solid var(--border); color: var(--navy); }
.skip-link { position: absolute; left: -999px; top: 0; background: var(--navy); color: #fff; padding: .6rem 1rem; z-index: 100; }
.skip-link:focus { left: 0; }
.related-cards a.card h3 { color: var(--navy); }
.text-center { text-align: center; }
.mt-0 { margin-top: 0; }
.section--flush-top { padding-top: 0; }
.section--tight-top { padding-top: var(--s-6); }

/* ---------- Contact: gestylede info + formulier ---------- */
.contact-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: var(--s-6); align-items: start; }
@media (max-width: 980px){ .contact-grid { grid-template-columns: 1fr; } }
.contact-card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--s-6); box-shadow: var(--shadow); }
.contact-card h2 { margin-top: 0; font-size: 1.4rem; }
.contact-info-row { display: flex; gap: .85rem; align-items: flex-start; margin-bottom: var(--s-4); }
.contact-info-row:last-child { margin-bottom: 0; }
.contact-info-row .ci { width: 44px; height: 44px; flex: 0 0 44px; border-radius: 12px; background: var(--blue-050); color: var(--blue); display: grid; place-items: center; }
.contact-info-row .ci svg { width: 20px; height: 20px; }
.contact-info-row strong { display: block; color: var(--navy); font-size: .95rem; }
.contact-info-row a { color: var(--ink); font-weight: 600; }
/* Contact: Google Maps locatie */
.contact-map-section { padding-top: 0; }
.contact-map-title { font-size: 1.4rem; margin-bottom: .35rem; }
.contact-map-sub { color: var(--ink-600); margin-bottom: var(--s-4); }
.contact-map { border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow); }
.contact-map iframe { display: block; width: 100%; height: 420px; border: 0; }
@media (max-width: 600px){ .contact-map iframe { height: 320px; } }
.contact-map-link { margin-top: var(--s-4); font-weight: 600; }
.form { display: grid; gap: var(--s-4); }
.form label { display: block; font-weight: 600; color: var(--navy); margin-bottom: .35rem; font-size: .95rem; }
.form input, .form select, .form textarea { width: 100%; padding: .8rem .9rem; border: 1px solid var(--border); border-radius: var(--radius-sm); font: inherit; color: var(--ink); background: #fff; transition: .15s ease; }
.form input:focus, .form select:focus, .form textarea:focus { border-color: var(--blue); outline: none; box-shadow: 0 0 0 3px rgba(21,81,140,.15); }
.form .btn { width: 100%; }
/* Contact: bredere aanvraag (categorie-pills, services, 2-koloms formulier) */
.request-tabs { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: var(--s-5); }
.request-tabs button { font: inherit; font-weight: 700; font-size: .9rem; padding: .55rem 1rem; border-radius: 999px; border: 1px solid var(--border); background: #fff; color: var(--navy); cursor: pointer; transition: .15s ease; }
.request-tabs button:hover { border-color: var(--blue); color: var(--blue); }
.request-tabs button.is-active { background: var(--blue); border-color: var(--blue); color: #fff; }
.form-intro { color: var(--ink-600); margin-bottom: var(--s-5); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-4); }
.form-grid label { display: grid; gap: .4rem; color: var(--navy); font-weight: 700; font-size: .9rem; }
.form-grid .full { grid-column: 1 / -1; }
.form-grid input, .form-grid select, .form-grid textarea { width: 100%; border: 1px solid var(--border); border-radius: 10px; padding: .8rem .9rem; font: inherit; font-weight: 400; color: var(--ink); background: #fff; transition: .15s ease; }
.form-grid textarea { resize: vertical; min-height: 140px; }
.form-grid input:focus, .form-grid select:focus, .form-grid textarea:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(21,81,140,.15); }
.submit-button { width: 100%; margin-top: var(--s-5); }
.form-note { margin: .8rem 0 0; color: var(--ink-400); font-size: .85rem; text-align: center; }
.form-note--tech { margin-top: var(--s-4); font-size: .78rem; }
.form-error { margin: 0 0 var(--s-4); padding: 12px 16px; border-radius: 10px; background: #FDECEC; border: 1px solid #F5C2C2; color: #9B1C1C; font-size: .92rem; }
.thanks-box { max-width: 640px; margin: 0 auto; background: #fff; border: 1px solid var(--border); border-radius: 18px; padding: var(--s-7) var(--s-6); text-align: center; box-shadow: 0 10px 30px rgba(11,29,56,.06); }
.thanks-check { width: 64px; height: 64px; margin: 0 auto var(--s-4); border-radius: 50%; background: var(--green, #10B981); color: #fff; font-size: 34px; line-height: 64px; }
.thanks-box h2 { margin: 0 0 var(--s-4); }
.thanks-steps { display: inline-block; text-align: left; margin: 0 auto var(--s-5); padding-left: 1.2em; color: var(--ink-600); line-height: 1.7; }
.thanks-box .btn { margin-top: var(--s-2); }
.contact-services { margin-top: var(--s-6); padding-top: var(--s-5); border-top: 1px solid var(--border); }
.contact-services h3 { font-size: 1.05rem; margin: 0 0 var(--s-3); }
.contact-services ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .5rem; }
.contact-services li { color: var(--ink-600); position: relative; padding-left: 1.5rem; margin: 0; }
.contact-services li::before { content: "✓"; position: absolute; left: 0; color: var(--teal-500); font-weight: 800; }
@media (max-width: 640px){ .form-grid { grid-template-columns: 1fr; } }

/* ---------- 16. Topbar (utility bar boven de header) ---------- */
.topbar { background: var(--navy-950); color: rgba(255,255,255,.85); font-size: .85rem; border-bottom: 1px solid rgba(255,255,255,.08); }
.topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; min-height: 40px; }
.topbar__contact { display: flex; flex-wrap: wrap; align-items: center; gap: 8px 24px; list-style: none; margin: 0; padding: 0; }
.topbar__contact li { margin: 0; }
.topbar__contact a, .topbar__contact span { display: inline-flex; align-items: center; gap: .45rem; color: rgba(255,255,255,.85); font-weight: 500; }
.topbar__contact a:hover { color: #fff; text-decoration: none; }
.topbar__contact svg { width: 15px; height: 15px; flex: 0 0 15px; color: var(--cyan-400); }
.lang { position: relative; }
.lang > summary { list-style: none; cursor: pointer; display: inline-flex; align-items: center; gap: .35rem; color: rgba(255,255,255,.85); font-weight: 600; padding: 4px 8px; border-radius: 8px; }
.lang > summary::-webkit-details-marker { display: none; }
.lang > summary::after { content: "▾"; font-size: .8em; }
.lang > summary:hover { color: #fff; background: rgba(255,255,255,.08); }
.lang__menu { position: absolute; right: 0; top: calc(100% + 6px); background: #fff; color: var(--ink); border: 1px solid var(--border); border-radius: var(--radius-sm); box-shadow: var(--shadow); min-width: 190px; padding: 6px; z-index: 70; display: grid; gap: 2px; }
.lang__menu span, .lang__menu a { display: block; padding: 8px 10px; border-radius: 8px; font-size: .9rem; }
.lang__menu a { color: var(--ink); font-weight: 600; }
.lang__menu a:hover { background: var(--blue-050); color: var(--blue); text-decoration: none; }
.lang__current { background: var(--blue-050); color: var(--blue); font-weight: 700; }
.lang__soon { color: var(--ink-400); }
@media (max-width: 768px){ .topbar { display: none; } }

/* ---------- 17. Contact hero (2-koloms met trust-panel) ---------- */
.hero--split .hero__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: var(--s-8); align-items: center; }
.hero__main h1 { margin-top: .4rem; }
.hero__panel { background: #fff; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: 26px; }
.trust-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; list-style: none; margin: 0; padding: 0; }
.trust-grid li { display: flex; gap: 12px; align-items: flex-start; margin: 0; }
.trust-grid .trust-ic { width: 42px; height: 42px; flex: 0 0 42px; border-radius: 12px; display: grid; place-items: center; }
.trust-grid .trust-ic svg { width: 20px; height: 20px; }
.trust-grid strong { display: block; color: var(--navy); font-size: .98rem; line-height: 1.2; }
.trust-grid span { display: block; color: var(--ink-600); font-size: .88rem; margin-top: 3px; }
.trust-ic--blue { background: var(--blue-050); color: var(--blue); }
.trust-ic--teal { background: #E3F7F0; color: var(--green-600); }
.trust-ic--cyan { background: #E2F7FB; color: #0E8FA8; }
.trust-ic--amber { background: #FEF3E2; color: #B5760A; }
@media (max-width: 900px){ .hero--split .hero__grid { grid-template-columns: 1fr; gap: var(--s-6); } }
@media (max-width: 460px){ .trust-grid { grid-template-columns: 1fr; } }

/* ---------- 18. Locatie-sectie (info-card + kaart) ---------- */
.location-section { padding-top: var(--s-7); }
.location-title { font-size: 1.5rem; margin-bottom: .3rem; }
.location-sub { color: var(--ink-600); margin-bottom: var(--s-6); }
.location-grid { display: grid; grid-template-columns: .8fr 1.4fr; gap: 28px; align-items: stretch; }
.location-info { display: grid; gap: 16px; align-content: start; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 26px; }
.info-box { display: flex; gap: 14px; align-items: flex-start; }
.info-box .info-ic { width: 44px; height: 44px; flex: 0 0 44px; border-radius: 12px; background: var(--blue-050); color: var(--blue); display: grid; place-items: center; }
.info-box .info-ic svg { width: 20px; height: 20px; }
.info-box strong { display: block; color: var(--navy); font-size: 1rem; }
.info-box span { display: block; color: var(--ink-600); font-size: .9rem; margin-top: 2px; }
.location-map { display: flex; flex-direction: column; }
.location-map .contact-map { flex: 1; }
.location-map .contact-map iframe { height: 100%; min-height: 360px; }
@media (max-width: 900px){ .location-grid { grid-template-columns: 1fr; } .location-map .contact-map iframe { min-height: 320px; } }

/* ---------- 15. Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}
