/* ==========================================================================
   mijn-woz-waarde.nl — design system
   Eén bron: tokens.css + design-system.md. Mobiel-eerst, WCAG 2.2 AA.
   ========================================================================== */

/* ---- Fonts (zelf gehost, font-display: swap) ---- */
@font-face { font-family:"Inter"; font-style:normal; font-weight:400; font-display:swap;
  src:url("../fonts/inter-latin-400.woff2") format("woff2"); }
@font-face { font-family:"Inter"; font-style:normal; font-weight:500; font-display:swap;
  src:url("../fonts/inter-latin-500.woff2") format("woff2"); }
@font-face { font-family:"Inter"; font-style:normal; font-weight:600; font-display:swap;
  src:url("../fonts/inter-latin-600.woff2") format("woff2"); }
@font-face { font-family:"Inter"; font-style:normal; font-weight:700; font-display:swap;
  src:url("../fonts/inter-latin-700.woff2") format("woff2"); }
@font-face { font-family:"JetBrains Mono"; font-style:normal; font-weight:400; font-display:swap;
  src:url("../fonts/jetbrains-mono-latin-400.woff2") format("woff2"); }

/* ---- Tokens ---- */
:root {
  --c-primary:#1B4965; --c-primary-hover:#143A52; --c-secondary:#2C6E9B; --c-accent:#0891B2;
  --c-ink:#0F172A; --c-body:#334155; --c-muted:#64748B;
  --c-bg:#FBFAF7; --c-surface:#FFFFFF; --c-surface-2:#F8FAFC; --c-surface-3:#F1F5F9;
  --c-border:#D7DEE7; --c-border-strong:#B8C4D0;
  --c-success:#15803D; --c-success-bg:#ECFDF3; --c-warning:#B45309; --c-warning-bg:#FEF6EC;
  --c-danger:#DC2626; --c-danger-bg:#FEF2F2; --c-info-bg:#EEF4F9;
  --font-sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --fs-display:48px; --fs-h1:36px; --fs-h2:28px; --fs-h3:22px; --fs-h4:18px;
  --fs-body-lg:19px; --fs-body:17px; --fs-small:14px;
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:24px;
  --space-6:32px; --space-7:48px; --space-8:64px; --space-9:96px;
  --container-max:1120px; --article-max:700px; --gutter:24px; --gutter-mobile:16px;
  --radius-sm:8px; --radius-md:12px; --radius-lg:16px; --radius-full:999px;
  --border:1px solid var(--c-border);
  --shadow-sm:0 1px 2px rgba(15,23,42,.06); --shadow-md:0 4px 16px rgba(15,23,42,.08);
  --shadow-lg:0 12px 32px rgba(15,23,42,.12);
  --ease:cubic-bezier(0.22,1,0.36,1); --dur:180ms;
  --focus-ring:0 0 0 2px var(--c-bg),0 0 0 4px var(--c-secondary);
}

/* ---- Reset / base ---- */
*,*::before,*::after { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){ html{scroll-behavior:auto;} *{animation-duration:.001ms!important;transition-duration:.001ms!important;} }
body { margin:0; font-family:var(--font-sans); font-size:var(--fs-body); line-height:1.6;
  color:var(--c-body); background:var(--c-bg); -webkit-font-smoothing:antialiased; }
img { max-width:100%; height:auto; display:block; }
h1,h2,h3,h4 { color:var(--c-ink); line-height:1.2; margin:0 0 .5em; font-weight:700; }
h1 { font-size:var(--fs-h1); line-height:1.15; letter-spacing:-.01em; }
h2 { font-size:var(--fs-h2); line-height:1.25; margin-top:1.6em; }
h3 { font-size:var(--fs-h3); line-height:1.3; font-weight:600; margin-top:1.4em; }
h4 { font-size:var(--fs-h4); font-weight:600; }
p { margin:0 0 1em; }
a { color:var(--c-primary); text-decoration:underline; text-underline-offset:2px;
  text-decoration-color:rgba(27,73,101,.35); transition:color var(--dur) var(--ease); }
a:hover { color:var(--c-primary-hover); text-decoration-color:currentColor; }
strong { font-weight:600; color:var(--c-ink); }
ul,ol { margin:0 0 1em; padding-left:1.4em; }
li { margin:.3em 0; }
:focus-visible { outline:none; box-shadow:var(--focus-ring); border-radius:var(--radius-sm); }
.tnum { font-variant-numeric:tabular-nums lining-nums; }
.skip-link { position:absolute; left:-9999px; top:0; background:var(--c-primary); color:#fff;
  padding:10px 16px; border-radius:0 0 var(--radius-sm) 0; z-index:100; }
