/* =============================================================================
   Metsens Design System — Gedeelde Stylesheet
   Versie: 2.0 | 2026-05-02
   Kleuren: Deep Navy #0B2447 + Energie Amber #F4840A
   Fonts: Plus Jakarta Sans (headings) · DM Sans (body)
   ============================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=DM+Sans:wght@400;500;600;700&display=swap');

/* ── Reset & base ─────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
img, svg { display: block; max-width: 100%; }
button { cursor: pointer; }
a { text-decoration: none; }

:root {
  /* Brand */
  --ms-primary:        #0B2447;
  --ms-primary-light:  #19376D;
  --ms-primary-deep:   #061633;
  --ms-accent:         #F4840A;
  --ms-accent-hover:   #D97208;
  --ms-accent-soft:    #FEF1E0;

  /* Surfaces */
  --ms-bg:             #F7F8FA;
  --ms-surface:        #FFFFFF;
  --ms-surface-muted:  #F1F3F7;
  --ms-border:         #E5E7EB;
  --ms-border-strong:  #CBD5E1;

  /* Tekst */
  --ms-text:           #1A1A2E;
  --ms-text-muted:     #6B7280;
  --ms-text-faint:     #9CA3AF;
  --ms-text-on-dark:   #FFFFFF;
  --ms-text-on-dark-muted: rgba(255,255,255,0.70);
  --ms-text-on-dark-faint: rgba(255,255,255,0.45);

  /* Semantisch */
  --ms-success:        #22C55E;
  --ms-success-soft:   #DCFCE7;
  --ms-warning:        #F59E0B;
  --ms-warning-soft:   #FEF3C7;
  --ms-danger:         #EF4444;
  --ms-danger-soft:    #FEE2E2;
  --ms-info:           #3B82F6;
  --ms-info-soft:      #DBEAFE;

  /* Urgentie */
  --ms-u-critical: #EF4444;
  --ms-u-high:     #F97316;
  --ms-u-medium:   #F59E0B;
  --ms-u-low:      #22C55E;

  /* Typografie */
  --ms-font-heading: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --ms-font-body:    'DM Sans', system-ui, -apple-system, sans-serif;
  --ms-font-mono:    ui-monospace, 'SF Mono', Consolas, monospace;

  /* Schaal — fluid met clamp() */
  --ms-fs-hero: clamp(2.4rem, 5vw + 0.8rem, 3.8rem);
  --ms-fs-h1:   clamp(1.9rem, 3vw + 0.8rem, 2.8rem);
  --ms-fs-h2:   clamp(1.45rem, 2vw + 0.8rem, 2.1rem);
  --ms-fs-h3:   1.45rem;
  --ms-fs-h4:   1.2rem;
  --ms-fs-lg:   1.1rem;
  --ms-fs-base: 1rem;
  --ms-fs-sm:   0.875rem;
  --ms-fs-xs:   0.75rem;

  --ms-lh-tight:   1.15;
  --ms-lh-snug:    1.35;
  --ms-lh-normal:  1.6;
  --ms-lh-relaxed: 1.72;

  /* Spacing */
  --ms-space-1:  4px;   --ms-space-2:  8px;
  --ms-space-3:  12px;  --ms-space-4:  16px;
  --ms-space-5:  20px;  --ms-space-6:  24px;
  --ms-space-8:  32px;  --ms-space-10: 40px;
  --ms-space-12: 48px;  --ms-space-16: 64px;
  --ms-space-20: 80px;

  /* Radii */
  --ms-radius-sm:   6px;
  --ms-radius-md:   8px;
  --ms-radius-card: 12px;
  --ms-radius-lg:   16px;
  --ms-radius-xl:   24px;
  --ms-radius-pill: 9999px;

  /* Schaduwen */
  --ms-shadow-card:       0 2px 16px rgba(11,36,71,0.08);
  --ms-shadow-hover:      0 6px 28px rgba(11,36,71,0.15);
  --ms-shadow-button:     0 4px 14px rgba(244,132,10,0.36);
  --ms-shadow-overlay:    0 24px 56px rgba(11,36,71,0.26);
  --ms-shadow-input:      inset 0 1px 2px rgba(11,36,71,0.04);

  /* Transities */
  --ms-ease:     cubic-bezier(0.4,0,0.2,1);
  --ms-ease-out: cubic-bezier(0,0,0.2,1);
  --ms-dur-fast: 150ms;
  --ms-dur-base: 220ms;
  --ms-dur-slow: 360ms;

  /* Layout */
  --ms-container: 1120px;
  --ms-nav-h:     64px;
}