.skip-link:focus { left:0; }
.visually-hidden { position:absolute!important; width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap; }

/* ---- Layout ---- */
.wrap { max-width:var(--container-max); margin:0 auto; padding:0 var(--gutter); }
.wrap-narrow { max-width:820px; margin:0 auto; padding:0 var(--gutter); }
.article { max-width:var(--article-max); }
.sec { padding-top:var(--space-8); }
main { display:block; }
.page-body { padding-bottom:var(--space-9); }
.cols-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);}
.cols-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);}
.cols-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);}
.toc-layout{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:var(--space-7);align-items:start;}
.toc-layout .article{max-width:none;}

/* ---- Buttons ---- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--font-sans); font-weight:600; font-size:16px; line-height:1; cursor:pointer;
  border-radius:var(--radius-md); border:1px solid transparent; padding:0 20px; height:44px;
  text-decoration:none; transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease); white-space:nowrap; }
.btn-primary { background:var(--c-primary); color:#fff; }
.btn-primary:hover { background:var(--c-primary-hover); color:#fff; }
.btn-secondary { background:var(--c-surface); border-color:var(--c-border-strong); color:var(--c-primary); }
.btn-secondary:hover { background:var(--c-surface-3); color:var(--c-primary); }
.btn-tertiary { background:none; color:var(--c-primary); padding:0 6px; height:auto; }
.btn-tertiary:hover { text-decoration:underline; }
.btn-sm { height:36px; font-size:14px; padding:0 14px; }
.btn-lg { height:52px; font-size:18px; padding:0 28px; }
.btn[disabled],.btn[aria-disabled="true"] { opacity:.5; pointer-events:none; }
.btn-block { width:100%; }

/* ---- Cards ---- */
.card { background:var(--c-surface); border:1px solid var(--c-border); border-radius:var(--radius-md);
  padding:var(--space-5); box-shadow:var(--shadow-sm); }
a.card,.card-link { display:block; text-decoration:none; color:inherit;
  transition:box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease); }
a.card:hover,.card-link:hover { box-shadow:var(--shadow-md); border-color:var(--c-border-strong); }
.card h3 { margin-top:0; font-size:var(--fs-h4); color:var(--c-ink); }
.card .card-desc { color:var(--c-body); font-size:15px; margin:0; }
.card-icon { width:40px;height:40px;border-radius:var(--radius-sm); display:flex;align-items:center;justify-content:center;
  background:var(--c-info-bg); color:var(--c-primary); margin-bottom:var(--space-3); }
.card-icon svg{width:22px;height:22px;}
.card-arrow{color:var(--c-primary);font-weight:600;font-size:14px;margin-top:var(--space-3);display:inline-flex;gap:4px;align-items:center;}

/* ---- Data cards (gemeente) ---- */
.datacards { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-4); }
.datacard { background:var(--c-surface); border:1px solid var(--c-border); border-radius:var(--radius-md);
  padding:var(--space-4) var(--space-5); box-shadow:var(--shadow-sm); }
.datacard .dc-label { font-size:13px; letter-spacing:.04em; text-transform:uppercase; color:var(--c-muted); margin:0 0 6px; }
.datacard .dc-value { font-size:30px; font-weight:700; color:var(--c-ink); line-height:1.1; }
.datacard .dc-trend { font-size:14px; margin-top:4px; color:var(--c-muted); }
.dc-trend.up{color:var(--c-success);} .dc-trend.down{color:var(--c-warning);}

/* ---- Callouts ---- */
.callout { border-radius:var(--radius-md); padding:var(--space-4) var(--space-5);
  border-left:4px solid var(--c-primary); background:var(--c-info-bg); margin:var(--space-5) 0; }
.callout .callout-title { font-weight:700; color:var(--c-ink); margin:0 0 6px; }
.callout p:last-child,.callout ul:last-child { margin-bottom:0; }
.callout-info { background:var(--c-info-bg); border-color:var(--c-primary); }
.callout-warning { background:var(--c-warning-bg); border-color:var(--c-warning); }
.callout-warning .callout-title{color:var(--c-warning);}
.callout-success { background:var(--c-success-bg); border-color:var(--c-success); }
.callout-success .callout-title{color:var(--c-success);}
.callout-summary { background:var(--c-info-bg); border-color:var(--c-primary); }
.callout-summary ul { margin:0; padding-left:1.2em; }
.callout-summary li { margin:.35em 0; }

/* ---- Tables ---- */
.table-scroll { overflow-x:auto; margin:var(--space-5) 0; -webkit-overflow-scrolling:touch; }
table.data { width:100%; border-collapse:collapse; font-size:15.5px; background:var(--c-surface);
  border:1px solid var(--c-border); border-radius:var(--radius-md); overflow:hidden; }
table.data th,table.data td { padding:10px 14px; text-align:left; border-bottom:1px solid var(--c-border);
  font-variant-numeric:tabular-nums lining-nums; }
table.data thead th { background:var(--c-primary); color:#fff; font-weight:600; }
table.data tbody tr:nth-child(even){ background:var(--c-surface-2); }
table.data td.num,table.data th.num{ text-align:right; }

/* ---- Accordion / FAQ ---- */
.accordion { border:1px solid var(--c-border); border-radius:var(--radius-md); overflow:hidden; background:var(--c-surface); }
.accordion-item + .accordion-item { border-top:1px solid var(--c-border); }
.accordion-item summary,.accordion-trigger { list-style:none; cursor:pointer; display:flex;
  align-items:center; justify-content:space-between; gap:16px; padding:18px 20px; width:100%;
  font:600 18px/1.4 var(--font-sans); color:var(--c-ink); background:none; border:none; text-align:left; }
.accordion-item summary::-webkit-details-marker{ display:none; }
.accordion-item .chev{ color:var(--c-muted); flex-shrink:0; transition:transform var(--dur) var(--ease); }
.accordion-item[open] .chev{ transform:rotate(180deg); }
.accordion-body { padding:0 20px 20px; color:var(--c-body); max-width:660px; }
.accordion-body p:last-child{ margin-bottom:0; }

/* ---- Badges ---- */
.badge { display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:500;
  padding:4px 10px; border-radius:var(--radius-full); background:var(--c-surface-3); color:var(--c-body); }
.badge-success { background:var(--c-success-bg); color:var(--c-success); }
.badge-dot::before{ content:""; width:7px;height:7px;border-radius:50%;background:currentColor;display:inline-block; }

/* ---- Breadcrumbs ---- */
.breadcrumbs { display:flex; flex-wrap:wrap; align-items:center; gap:8px; font-size:14px;
  color:var(--c-muted); margin-bottom:18px; padding:0; list-style:none; }
.breadcrumbs a{ color:var(--c-muted); text-decoration:none; }
.breadcrumbs a:hover{ text-decoration:underline; }
.breadcrumbs .sep{ color:var(--c-muted); }
.breadcrumbs [aria-current]{ color:var(--c-body); }

/* ---- Byline ---- */
.byline { font-size:14.5px; color:var(--c-muted); margin:0 0 var(--space-5);
  padding:12px 16px; background:var(--c-surface-2); border:1px solid var(--c-border); border-radius:var(--radius-sm); }
.byline strong{ color:var(--c-body); font-weight:600; }
.byline .byline-check{ display:block; margin-top:4px; }

/* ---- Sources / updated ---- */
.sources { padding-top:var(--space-5); margin-top:var(--space-6); border-top:1px solid var(--c-border);
  font-size:14.5px; color:var(--c-muted); }
.sources h2{ font-size:var(--fs-h4); color:var(--c-ink); margin-bottom:8px; }
.sources ul{ list-style:none; padding:0; margin:0 0 8px; }
.sources li{ margin:.25em 0; }
.updated { font-size:14px; color:var(--c-muted); margin-top:8px; }

/* ---- Visuals (SVG-figuren) ---- */
.visual { margin:var(--space-6) 0; }
.visual-svg { background:var(--c-surface); border:1px solid var(--c-border); border-radius:var(--radius-md);
  padding:var(--space-4); }
.visual-svg svg { width:100%; height:auto; display:block; }
.visual figcaption { font-size:14px; color:var(--c-muted); margin-top:8px; }

/* ---- Kennisbank-filters ---- */
.kb-filters { display:flex; flex-wrap:wrap; gap:8px; margin:8px 0 var(--space-5); }
.kb-filters .badge { cursor:pointer; border:1px solid var(--c-border); background:var(--c-surface); }
.kb-filters .badge[aria-pressed="true"] { background:var(--c-primary); color:#fff; border-color:var(--c-primary); }

/* ---- Lees ook ---- */
.lees-ook { background:var(--c-surface-2); border:1px solid var(--c-border); border-radius:var(--radius-md);
  padding:var(--space-5); margin:var(--space-6) 0; }
.lees-ook h2{ font-size:var(--fs-h4); margin:0 0 10px; }
.lees-ook ul{ margin:0; padding-left:1.2em; }

/* ---- Header / nav ---- */
.site-header { position:sticky; top:0; z-index:50; height:64px; background:var(--c-surface);
  border-bottom:1px solid var(--c-border); box-shadow:var(--shadow-sm); }
.site-header .wrap{ max-width:1280px; height:100%; display:flex; align-items:center; gap:var(--space-4); }
.brand{ display:flex; align-items:center; flex-shrink:0; text-decoration:none; }
.brand img{ height:28px; }
.nav-desktop{ display:flex; gap:0; margin-left:2px; flex:1; min-width:0; }
.nav-item{ position:relative; }
.nav-item > a{ display:inline-flex; align-items:center; gap:3px; padding:8px 10px; border-radius:var(--radius-sm);
  text-decoration:none; font-size:14.5px; font-weight:500; color:var(--c-body); white-space:nowrap; }
.nav-item > a:hover,.nav-item.is-active > a{ color:var(--c-primary); background:var(--c-surface-3); }
.nav-dropdown{ position:absolute; top:100%; left:0; min-width:240px; background:var(--c-surface);
  border:1px solid var(--c-border); border-radius:var(--radius-md); box-shadow:var(--shadow-md);
  padding:8px; display:none; flex-direction:column; gap:2px; }
.nav-item:hover .nav-dropdown,.nav-item:focus-within .nav-dropdown{ display:flex; }
.nav-dropdown a{ padding:9px 12px; border-radius:var(--radius-sm); text-decoration:none; font-size:14.5px;
  color:var(--c-body); }
.nav-dropdown a:hover{ background:var(--c-surface-3); color:var(--c-primary); }
.nav-cta{ flex-shrink:0; }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; color:var(--c-ink); padding:6px; }
.mobile-menu{ position:fixed; inset:64px 0 0; z-index:40; background:var(--c-surface); padding:16px;
  display:none; flex-direction:column; gap:2px; overflow-y:auto; }
.mobile-menu.open{ display:flex; }
.mobile-menu a{ padding:14px 12px; border-radius:var(--radius-sm); text-decoration:none; font-size:18px;
  font-weight:500; color:var(--c-ink); }
.mobile-menu a:active{ background:var(--c-surface-3); }
.mobile-menu .mm-group{ font-size:13px; text-transform:uppercase; letter-spacing:.04em; color:var(--c-muted);
  padding:14px 12px 4px; }

/* ---- Hero ---- */
.hero{ background:linear-gradient(180deg,var(--c-info-bg),var(--c-bg)); padding:var(--space-8) 0 var(--space-7); }
.hero h1{ font-size:var(--fs-display); line-height:1.1; letter-spacing:-.02em; margin:0 0 var(--space-4); max-width:720px; }
.hero .hero-sub{ font-size:var(--fs-body-lg); color:var(--c-muted); max-width:620px; margin:0 0 var(--space-6); }

/* ---- Searchbar (WOZ) ---- */
.wozbar{ background:var(--c-surface); border:1px solid var(--c-border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md); padding:var(--space-4); max-width:620px; }
.wozbar form{ display:flex; gap:var(--space-3); }
.wozbar .field{ flex:1; position:relative; }
.wozbar input{ width:100%; height:52px; padding:0 16px; border:1px solid var(--c-border); border-radius:var(--radius-md);
  font-size:16px; font-family:var(--font-sans); color:var(--c-ink); background:var(--c-surface); }
.wozbar input:focus{ outline:none; border-color:var(--c-secondary); box-shadow:0 0 0 3px rgba(44,110,155,.15); }
.wozbar .btn{ height:52px; }
.wozbar-meta{ display:flex; flex-wrap:wrap; gap:12px; align-items:center; margin-top:12px; font-size:13.5px; color:var(--c-muted); }
.woz-suggest{ position:absolute; top:calc(100% + 6px); left:0; right:0; background:var(--c-surface);
  border:1px solid var(--c-border); border-radius:var(--radius-md); box-shadow:var(--shadow-md); z-index:20;
  max-height:280px; overflow-y:auto; display:none; }
.woz-suggest.open{ display:block; }
.woz-suggest button{ display:block; width:100%; text-align:left; padding:11px 14px; background:none; border:none;
  border-bottom:1px solid var(--c-border); cursor:pointer; font-size:15px; color:var(--c-body); font-family:var(--font-sans); }
.woz-suggest button:hover,.woz-suggest button[aria-selected="true"]{ background:var(--c-surface-3); }
.skeleton{ background:linear-gradient(90deg,var(--c-surface-3) 25%,var(--c-surface-2) 50%,var(--c-surface-3) 75%);
  background-size:200% 100%; animation:sk 1.2s infinite; border-radius:var(--radius-sm); }
@keyframes sk{ to{ background-position:-200% 0; } }
@media (prefers-reduced-motion:reduce){ .skeleton{ animation:none; } }

/* ---- Forms ---- */
.field-label{ display:block; font-size:15px; font-weight:600; color:var(--c-ink); margin-bottom:6px; }
.field-help{ font-size:13.5px; color:var(--c-muted); margin-top:6px; }
.field-input,select.field-input{ width:100%; height:46px; padding:0 14px; border:1px solid var(--c-border);
  border-radius:var(--radius-sm); font-size:16px; font-family:var(--font-sans); color:var(--c-ink); background:var(--c-surface); }
.field-input:focus{ outline:none; border-color:var(--c-secondary); box-shadow:0 0 0 3px rgba(44,110,155,.15); }
.field-input.error{ border-color:var(--c-danger); }
.field-error{ font-size:13.5px; color:var(--c-danger); margin-top:6px; }
.form-row{ margin-bottom:var(--space-4); }

/* ---- Tool result panel ---- */
.tool{ background:var(--c-surface); border:1px solid var(--c-border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm); padding:var(--space-6); }
.tool-result{ margin-top:var(--space-5); padding:var(--space-5); border-radius:var(--radius-md);
  background:var(--c-surface-2); border:1px solid var(--c-border); }
.tool-result .result-value{ font-size:32px; font-weight:700; color:var(--c-ink); line-height:1.1; }
.tool-result .result-explain{ margin-top:8px; color:var(--c-body); }
.tool-disclaimer{ font-size:13.5px; color:var(--c-muted); margin-top:var(--space-3); }
.is-hidden{ display:none!important; }

/* ---- Sticky CTA ---- */
.sticky-cta{ position:sticky; bottom:16px; z-index:25; margin:var(--space-6) auto 0; max-width:760px;
  background:var(--c-surface); border:1px solid var(--c-border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); padding:14px 16px; display:flex; align-items:center; gap:16px; }
.sticky-cta .cta-label{ font-weight:600; color:var(--c-ink); flex-shrink:0; }
.sticky-cta .cta-field{ flex:1; }
.sticky-cta input{ width:100%; height:40px; padding:0 12px; border-radius:var(--radius-sm);
  border:1px solid var(--c-border); font-size:15px; font-family:var(--font-sans); }
.sticky-cta .cta-close{ background:none; border:none; cursor:pointer; color:var(--c-muted); font-size:20px; line-height:1; padding:4px; }

/* ---- TOC ---- */
.toc{ position:sticky; top:80px; font-size:14.5px; }
.toc h2{ font-size:13px; text-transform:uppercase; letter-spacing:.04em; color:var(--c-muted); margin:0 0 10px; }
.toc ul{ list-style:none; margin:0; padding:0; border-left:2px solid var(--c-border); }
.toc li a{ display:block; padding:5px 0 5px 14px; margin-left:-2px; border-left:2px solid transparent;
  color:var(--c-muted); text-decoration:none; }
.toc li a:hover{ color:var(--c-primary); }
.toc li a.active{ color:var(--c-primary); border-left-color:var(--c-primary); font-weight:500; }
.toc-mobile{ display:none; margin-bottom:var(--space-5); }
.toc-mobile summary{ cursor:pointer; font-weight:600; color:var(--c-ink); padding:12px 14px;
  background:var(--c-surface); border:1px solid var(--c-border); border-radius:var(--radius-sm); }

/* ---- Hub ---- */
.hub-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-4); }
.prov-card{ display:block; text-decoration:none; color:inherit; }
.gem-search{ position:relative; max-width:560px; }
.gem-results{ margin-top:var(--space-4); }
.sortable th{ cursor:pointer; user-select:none; }
.sortable th[aria-sort]{ text-decoration:underline; }