/* ── Body ─────────────────────────────────────────────────────────────────── */
body {
  font-family: var(--ms-font-body);
  font-size: var(--ms-fs-base);
  line-height: var(--ms-lh-normal);
  color: var(--ms-text);
  background: var(--ms-bg);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── Typografie ───────────────────────────────────────────────────────────── */
.ms-hero { font-family: var(--ms-font-heading); font-weight: 800; font-size: var(--ms-fs-hero); line-height: var(--ms-lh-tight); letter-spacing: -0.025em; color: var(--ms-primary); }
.ms-h1   { font-family: var(--ms-font-heading); font-weight: 700; font-size: var(--ms-fs-h1);   line-height: var(--ms-lh-tight); letter-spacing: -0.018em; color: var(--ms-primary); }
.ms-h2   { font-family: var(--ms-font-heading); font-weight: 700; font-size: var(--ms-fs-h2);   line-height: var(--ms-lh-snug);  letter-spacing: -0.01em;  color: var(--ms-primary); }
.ms-h3   { font-family: var(--ms-font-heading); font-weight: 700; font-size: var(--ms-fs-h3);   line-height: var(--ms-lh-snug);  color: var(--ms-primary); }
.ms-h4   { font-family: var(--ms-font-heading); font-weight: 600; font-size: var(--ms-fs-h4);   line-height: var(--ms-lh-snug);  color: var(--ms-primary); }
.ms-eyebrow { font-family: var(--ms-font-heading); font-weight: 600; font-size: var(--ms-fs-xs); letter-spacing: 0.09em; text-transform: uppercase; color: var(--ms-accent); }
.ms-lead { font-family: var(--ms-font-body); font-size: var(--ms-fs-lg); line-height: var(--ms-lh-relaxed); color: var(--ms-text-muted); }
.ms-body { font-family: var(--ms-font-body); font-size: var(--ms-fs-base); line-height: var(--ms-lh-normal); color: var(--ms-text); }
.ms-body-sm { font-family: var(--ms-font-body); font-size: var(--ms-fs-sm); line-height: var(--ms-lh-normal); color: var(--ms-text-muted); }
.ms-micro { font-family: var(--ms-font-body); font-size: var(--ms-fs-xs); line-height: var(--ms-lh-normal); color: var(--ms-text-faint); }

.ms-on-dark       { color: var(--ms-text-on-dark); }
.ms-on-dark-muted { color: var(--ms-text-on-dark-muted); }
.ms-accent-text   { color: var(--ms-accent); }

/* ── Layout hulpklassen ───────────────────────────────────────────────────── */
.ms-container { max-width: var(--ms-container); margin: 0 auto; padding: 0 var(--ms-space-6); }
.ms-section   { padding: var(--ms-space-20) 0; }
.ms-section-sm{ padding: var(--ms-space-12) 0; }
.ms-text-center { text-align: center; }
.ms-sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }

/* ── Navigatie ────────────────────────────────────────────────────────────── */
.ms-nav {
  position: sticky; top: 0; z-index: 200;
  height: var(--ms-nav-h);
  background: rgba(11,36,71,0.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,0.09);
}
.ms-nav-inner {
  max-width: var(--ms-container); margin: 0 auto;
  padding: 0 var(--ms-space-6);
  height: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--ms-space-6);
}
.ms-nav-brand {
  display: flex; align-items: center; gap: var(--ms-space-3);
  text-decoration: none; flex-shrink: 0;
}
.ms-nav-logo {
  width: 36px; height: 36px;
  background: var(--ms-accent); border-radius: var(--ms-radius-md);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ms-nav-wordmark {
  font-family: var(--ms-font-heading); font-weight: 800; font-size: 1.15rem;
  color: #fff; letter-spacing: -0.01em; line-height: 1.2;
}
.ms-nav-sub {
  font-size: var(--ms-fs-xs); color: var(--ms-text-on-dark-faint);
  letter-spacing: 0.05em; text-transform: uppercase;
}
.ms-nav-links {
  display: flex; align-items: center; gap: var(--ms-space-5); list-style: none;
}
.ms-nav-links a {
  font-family: var(--ms-font-body); font-size: var(--ms-fs-sm); font-weight: 500;
  color: var(--ms-text-on-dark-muted); transition: color var(--ms-dur-fast);
}
.ms-nav-links a:hover { color: var(--ms-text-on-dark); }
.ms-nav-badge {
  font-family: var(--ms-font-heading); font-size: var(--ms-fs-xs); font-weight: 600;
  color: var(--ms-text-on-dark-muted); border: 1px solid rgba(255,255,255,0.18);
  padding: 4px 12px; border-radius: var(--ms-radius-pill);
}

/* ── Knoppen ──────────────────────────────────────────────────────────────── */
.ms-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--ms-space-2);
  font-family: var(--ms-font-heading); font-weight: 600;
  border-radius: var(--ms-radius-card); border: none;
  transition: all var(--ms-dur-base) var(--ms-ease);
  white-space: nowrap; cursor: pointer;
  text-decoration: none;
}
.ms-btn:disabled { opacity: 0.45; pointer-events: none; }

.ms-btn-primary {
  background: var(--ms-accent); color: #fff;
  font-size: var(--ms-fs-base); padding: 13px 26px;
  box-shadow: var(--ms-shadow-button);
}
.ms-btn-primary:hover { background: var(--ms-accent-hover); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(244,132,10,0.45); }
.ms-btn-primary:active { transform: translateY(0); }

.ms-btn-secondary {
  background: #fff; color: var(--ms-primary);
  font-size: var(--ms-fs-base); padding: 12px 24px;
  border: 2px solid var(--ms-primary);
}
.ms-btn-secondary:hover { background: var(--ms-surface-muted); }

.ms-btn-ghost {
  background: transparent; color: var(--ms-primary);
  font-size: var(--ms-fs-sm); padding: 8px 14px;
}
.ms-btn-ghost:hover { background: var(--ms-surface-muted); }

.ms-btn-lg { font-size: var(--ms-fs-lg); padding: 16px 34px; }
.ms-btn-sm { font-size: var(--ms-fs-sm); padding: 9px 18px; }
.ms-btn-full { width: 100%; }

/* ── Kaarten ──────────────────────────────────────────────────────────────── */
.ms-card {
  background: var(--ms-surface); border-radius: var(--ms-radius-card);
  box-shadow: var(--ms-shadow-card); border: 1px solid var(--ms-border);
  overflow: hidden; transition: box-shadow var(--ms-dur-base), transform var(--ms-dur-base);
}
.ms-card:hover { box-shadow: var(--ms-shadow-hover); transform: translateY(-3px); }
.ms-card-body { padding: var(--ms-space-6); }