/* ---- Blog ---- */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-5); }
.featured-grid{ display:grid; grid-template-columns:1.3fr 1fr; gap:var(--space-6); align-items:center; }
.article-card .ac-img{ aspect-ratio:16/9; background:var(--c-surface-3); border-radius:var(--radius-md); margin-bottom:var(--space-3);
  display:flex; align-items:center; justify-content:center; color:var(--c-muted); }
.article-card .ac-label{ font-size:12px; }
.article-meta{ font-size:14px; color:var(--c-muted); display:flex; gap:12px; flex-wrap:wrap; }

/* ---- Footer ---- */
.site-footer{ background:var(--c-primary); color:#fff; margin-top:var(--space-9); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:var(--space-6);
  padding:56px var(--gutter) 32px; max-width:var(--container-max); margin:0 auto; }
.footer-grid img{ height:28px; margin-bottom:14px; }
.footer-grid h2{ color:#fff; font-size:14px; font-weight:600; letter-spacing:.03em; text-transform:uppercase;
  margin:0 0 14px; opacity:.8; }
.footer-grid ul{ list-style:none; margin:0; padding:0; display:grid; gap:9px; }
.footer-grid a{ color:rgba(255,255,255,.82); text-decoration:none; font-size:14.5px; }
.footer-grid a:hover{ color:#fff; text-decoration:underline; }
.footer-tagline{ color:rgba(255,255,255,.78); font-size:14.5px; margin:0; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.14); }
.footer-bottom .wrap{ display:flex; flex-wrap:wrap; gap:16px; justify-content:space-between;
  padding:18px var(--gutter); font-size:13.5px; color:rgba(255,255,255,.7); }