/* ── Badges / tags ────────────────────────────────────────────────────────── */
.ms-badge {
  display: inline-flex; align-items: center; gap: var(--ms-space-2);
  font-family: var(--ms-font-heading); font-weight: 600; font-size: var(--ms-fs-xs);
  padding: 4px 10px; border-radius: var(--ms-radius-pill);
}
.ms-badge-live    { background: rgba(34,197,94,0.12); color: #15803d; }
.ms-badge-soon    { background: rgba(244,132,10,0.12); color: #c2610b; }
.ms-badge-info    { background: var(--ms-info-soft);    color: #1d4ed8; }
.ms-badge-critical{ background: var(--ms-danger-soft);  color: #b91c1c; }
.ms-badge-high    { background: rgba(249,115,22,0.12);  color: #c2410c; }
.ms-badge-medium  { background: var(--ms-warning-soft); color: #92400e; }
.ms-badge-low     { background: var(--ms-success-soft); color: #15803d; }

.ms-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.ms-dot-live     { background: var(--ms-success); animation: ms-pulse 1.6s infinite; }
.ms-dot-critical { background: var(--ms-u-critical); }
.ms-dot-high     { background: var(--ms-u-high); }
.ms-dot-medium   { background: var(--ms-u-medium); }
.ms-dot-low      { background: var(--ms-u-low); }

/* ── Formulier elementen ──────────────────────────────────────────────────── */
.ms-input {
  width: 100%; font-family: var(--ms-font-body); font-size: var(--ms-fs-base);
  padding: 11px 14px; border: 1.5px solid var(--ms-border);
  border-radius: var(--ms-radius-md); background: var(--ms-surface); color: var(--ms-text);
  transition: border-color var(--ms-dur-fast), box-shadow var(--ms-dur-fast);
  outline: none; box-shadow: var(--ms-shadow-input);
}
.ms-input:focus { border-color: var(--ms-accent); box-shadow: 0 0 0 3px rgba(244,132,10,0.16); }
.ms-input::placeholder { color: var(--ms-text-faint); }

.ms-label { display: block; font-family: var(--ms-font-heading); font-weight: 600; font-size: var(--ms-fs-sm); color: var(--ms-text); margin-bottom: var(--ms-space-2); }
.ms-field { display: flex; flex-direction: column; gap: var(--ms-space-2); margin-bottom: var(--ms-space-5); }

/* ── Radio cards ──────────────────────────────────────────────────────────── */
.ms-radio-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--ms-space-3); }
.ms-radio-grid-2 { grid-template-columns: repeat(2, 1fr); }
.ms-radio-grid-1 { grid-template-columns: 1fr; }

.ms-radio-card {
  position: relative; width: 100%;
  display: flex; align-items: center; gap: var(--ms-space-4); padding: var(--ms-space-4);
  border-radius: var(--ms-radius-card); border: 2px solid var(--ms-border);
  background: var(--ms-surface); text-align: left; cursor: pointer;
  transition: all var(--ms-dur-fast) var(--ms-ease); outline: none;
  font-family: inherit;
}
.ms-radio-card:hover { border-color: var(--ms-border-strong); background: var(--ms-surface-muted); }
.ms-radio-card[aria-checked="true"] {
  border-color: var(--ms-accent); background: var(--ms-accent-soft);
  box-shadow: 0 2px 8px rgba(244,132,10,0.14);
}
.ms-radio-card-icon {
  width: 44px; height: 44px; border-radius: var(--ms-radius-md);
  background: var(--ms-surface-muted); display: flex; align-items: center; justify-content: center;
  font-size: 1.35rem; flex-shrink: 0; transition: background var(--ms-dur-fast);
}
.ms-radio-card[aria-checked="true"] .ms-radio-card-icon { background: rgba(244,132,10,0.18); }
.ms-radio-card-content { flex: 1; }
.ms-radio-card-label { font-family: var(--ms-font-heading); font-weight: 600; font-size: var(--ms-fs-sm); color: var(--ms-text); }
.ms-radio-card-desc  { font-size: var(--ms-fs-xs); color: var(--ms-text-muted); margin-top: 2px; }
.ms-radio-card-indicator {
  width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0;
  border: 2px solid var(--ms-border-strong); background: var(--ms-surface);
  display: flex; align-items: center; justify-content: center;
  transition: all var(--ms-dur-fast);
}
.ms-radio-card[aria-checked="true"] .ms-radio-card-indicator {
  border-color: var(--ms-accent); background: var(--ms-accent);
}
.ms-radio-card[aria-checked="true"] .ms-radio-card-indicator::after {
  content: ''; width: 7px; height: 7px; border-radius: 50%; background: #fff;
}

/* Checkbox cards (meervoudig) */
.ms-check-card[aria-checked="true"] { border-color: var(--ms-primary); background: rgba(11,36,71,0.04); }
.ms-check-card[aria-checked="true"] .ms-radio-card-indicator {
  border-color: var(--ms-primary); background: var(--ms-primary); border-radius: 4px;
}
.ms-check-card[aria-checked="true"] .ms-radio-card-indicator::after {
  content: ''; width: 10px; height: 6px;
  border-left: 2px solid #fff; border-bottom: 2px solid #fff;
  transform: rotate(-45deg) translate(1px,-1px);
  background: transparent; border-radius: 0;
}

/* ── Voortgangsbalk ───────────────────────────────────────────────────────── */
.ms-progress-wrap { width: 100%; }
.ms-progress-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--ms-space-2); }
.ms-progress-label { font-family: var(--ms-font-heading); font-weight: 600; font-size: var(--ms-fs-xs); color: var(--ms-primary); }
.ms-progress-step  { font-family: var(--ms-font-body); font-size: var(--ms-fs-xs); color: var(--ms-text-muted); }
.ms-progress-track { height: 7px; background: var(--ms-border); border-radius: var(--ms-radius-pill); overflow: hidden; }
.ms-progress-fill  { height: 100%; background: var(--ms-accent); border-radius: var(--ms-radius-pill); transition: width 480ms var(--ms-ease-out); }

/* ── Hero – netwerk achtergrond ───────────────────────────────────────────── */
.ms-hero-section {
  position: relative; overflow: hidden;
  background-color: var(--ms-primary-deep);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Ccircle cx='10' cy='10' r='2' fill='%23F4840A' fill-opacity='0.18'/%3E%3Ccircle cx='50' cy='10' r='2' fill='%23F4840A' fill-opacity='0.12'/%3E%3Ccircle cx='10' cy='50' r='2' fill='%23F4840A' fill-opacity='0.12'/%3E%3Ccircle cx='70' cy='40' r='2' fill='%23F4840A' fill-opacity='0.14'/%3E%3Ccircle cx='40' cy='70' r='2' fill='%23F4840A' fill-opacity='0.10'/%3E%3Cline x1='10' y1='10' x2='50' y2='10' stroke='%23F4840A' stroke-opacity='0.07' stroke-width='1'/%3E%3Cline x1='10' y1='10' x2='10' y2='50' stroke='%23F4840A' stroke-opacity='0.07' stroke-width='1'/%3E%3Cline x1='50' y1='10' x2='70' y2='40' stroke='%23F4840A' stroke-opacity='0.06' stroke-width='1'/%3E%3Cline x1='10' y1='50' x2='40' y2='70' stroke='%23F4840A' stroke-opacity='0.06' stroke-width='1'/%3E%3Cline x1='70' y1='40' x2='40' y2='70' stroke='%23F4840A' stroke-opacity='0.05' stroke-width='1'/%3E%3C/svg%3E");
  padding: var(--ms-space-20) var(--ms-space-6);
  text-align: center;
}
.ms-hero-glow-1 {
  position: absolute; top: 18%; right: 8%; width: 280px; height: 280px;
  background: rgba(244,132,10,0.10); border-radius: 50%; filter: blur(64px); pointer-events: none;
}
.ms-hero-glow-2 {
  position: absolute; bottom: 14%; left: 8%; width: 220px; height: 220px;
  background: rgba(96,165,250,0.08); border-radius: 50%; filter: blur(64px); pointer-events: none;
}
.ms-hero-content { position: relative; z-index: 1; max-width: 780px; margin: 0 auto; }

/* ── Donatie sectie ───────────────────────────────────────────────────────── */
.ms-donate {
  background: var(--ms-primary);
  padding: var(--ms-space-16) var(--ms-space-6);
  text-align: center;
}
.ms-donate-qr {
  width: 140px; height: 140px; border-radius: var(--ms-radius-lg);
  border: 4px solid rgba(255,255,255,0.20); background: #fff; padding: var(--ms-space-2);
  margin: 0 auto var(--ms-space-4);
  display: block;
}
.ms-donate-link {
  font-family: var(--ms-font-heading); font-weight: 700; font-size: var(--ms-fs-h4);
  color: var(--ms-accent);
}
.ms-donate-link:hover { color: var(--ms-accent-hover); }

/* ── Footer ───────────────────────────────────────────────────────────────── */
.ms-footer {
  background: var(--ms-primary-deep);
  padding: var(--ms-space-10) var(--ms-space-6);
  color: var(--ms-text-on-dark-muted);
}
.ms-footer-inner {
  max-width: var(--ms-container); margin: 0 auto;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: var(--ms-space-5);
}
.ms-footer-brand { display: flex; align-items: center; gap: var(--ms-space-3); }
.ms-footer-links { display: flex; gap: var(--ms-space-6); flex-wrap: wrap; list-style: none; }
.ms-footer-links a { font-size: var(--ms-fs-sm); color: var(--ms-text-on-dark-muted); transition: color var(--ms-dur-fast); }
.ms-footer-links a:hover { color: var(--ms-accent); }
.ms-footer-copy {
  max-width: var(--ms-container); margin: var(--ms-space-5) auto 0;
  padding-top: var(--ms-space-5); border-top: 1px solid rgba(255,255,255,0.09);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--ms-space-2);
  font-size: var(--ms-fs-xs); color: var(--ms-text-on-dark-faint);
}

/* ── Wizard wrapper ───────────────────────────────────────────────────────── */
.ms-wizard {
  max-width: 660px; margin: 0 auto; padding: var(--ms-space-10) var(--ms-space-6);
}
.ms-wizard-card {
  background: var(--ms-surface); border-radius: var(--ms-radius-lg);
  box-shadow: var(--ms-shadow-overlay); overflow: hidden;
}
.ms-wizard-header {
  padding: var(--ms-space-5) var(--ms-space-6);
  border-bottom: 1px solid var(--ms-border);
  display: flex; align-items: center; gap: var(--ms-space-4);
}
.ms-wizard-body {
  padding: var(--ms-space-8);
  animation: ms-fadeup var(--ms-dur-slow) var(--ms-ease-out);
}
.ms-wizard-nav {
  display: flex; gap: var(--ms-space-3); margin-top: var(--ms-space-8);
  padding-top: var(--ms-space-6); border-top: 1px solid var(--ms-border);
}

/* ── Resultaat pagina ─────────────────────────────────────────────────────── */
.ms-result-hero { background: var(--ms-primary); padding: var(--ms-space-16) var(--ms-space-6); }
.ms-urgency-banner {
  border-radius: var(--ms-radius-card); padding: var(--ms-space-5) var(--ms-space-6);
  margin-bottom: var(--ms-space-6); display: flex; align-items: center; gap: var(--ms-space-4);
}
.ms-urgency-critical { background: var(--ms-danger-soft);  border-left: 4px solid var(--ms-u-critical); }
.ms-urgency-high     { background: rgba(249,115,22,0.08);  border-left: 4px solid var(--ms-u-high); }
.ms-urgency-medium   { background: var(--ms-warning-soft); border-left: 4px solid var(--ms-u-medium); }
.ms-urgency-low      { background: var(--ms-success-soft); border-left: 4px solid var(--ms-u-low); }

.ms-action-card {
  display: flex; gap: var(--ms-space-4); align-items: flex-start;
  background: var(--ms-surface); border-radius: var(--ms-radius-card);
  border: 1px solid var(--ms-border); padding: var(--ms-space-5);
  margin-bottom: var(--ms-space-3);
}
.ms-action-num {
  width: 32px; height: 32px; flex-shrink: 0;
  border-radius: 50%; background: var(--ms-primary); color: var(--ms-accent);
  font-family: var(--ms-font-heading); font-weight: 700; font-size: var(--ms-fs-sm);
  display: flex; align-items: center; justify-content: center;
}
.ms-subsidy-row {
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--ms-space-2);
  padding: var(--ms-space-4) 0; border-bottom: 1px solid var(--ms-border);
}
.ms-subsidy-row:last-child { border-bottom: none; }

/* ── FAQ accordion ────────────────────────────────────────────────────────── */
.ms-faq-item { border: 1px solid var(--ms-border); border-radius: var(--ms-radius-card); overflow: hidden; margin-bottom: var(--ms-space-2); }
.ms-faq-btn {
  width: 100%; display: flex; justify-content: space-between; align-items: center;
  padding: var(--ms-space-5) var(--ms-space-6); background: var(--ms-surface); border: none;
  font-family: var(--ms-font-heading); font-weight: 600; font-size: var(--ms-fs-base);
  color: var(--ms-primary); text-align: left; cursor: pointer;
  transition: background var(--ms-dur-fast);
}
.ms-faq-btn:hover { background: var(--ms-surface-muted); }
.ms-faq-icon { transition: transform var(--ms-dur-base); flex-shrink: 0; }
.ms-faq-item.open .ms-faq-icon { transform: rotate(180deg); }
.ms-faq-body {
  padding: 0 var(--ms-space-6) var(--ms-space-5);
  font-size: var(--ms-fs-sm); line-height: var(--ms-lh-relaxed);
  color: var(--ms-text-muted); border-top: 1px solid var(--ms-border);
  padding-top: var(--ms-space-4); display: none;
}
.ms-faq-item.open .ms-faq-body { display: block; }

/* ── Animaties ────────────────────────────────────────────────────────────── */
@keyframes ms-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.4; transform: scale(0.9); }
}
@keyframes ms-fadeup {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes ms-spin {
  to { transform: rotate(360deg); }
}
@keyframes ms-shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}