/* ---- Cookiebanner ---- */
.cookiebar{ position:fixed; bottom:16px; left:16px; right:16px; z-index:60; max-width:560px; margin:0 auto;
  background:var(--c-surface); border:1px solid var(--c-border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); padding:var(--space-5); display:none; }
.cookiebar.show{ display:block; }
.cookiebar p{ font-size:14.5px; margin:0 0 var(--space-4); }
.cookiebar .cookie-actions{ display:flex; gap:var(--space-3); flex-wrap:wrap; }

/* ---- Pills row (waarvoor wordt WOZ gebruikt) ---- */
.usecards{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-4); }
.usecard{ text-align:left; }
.usecard .card-icon{ background:var(--c-surface-3); }

/* ---- Responsive ---- */
@media (max-width:1024px){
  .toc-layout{ grid-template-columns:1fr; gap:0; }
  .toc-aside{ display:none; }
  .toc-mobile{ display:block; }
  .cols-4{ grid-template-columns:repeat(2,1fr); }
  .datacards{ grid-template-columns:repeat(2,1fr); }
  .usecards{ grid-template-columns:repeat(2,1fr); }
  .hub-grid{ grid-template-columns:repeat(2,1fr); }
  .blog-grid{ grid-template-columns:repeat(2,1fr); }
  .featured-grid{ grid-template-columns:1fr; }
}
/* Toon de volledige balk pas als die past; daaronder het hamburgermenu. */
@media (max-width:1160px){
  .nav-desktop,.nav-cta{ display:none; }
  .nav-toggle{ display:inline-flex; }
}
@media (max-width:900px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:640px){
  :root{ --fs-display:32px; --fs-h1:28px; --fs-h2:24px; --fs-h3:20px; }
  .wrap,.wrap-narrow{ padding:0 var(--gutter-mobile); }
  .sec{ padding-top:var(--space-7); }
  .cols-4,.cols-3,.cols-2,.datacards,.usecards,.hub-grid,.blog-grid{ grid-template-columns:1fr; }
  .wozbar form{ flex-direction:column; }
  .wozbar .btn{ width:100%; }
  .sticky-cta{ flex-wrap:wrap; }
  .sticky-cta .cta-field{ flex-basis:100%; }
  .footer-grid{ grid-template-columns:1fr; }
  .hide-mobile{ display:none!important; }
}