/* ── Komend binnenkort kaart ──────────────────────────────────────────────── */
.ms-soon-overlay {
  position: absolute; inset: 0; border-radius: var(--ms-radius-card);
  background: rgba(247,248,250,0.85); backdrop-filter: blur(2px);
  display: flex; align-items: center; justify-content: center; z-index: 2;
}

/* ── Statistieken strip ───────────────────────────────────────────────────── */
.ms-stats {
  border-top: 1px solid var(--ms-border); border-bottom: 1px solid var(--ms-border);
  background: var(--ms-surface); padding: var(--ms-space-10) 0;
}
.ms-stats-inner {
  max-width: var(--ms-container); margin: 0 auto; padding: 0 var(--ms-space-6);
  display: flex; justify-content: center; align-items: center;
  gap: var(--ms-space-16); flex-wrap: wrap;
}
.ms-stat-num { font-family: var(--ms-font-heading); font-weight: 800; font-size: var(--ms-fs-h1); color: var(--ms-primary); line-height: 1; }
.ms-stat-lbl { font-size: var(--ms-fs-sm); color: var(--ms-text-muted); margin-top: var(--ms-space-1); }

/* ── Print ────────────────────────────────────────────────────────────────── */
@media print {
  .ms-nav, .ms-footer, .no-print, .ms-donate, .ms-wizard-nav, .ms-btn { display: none !important; }
  body { background: #fff; font-size: 11pt; color: #000; }
  .ms-container { max-width: none; padding: 0; }
  .print-only { display: block !important; }
  .ms-card, .ms-action-card, .ms-urgency-banner { break-inside: avoid; }
  @page { margin: 20mm 18mm; size: A4; }
}
.print-only { display: none; }

/* ── Responsief ───────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .ms-nav-links { display: none; }
  .ms-hero-section { padding: var(--ms-space-12) var(--ms-space-5); }
  .ms-section  { padding: var(--ms-space-12) 0; }
  .ms-radio-grid-2 { grid-template-columns: 1fr; }
  .ms-stats-inner { gap: var(--ms-space-10); }
  .ms-footer-inner { flex-direction: column; align-items: flex-start; }
  .ms-wizard-body { padding: var(--ms-space-6); }
}
@media (max-width: 480px) {
  .ms-container { padding: 0 var(--ms-space-4); }
  .ms-btn-lg { font-size: var(--ms-fs-base); padding: 14px 24px; }
  .ms-hero-section { padding: var(--ms-space-10) var(--ms-space-4); }
}
