/* =========================================================================
     GEMEENTEGELD — design tokens
     Dark brutalist. V for Vendetta × long-form journalism.
     ========================================================================= */
  :root{
    /* Color — primitives */
    --gg-black:#0a0a0a;
    --gg-black-2:#111111;
    --gg-black-3:#181614;

    --gg-bone:#ede4d3;
    --gg-bone-2:#d9d0bf;
    --gg-bone-3:#a59c8b;
    --gg-bone-4:#6b6357;

    --gg-blood:#a4161a;
    --gg-blood-dark:#7a0f12;

    --gg-gold:#c9a961;
    --gg-gold-dark:#9a7f43;

    --gg-rule:#2a2620;
    --gg-rule-soft:#1a1815;

    /* Color — semantic */
    --bg:var(--gg-black);
    --bg-elev:var(--gg-black-2);
    --fg:var(--gg-bone);
    --fg-dim:var(--gg-bone-2);
    --fg-mute:var(--gg-bone-3);
    --fg-faint:var(--gg-bone-4);
    --accent:var(--gg-gold);
    --alarm:var(--gg-blood);
    --rule:var(--gg-rule);
    --rule-soft:var(--gg-rule-soft);
    --focus:var(--gg-bone);

    /* Type */
    --font-display:"Fraunces","Playfair Display","Bodoni 72","Didot",Georgia,"Times New Roman",serif;
    --font-body:"Inter Tight",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue",Arial,sans-serif;
    --font-mono:"JetBrains Mono","IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;

    --fs-eyebrow:12px;
    --fs-body:17px;
    --fs-lede:clamp(19px,2vw,24px);
    --fs-h2:clamp(32px,4.4vw,56px);
    --fs-h1:clamp(44px,7.2vw,104px);
    --fs-mega:clamp(64px,12vw,180px);

    --tr-eyebrow:0.18em;

    /* Spacing */
    --pad-section:clamp(72px,10vw,128px);
    --pad-gutter:clamp(20px,4vw,48px);
    --maxw:1180px;
    --maxw-text:680px;

    --radius:0;

    /* Motion */
    --ease:cubic-bezier(0.2,0.6,0.2,1);
    --dur-fast:180ms;
    --dur-slow:900ms;
  }

  /* ========== Base ========== */
  *{box-sizing:border-box}
  html{
    scroll-behavior:smooth;
    background:var(--bg);color:var(--fg);
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    text-rendering:optimizeLegibility;
  }
  body{
    margin:0;background:var(--bg);color:var(--fg);
    font-family:var(--font-body);font-size:var(--fs-body);line-height:1.55;
    font-feature-settings:"tnum" 1, "ss01" 1;
  }
  ::selection{background:var(--alarm);color:var(--fg)}

  h1,h2,h3,h4{
    font-family:var(--font-display);font-weight:400;color:var(--fg);
    line-height:1.02;letter-spacing:-0.035em;margin:0;text-wrap:balance;
  }
  h1{font-size:var(--fs-h1);font-weight:300}
  h2{font-size:var(--fs-h2);font-weight:300;letter-spacing:-0.025em;line-height:1.08}
  h1 em,h2 em,h3 em{font-style:italic;font-weight:inherit;color:var(--fg)}

  p{margin:0 0 1em;max-width:var(--maxw-text);text-wrap:pretty}

  a{
    color:inherit;text-decoration:none;
    border-bottom:1px solid var(--rule);
    transition:border-color var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease);
  }
  a:hover{border-color:var(--accent);color:var(--fg)}
  a:focus-visible{outline:2px solid var(--focus);outline-offset:2px;border-color:transparent}

  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-gutter)}

  /* ========== Primitives ========== */
  .eyebrow{
    font-family:var(--font-body);font-size:var(--fs-eyebrow);font-weight:500;
    letter-spacing:var(--tr-eyebrow);text-transform:uppercase;color:var(--fg-mute);
    display:inline-flex;align-items:center;gap:10px;margin:0;
  }
  .eyebrow::before{content:"";width:18px;height:1px;background:var(--accent)}

  .lede{
    font-family:var(--font-display);font-weight:300;font-style:italic;
    font-size:var(--fs-lede);line-height:1.5;color:var(--fg-dim);
    max-width:58ch;
  }

  .num{
    font-family:var(--font-display);font-weight:300;
    font-variant-numeric:tabular-nums;letter-spacing:-0.02em;
  }
  .num--alarm{color:var(--alarm)}
  .num--mega{font-size:var(--fs-mega);line-height:1}

  .mono{
    font-family:var(--font-mono);
    font-feature-settings:"tnum" 1,"zero" 1;
  }

  blockquote{
    font-family:var(--font-display);font-weight:300;font-style:italic;
    font-size:clamp(24px,3vw,36px);line-height:1.3;color:var(--fg);
    border-left:1px solid var(--accent);
    padding:12px 0 12px 32px;margin:64px 0;max-width:44ch;
  }
  blockquote cite{
    display:block;margin-top:16px;
    font-family:var(--font-body);font-style:normal;
    font-size:var(--fs-eyebrow);letter-spacing:var(--tr-eyebrow);
    text-transform:uppercase;color:var(--fg-mute);
  }

  hr{border:0;border-top:1px solid var(--rule);margin:64px 0}

  /* ========== Topbar ========== */
  .topbar{
    position:sticky;top:0;z-index:50;
    background:rgba(10,10,10,0.88);
    backdrop-filter:saturate(140%) blur(10px);
    -webkit-backdrop-filter:saturate(140%) blur(10px);
    border-bottom:1px solid var(--rule);
  }
  .topbar-inner{
    display:flex;align-items:center;justify-content:space-between;height:64px;
  }
  .brand{display:flex;align-items:baseline;gap:10px;border-bottom:0}
  .brand:hover{border-bottom:0}
  .brand-name{font-family:var(--font-display);font-size:22px;font-weight:300;letter-spacing:-0.02em;color:var(--fg)}
  .brand-dot{
    width:6px;height:6px;border-radius:50%;background:var(--accent);
    display:inline-block;transform:translateY(-3px);
  }
  .brand-sub{
    font-family:var(--font-body);font-size:12px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
  }
  nav.nav{display:flex;gap:22px}
  nav.nav a{
    font-size:13px;color:var(--fg-dim);padding:4px 0;
    border-bottom:1px solid transparent;
    transition:border-color var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease);
  }
  nav.nav a:hover{border-bottom-color:var(--accent);color:var(--fg)}
  nav.nav a.active{border-bottom-color:var(--accent);color:var(--fg)}
  @media (max-width:820px){ nav.nav{display:none} }

  /* ========== Hero ========== */
  .hero{padding:clamp(48px,9vw,120px) 0 clamp(40px,7vw,96px)}
  .display{
    font-family:var(--font-display);font-weight:300;
    font-size:var(--fs-h1);line-height:1.02;letter-spacing:-0.035em;
    margin:.35em 0 .45em;max-width:14ch;color:var(--fg);
  }
  .hero-meta{
    display:grid;grid-template-columns:repeat(5,1fr);
    border-top:1px solid var(--rule);
  }
  .hm{padding:22px;border-right:1px solid var(--rule-soft)}
  .hm:first-child{padding-left:0}
  .hm:last-child{border-right:0}
  .hm-num{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(26px,3vw,40px);letter-spacing:-0.02em;line-height:1;
    color:var(--fg);font-variant-numeric:tabular-nums;
  }
  .hm-num--alarm{color:var(--alarm)}
  .hm-lbl{
    font-family:var(--font-body);font-size:12px;font-weight:500;
    letter-spacing:0.12em;text-transform:uppercase;color:var(--fg-mute);
    margin-top:10px;
  }
  @media (max-width:820px){
    .hero-meta{grid-template-columns:repeat(2,1fr)}
    .hm{padding:18px 14px 18px 0}
    .hm:nth-child(even){border-right:0}
  }

  /* ========== Section frame ========== */
  section.s{padding:var(--pad-section) 0;border-top:1px solid var(--rule);background:var(--bg)}
  section.s.alt{background:var(--bg-elev)}
  .section-head{max-width:720px;margin-bottom:clamp(40px,5vw,64px)}
  .section-head h2{margin:.35em 0 .45em}
  .section-head .intro{
    font-family:var(--font-display);font-weight:300;font-style:italic;
    font-size:clamp(17px,1.5vw,20px);color:var(--fg-dim);margin:0;max-width:56ch;
  }

  .placeholder{
    border:1px dashed var(--rule);padding:40px;color:var(--fg-mute);
    font-family:var(--font-mono);font-size:12px;letter-spacing:0.04em;
    display:flex;align-items:center;justify-content:center;min-height:160px;
    text-transform:uppercase;
  }

  /* ========== §02 Overzicht ========== */
  .ov-top{
    display:grid;grid-template-columns:1.2fr 1fr;
    gap:clamp(40px,6vw,96px);align-items:start;
    margin-bottom:clamp(56px,7vw,96px);
  }
  .ov-mega{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(80px,11vw,160px);line-height:0.95;
    letter-spacing:-0.04em;color:var(--fg);
    font-variant-numeric:tabular-nums;
  }
  .ov-mega-unit{font-size:0.4em;color:var(--fg-mute);margin-left:12px}
  .ov-mega-cap{
    font-family:var(--font-body);font-size:12px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
    margin-top:16px;
  }
  .ov-context{
    display:grid;grid-template-columns:1fr 1fr;
    border-top:1px solid var(--rule);
  }
  .ov-cx{
    padding:22px 22px 22px 0;
    border-right:1px solid var(--rule-soft);
    border-bottom:1px solid var(--rule-soft);
  }
  .ov-cx:nth-child(2n){border-right:0;padding-right:0;padding-left:22px}
  .ov-cx:nth-last-child(-n+2){border-bottom:0}
  .ov-cx-num{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(22px,2.4vw,32px);letter-spacing:-0.02em;line-height:1;
    color:var(--fg);font-variant-numeric:tabular-nums;
  }
  .ov-cx-num--alarm{color:var(--alarm)}
  .ov-cx-lbl{
    font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
    margin-top:10px;
  }
  .ov-cx-sub{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
    margin-top:4px;
  }

  .ov-bars-head{
    display:flex;justify-content:space-between;align-items:baseline;
    margin-bottom:24px;padding-bottom:16px;
    border-bottom:1px solid var(--rule);
  }
  .ov-bars-title{
    font-family:var(--font-display);font-weight:400;
    font-size:clamp(20px,2vw,24px);letter-spacing:-0.02em;color:var(--fg);
  }
  .ov-bars-sub{
    font-family:var(--font-body);font-size:12px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
  }
  .ov-row{padding:18px 0;border-bottom:1px solid var(--rule-soft)}
  .ov-row:last-child{border-bottom:0}
  .ov-row-top{
    display:grid;grid-template-columns:28px 1fr auto;
    gap:18px;align-items:baseline;
  }
  .ov-rank{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);
    font-variant-numeric:tabular-nums;
  }
  .ov-name{
    font-family:var(--font-display);font-weight:400;
    font-size:clamp(17px,1.6vw,20px);letter-spacing:-0.015em;color:var(--fg);
  }
  .ov-sub{
    font-family:var(--font-body);font-size:13px;color:var(--fg-mute);
    margin-top:3px;
  }
  .ov-amount{
    font-family:var(--font-mono);font-size:13px;color:var(--fg);
    font-variant-numeric:tabular-nums;
  }
  .ov-amount-share{color:var(--fg-mute);margin-left:10px}
  .ov-bar-track{
    grid-column:2 / 4;
    margin-top:10px;height:2px;background:var(--rule);position:relative;overflow:hidden;
  }
  .ov-bar-fill{
    height:2px;background:var(--fg);width:0;
    transition:width var(--dur-slow) var(--ease);
  }
  .ov-row-meta{
    grid-column:2 / 4;
    margin-top:12px;
    display:flex;justify-content:space-between;align-items:baseline;gap:16px;
    font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);
    letter-spacing:0.04em;font-variant-numeric:tabular-nums;
  }
  .ov-row-meta .ov-pp strong{color:var(--fg);font-weight:400}
  .ov-row-link{
    font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
    border-bottom:1px solid transparent;
    transition:color var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease);
  }
  .ov-row-link:hover{color:var(--accent);border-bottom-color:var(--accent)}
  .ov-row-link::after{content:" →";display:inline-block;margin-left:4px;transition:transform var(--dur-fast) var(--ease)}
  .ov-row-link:hover::after{transform:translateX(2px)}
  .ov-rows.in .ov-bar-fill{width:var(--pct)}
  .ov-rows.in .ov-row:nth-child(1)  .ov-bar-fill{transition-delay:0ms}
  .ov-rows.in .ov-row:nth-child(2)  .ov-bar-fill{transition-delay:80ms}
  .ov-rows.in .ov-row:nth-child(3)  .ov-bar-fill{transition-delay:160ms}
  .ov-rows.in .ov-row:nth-child(4)  .ov-bar-fill{transition-delay:240ms}
  .ov-rows.in .ov-row:nth-child(5)  .ov-bar-fill{transition-delay:320ms}
  .ov-rows.in .ov-row:nth-child(6)  .ov-bar-fill{transition-delay:400ms}
  .ov-rows.in .ov-row:nth-child(7)  .ov-bar-fill{transition-delay:480ms}
  .ov-rows.in .ov-row:nth-child(8)  .ov-bar-fill{transition-delay:560ms}
  .ov-rows.in .ov-row:nth-child(9)  .ov-bar-fill{transition-delay:640ms}

  @media (max-width:820px){
    .ov-top{grid-template-columns:1fr}
    .ov-row-top{grid-template-columns:24px 1fr;grid-template-rows:auto auto}
    .ov-amount{grid-column:1 / 3;text-align:left}
    .ov-bar-track{grid-column:1 / 3}
    .ov-row-meta{grid-column:1 / 3}
  }
  @media (prefers-reduced-motion:reduce){
    .ov-bar-fill{width:var(--pct) !important;transition:none !important}
  }

  /* ========== §02 · Rijksbijdrage callout ========== */
  .rb-callout{
    background:var(--bg-elev);
    border:1px solid var(--rule);
    padding:clamp(28px,4vw,48px);
    margin:clamp(48px,6vw,72px) 0 clamp(56px,7vw,80px);
  }
  .rb-head{margin-bottom:clamp(28px,3vw,40px);max-width:560px}
  .rb-head h3{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(26px,3vw,36px);letter-spacing:-0.025em;line-height:1.1;
    color:var(--fg);margin:.4em 0 0;
  }
  .rb-head h3 em{font-style:italic;color:var(--fg)}
  .rb-grid{
    display:grid;grid-template-columns:1.4fr 1fr;
    gap:clamp(32px,5vw,64px);align-items:start;
  }
  .rb-text p{
    font-family:var(--font-body);font-size:15px;color:var(--fg-dim);
    line-height:1.6;margin:0 0 14px;max-width:60ch;
  }
  .rb-text p:last-child{
    margin-top:18px;padding-top:18px;
    border-top:1px solid var(--rule);
    color:var(--fg);font-family:var(--font-display);
    font-style:italic;font-weight:300;font-size:18px;
  }
  .rb-spread{
    border-left:1px solid var(--rule);
    padding-left:clamp(24px,3vw,36px);
  }
  .rb-spread-lbl{
    font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
    margin-bottom:18px;
  }
  .rb-spread-sub{
    display:block;font-weight:400;letter-spacing:0.04em;
    text-transform:none;color:var(--fg-faint);
    font-family:var(--font-mono);font-size:11px;margin-top:4px;
  }
  .rb-row{
    display:flex;justify-content:space-between;align-items:baseline;
    padding:14px 0;border-bottom:1px solid var(--rule-soft);gap:14px;
  }
  .rb-row:last-child{border-bottom:0}
  .rb-row-name{
    font-family:var(--font-body);font-size:13px;color:var(--fg-dim);
  }
  .rb-row-name span{
    display:block;font-family:var(--font-mono);font-size:10px;
    color:var(--fg-faint);margin-top:2px;letter-spacing:0.04em;
  }
  .rb-row-num{
    font-family:var(--font-display);font-weight:300;font-size:22px;
    letter-spacing:-0.02em;line-height:1;color:var(--fg);
    font-variant-numeric:tabular-nums;
  }
  .rb-row--katwijk{
    background:rgba(201,169,97,0.06);
    margin:0 -10px;padding-left:10px;padding-right:10px;
  }
  .rb-row--katwijk .rb-row-name{color:var(--fg)}
  .rb-row--katwijk .rb-row-num{color:var(--accent);font-size:18px}
  .rb-source{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
    margin:24px 0 0;padding-top:18px;border-top:1px solid var(--rule);
    max-width:90ch;
  }
  @media (max-width:820px){
    .rb-grid{grid-template-columns:1fr}
    .rb-spread{border-left:0;padding-left:0;border-top:1px solid var(--rule);padding-top:24px}
  }

  /* ========== §03 Trends ========== */
  .tr-bar{
    display:flex;justify-content:space-between;align-items:baseline;
    flex-wrap:wrap;gap:16px;
    padding-bottom:16px;margin-bottom:24px;
    border-bottom:1px solid var(--rule);
  }
  .tr-filters{display:flex;gap:0}
  .tr-filter{
    font-family:var(--font-body);font-size:12px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
    background:transparent;border:0;border-bottom:1px solid transparent;
    padding:8px 18px 8px 0;margin-right:18px;cursor:pointer;
    transition:color var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease);
  }
  .tr-filter:hover{color:var(--fg)}
  .tr-filter.active{color:var(--fg);border-bottom-color:var(--accent)}
  .tr-filter:focus-visible{outline:2px solid var(--focus);outline-offset:2px}
  .tr-meta{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
  }
  .tr-grid{
    display:grid;grid-template-columns:repeat(3,1fr);
    column-gap:clamp(24px,3vw,48px);
    border-top:1px solid var(--rule);
  }
  .tr-cell{
    padding:28px 0;border-bottom:1px solid var(--rule-soft);
    display:flex;flex-direction:column;gap:18px;
  }
  .tr-cell.hidden{display:none}
  .tr-cell-head{
    display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  }
  .tr-cell-name{
    font-family:var(--font-display);font-weight:400;font-size:17px;
    letter-spacing:-0.015em;color:var(--fg);
  }
  .tr-cell-rank{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);
  }
  .tr-spark{position:relative;height:48px;width:100%}
  .tr-cell-foot{
    display:flex;justify-content:space-between;align-items:baseline;
  }
  .tr-delta{
    font-family:var(--font-display);font-weight:300;font-size:28px;
    letter-spacing:-0.02em;line-height:1;color:var(--fg);
    font-variant-numeric:tabular-nums;
  }
  .tr-delta--alarm{color:var(--alarm)}
  .tr-range{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
  }
  @media (max-width:820px){
    .tr-grid{grid-template-columns:1fr}
  }

  /* ========== §04 Jouw lasten ========== */
  .la-households{
    display:grid;grid-template-columns:repeat(3,1fr);
    gap:clamp(24px,4vw,56px);margin-bottom:clamp(56px,7vw,88px);
  }
  .la-hh{
    border-top:1px solid var(--fg);padding-top:24px;
    display:flex;flex-direction:column;
  }
  .la-hh-lbl{
    font-family:var(--font-body);font-size:12px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
  }
  .la-hh-sub{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
    margin-top:6px;
  }
  .la-hh-total{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(44px,5vw,64px);letter-spacing:-0.03em;line-height:1;
    color:var(--fg);font-variant-numeric:tabular-nums;
    margin:22px 0 28px;
  }
  .la-hh-items{
    display:flex;flex-direction:column;gap:10px;
    font-family:var(--font-mono);font-size:13px;color:var(--fg-dim);
    font-variant-numeric:tabular-nums;
  }
  .la-hh-item{
    display:flex;justify-content:space-between;
    border-bottom:1px solid var(--rule-soft);padding-bottom:8px;
  }
  .la-hh-item-k{color:var(--fg-mute)}
  .la-hh-item-none{color:var(--fg-faint)}

  .la-tarief-head{
    display:flex;justify-content:space-between;align-items:baseline;
    margin-bottom:16px;
  }
  .la-tarief-title{
    font-family:var(--font-display);font-weight:400;
    font-size:clamp(20px,2vw,24px);letter-spacing:-0.02em;color:var(--fg);
  }
  .la-tarief-meta{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
  }
  table.la-tarief{
    width:100%;border-collapse:collapse;
    font-family:var(--font-body);font-size:14px;color:var(--fg);
  }
  .la-tarief th{
    text-align:left;padding:14px 16px 14px 0;
    border-bottom:1px solid var(--rule);
    font-family:var(--font-body);font-weight:500;font-size:11px;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
  }
  .la-tarief th.num{text-align:right;font-family:var(--font-body)}
  .la-tarief td{
    padding:14px 16px 14px 0;
    border-bottom:1px solid var(--rule-soft);
    vertical-align:top;
  }
  .la-tarief td.num{
    text-align:right;font-family:var(--font-mono);
    font-variant-numeric:tabular-nums;color:var(--fg);
  }
  .la-tarief td.num--muted{color:var(--fg-mute)}
  .la-tarief td.num--alarm{color:var(--alarm)}
  .la-tarief td.num--gold{color:var(--accent)}
  .la-tarief td:last-child,.la-tarief th:last-child{padding-right:0}
  .la-tarief tr:last-child td{border-bottom:0}
  .la-tarief-cat{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
    display:block;margin-top:3px;
  }
  .la-tarief-scroll{overflow-x:auto}

  @media (max-width:820px){
    .la-households{grid-template-columns:1fr}
    table.la-tarief{min-width:620px}
  }

  /* ========== §05 Formatie ========== */
  .fo-stats{
    display:grid;grid-template-columns:repeat(4,1fr);
    border-top:1px solid var(--rule);margin-bottom:clamp(48px,6vw,72px);
  }
  .fo-stat{
    padding:22px 22px 22px 0;
    border-right:1px solid var(--rule-soft);
  }
  .fo-stat:first-child{padding-left:0}
  .fo-stat:last-child{border-right:0}
  .fo-stat-num{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(28px,3.2vw,40px);letter-spacing:-0.02em;line-height:1;
    color:var(--fg);font-variant-numeric:tabular-nums;
  }
  .fo-stat-num--alarm{color:var(--alarm)}
  .fo-stat-lbl{
    font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
    margin-top:12px;
  }
  .fo-stat-sub{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);margin-top:4px;
  }
  @media (max-width:820px){
    .fo-stats{grid-template-columns:repeat(2,1fr)}
    .fo-stat{padding:18px 14px 18px 0}
    .fo-stat:nth-child(even){border-right:0}
    .fo-stat:nth-child(3),.fo-stat:nth-child(4){padding-top:18px;border-top:1px solid var(--rule-soft)}
  }

  .fo-tbl-head{
    display:flex;justify-content:space-between;align-items:baseline;
    margin-bottom:16px;
  }
  .fo-tbl-title{
    font-family:var(--font-display);font-weight:400;
    font-size:clamp(20px,2vw,24px);letter-spacing:-0.02em;color:var(--fg);
  }
  .fo-tbl-meta{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
  }
  .fo-tbl-scroll{overflow-x:auto;margin-bottom:clamp(48px,6vw,80px)}
  table.fo-tbl{
    width:100%;border-collapse:collapse;
    font-family:var(--font-body);font-size:14px;color:var(--fg);
  }
  .fo-tbl th{
    text-align:left;padding:14px 16px 14px 0;
    border-bottom:1px solid var(--rule);
    font-family:var(--font-body);font-weight:500;font-size:11px;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
  }
  .fo-tbl th.num{text-align:right}
  .fo-tbl td{
    padding:14px 16px 14px 0;
    border-bottom:1px solid var(--rule-soft);
    vertical-align:top;
  }
  .fo-tbl td.num{
    text-align:right;font-family:var(--font-mono);
    font-variant-numeric:tabular-nums;color:var(--fg);
  }
  .fo-tbl td.num--muted{color:var(--fg-mute)}
  .fo-tbl td.num--alarm{color:var(--alarm)}
  .fo-tbl td:last-child,.fo-tbl th:last-child{padding-right:0}
  .fo-tbl tr:last-child td{border-bottom:0}
  .fo-tbl .fo-rank{
    color:var(--fg-mute);font-family:var(--font-mono);font-size:12px;
    padding-right:16px;width:32px;
  }
  .fo-tbl tfoot td{
    border-top:1px solid var(--rule);border-bottom:0;
    padding-top:16px;color:var(--fg);
    font-family:var(--font-body);font-weight:500;font-size:12px;
    letter-spacing:0.12em;text-transform:uppercase;
  }
  .fo-tbl tfoot td.num{
    text-transform:none;letter-spacing:0;
    font-family:var(--font-mono);font-weight:400;font-size:14px;
  }

  @media (max-width:820px){
    table.fo-tbl{min-width:640px}
  }

  /* ========== §06 Salarissen ========== */
  .sa-explainer{
    background:var(--bg-elev);
    border:1px solid var(--rule);
    padding:clamp(28px,4vw,48px);
    margin-bottom:clamp(48px,6vw,72px);
    display:grid;grid-template-columns:1.4fr 1fr;
    gap:clamp(32px,5vw,64px);align-items:start;
  }
  .sa-explainer h3{
    font-family:var(--font-display);font-weight:400;
    font-size:clamp(22px,2.4vw,28px);letter-spacing:-0.02em;line-height:1.15;
    color:var(--fg);margin-bottom:14px;
  }
  .sa-explainer p{
    font-family:var(--font-body);font-size:15px;color:var(--fg-dim);
    line-height:1.6;margin:0 0 12px;max-width:58ch;
  }
  .sa-explainer-meta{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
    letter-spacing:0.04em;margin-top:12px;
  }
  .sa-bookends{
    display:flex;flex-direction:column;gap:20px;
    border-left:1px solid var(--rule);padding-left:clamp(24px,3vw,36px);
  }
  .sa-bookend-lbl{
    font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
  }
  .sa-bookend-num{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(28px,3.2vw,40px);letter-spacing:-0.02em;line-height:1;
    color:var(--fg);font-variant-numeric:tabular-nums;margin-top:8px;
  }
  .sa-bookend-num--alarm{color:var(--alarm)}
  .sa-bookend-sub{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);margin-top:4px;
  }
  @media (max-width:820px){
    .sa-explainer{grid-template-columns:1fr}
    .sa-bookends{border-left:0;padding-left:0;border-top:1px solid var(--rule);padding-top:24px}
  }

  .sa-chart-head{
    display:flex;justify-content:space-between;align-items:baseline;
    margin-bottom:16px;
  }
  .sa-chart-title{
    font-family:var(--font-display);font-weight:400;
    font-size:clamp(20px,2vw,24px);letter-spacing:-0.02em;color:var(--fg);
  }
  .sa-chart-meta{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
  }
  .sa-chart{
    position:relative;height:520px;
    padding:8px 0 8px 0;
    border-top:1px solid var(--rule);
    margin-bottom:clamp(56px,7vw,80px);
  }
  @media (max-width:820px){
    .sa-chart{height:440px}
  }

  table.sa-fn{
    width:100%;border-collapse:collapse;
    font-family:var(--font-body);font-size:14px;color:var(--fg);
  }
  .sa-fn th{
    text-align:left;padding:14px 16px 14px 0;
    border-bottom:1px solid var(--rule);
    font-family:var(--font-body);font-weight:500;font-size:11px;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
  }
  .sa-fn th.num{text-align:right}
  .sa-fn td{
    padding:16px 16px 16px 0;border-bottom:1px solid var(--rule-soft);
    vertical-align:top;
  }
  .sa-fn td.num{
    text-align:right;font-family:var(--font-mono);
    font-variant-numeric:tabular-nums;color:var(--fg);
  }
  .sa-fn td.num--alarm{color:var(--alarm)}
  .sa-fn td:last-child,.sa-fn th:last-child{padding-right:0}
  .sa-fn tr:last-child td{border-bottom:0}
  .sa-fn-cluster{
    font-family:var(--font-display);font-weight:400;font-size:17px;
    letter-spacing:-0.015em;color:var(--fg);
  }
  .sa-fn-sub{
    display:block;margin-top:4px;
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
  }
  .sa-fn-scroll{overflow-x:auto}
  @media (max-width:820px){ table.sa-fn{min-width:600px} }

  /* ========== §07 Subsidies ========== */
  .su-stats{
    display:grid;grid-template-columns:repeat(4,1fr);
    border-top:1px solid var(--rule);margin-bottom:clamp(48px,6vw,72px);
  }
  .su-stat{padding:22px 22px 22px 0;border-right:1px solid var(--rule-soft)}
  .su-stat:first-child{padding-left:0}
  .su-stat:last-child{border-right:0}
  .su-stat-num{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(26px,3vw,36px);letter-spacing:-0.02em;line-height:1;
    color:var(--fg);font-variant-numeric:tabular-nums;
  }
  .su-stat-num--alarm{color:var(--alarm)}
  .su-stat-num--gold{color:var(--accent)}
  .su-stat-lbl{
    font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
    margin-top:12px;
  }
  .su-stat-sub{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);margin-top:4px}
  @media (max-width:820px){
    .su-stats{grid-template-columns:repeat(2,1fr)}
    .su-stat{padding:18px 14px 18px 0}
    .su-stat:nth-child(even){border-right:0}
    .su-stat:nth-child(3),.su-stat:nth-child(4){padding-top:18px;border-top:1px solid var(--rule-soft)}
  }

  .su-toolbar{
    display:flex;gap:24px;flex-wrap:wrap;
    align-items:center;justify-content:space-between;
    padding:16px 0;border-bottom:1px solid var(--rule);
    margin-bottom:0;
  }
  .su-search{
    display:flex;align-items:center;gap:10px;flex:1;min-width:240px;
    border-bottom:1px solid var(--rule);padding:6px 0;
  }
  .su-search:focus-within{border-bottom-color:var(--accent)}
  .su-search svg{width:14px;height:14px;color:var(--fg-mute);flex-shrink:0}
  .su-search input{
    background:transparent;border:0;outline:0;
    font-family:var(--font-body);font-size:14px;color:var(--fg);
    flex:1;padding:4px 0;
  }
  .su-search input::placeholder{color:var(--fg-mute)}
  .su-sort{display:flex;gap:0;align-items:baseline;flex-shrink:0}
  .su-sort-lbl{
    font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
    margin-right:14px;
  }
  .su-sort button{
    background:transparent;border:0;cursor:pointer;
    font-family:var(--font-body);font-size:12px;font-weight:500;
    letter-spacing:0.08em;text-transform:uppercase;color:var(--fg-mute);
    padding:6px 14px 6px 0;margin-right:6px;
    border-bottom:1px solid transparent;
    transition:color var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease);
  }
  .su-sort button:hover{color:var(--fg)}
  .su-sort button.active{color:var(--fg);border-bottom-color:var(--accent)}
  .su-sort button:focus-visible{outline:2px solid var(--focus);outline-offset:2px}
  .su-cats{flex-wrap:wrap;align-items:center;padding:14px 0;border-bottom:1px solid var(--rule-soft)}

  .su-notice{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
    padding:12px 0;border-bottom:1px solid var(--rule-soft);
    display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  }
  .su-notice-alarm{color:var(--alarm)}

  .su-list{margin-top:8px}
  details.su-row{
    border-bottom:1px solid var(--rule-soft);
    transition:background var(--dur-fast) var(--ease);
  }
  details.su-row[open]{background:var(--bg)}
  details.su-row summary{
    display:grid;
    grid-template-columns: 28px 1.6fr 1fr auto;
    gap:24px;align-items:center;
    padding:20px 0;cursor:pointer;list-style:none;
  }
  details.su-row summary::-webkit-details-marker{display:none}
  details.su-row summary:hover{background:rgba(255,255,255,0.01)}
  .su-chev{
    font-family:var(--font-mono);font-size:14px;color:var(--fg-mute);
    transition:transform var(--dur-fast) var(--ease);
    width:28px;text-align:center;
  }
  details.su-row[open] .su-chev{transform:rotate(90deg);color:var(--accent)}
  .su-name{
    font-family:var(--font-display);font-weight:400;font-size:17px;
    letter-spacing:-0.015em;color:var(--fg);
    display:flex;flex-direction:column;gap:4px;
  }
  .su-tag{
    display:inline-block;font-family:var(--font-body);font-size:10px;
    font-weight:500;letter-spacing:0.14em;text-transform:uppercase;
    color:var(--fg-mute);border:1px solid var(--rule);
    padding:2px 8px;margin-top:4px;align-self:flex-start;
  }
  .su-tag--gold{color:var(--accent);border-color:var(--accent)}
  .su-tag--alarm{color:var(--alarm);border-color:var(--alarm)}
  .su-mini{position:relative;height:36px;width:100%;min-width:120px}
  .su-meta{
    display:flex;flex-direction:column;align-items:flex-end;gap:4px;
    text-align:right;
  }
  .su-amount{
    font-family:var(--font-mono);font-size:14px;color:var(--fg);
    font-variant-numeric:tabular-nums;
  }
  .su-delta{
    font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.08em;color:var(--fg-mute);
  }
  .su-delta--gold{color:var(--accent)}
  .su-delta--alarm{color:var(--alarm)}
  .su-delta--faint{color:var(--fg-faint)}

  .su-detail{
    display:grid;grid-template-columns:1.2fr 1fr;
    gap:clamp(24px,4vw,48px);
    padding:8px 0 32px 52px;
    border-top:1px solid var(--rule-soft);
  }
  .su-detail-bar{position:relative;height:200px}
  .su-detail-tbl-wrap{font-family:var(--font-mono);font-size:12px;color:var(--fg-dim)}
  table.su-yr{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
  .su-yr th{
    text-align:right;padding:6px 0;
    font-family:var(--font-body);font-weight:500;font-size:10px;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
    border-bottom:1px solid var(--rule-soft);
  }
  .su-yr th:first-child{text-align:left}
  .su-yr td{padding:6px 0;border-bottom:1px solid var(--rule-soft)}
  .su-yr td:last-child{text-align:right;color:var(--fg)}
  .su-yr td:first-child{color:var(--fg-mute)}
  .su-yr tr.hist td:last-child{font-style:italic;color:var(--fg-faint)}
  .su-yr tr.hist td:first-child::after{
    content:" geschat";color:var(--fg-faint);font-size:10px;
    text-transform:uppercase;letter-spacing:0.12em;margin-left:6px;
  }
  .su-yr tr.divider td{
    border-bottom:0;padding-top:14px;padding-bottom:6px;
    font-family:var(--font-body);font-size:10px;font-weight:500;
    letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-mute);
    text-align:left !important;
  }
  .su-yr tr.hi td{color:var(--accent);font-weight:500}
  .su-yr tr.hi td:first-child::after{content:""}

  .su-context h5{
    font-family:var(--font-body);font-size:10px;font-weight:500;
    letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-mute);
    margin:0 0 10px;
  }
  .su-context p{
    font-family:var(--font-body);font-size:14px;color:var(--fg-dim);
    line-height:1.55;margin:0 0 12px;max-width:46ch;
  }
  .su-context .su-source{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
    margin-top:14px;
  }

  .su-empty{
    padding:32px 0;text-align:center;
    font-family:var(--font-mono);font-size:12px;color:var(--fg-mute);
  }

  @media (max-width:820px){
    details.su-row summary{grid-template-columns:24px 1fr auto;gap:14px}
    .su-mini{display:none}
    .su-detail{grid-template-columns:1fr;padding-left:0}
  }

  /* ========== §08 Per programma ========== */
  .pg-intro{
    background:var(--bg-elev);
    border:1px solid var(--rule);
    padding:clamp(32px,4vw,56px);
    margin-bottom:clamp(48px,6vw,72px);
    display:grid;grid-template-columns:repeat(3,1fr);
    gap:clamp(24px,3vw,48px);
  }
  .pg-intro-cell{
    border-left:1px solid var(--rule);padding-left:clamp(24px,3vw,36px);
  }
  .pg-intro-cell:first-child{border-left:0;padding-left:0}
  .pg-intro-num{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(32px,4vw,52px);letter-spacing:-0.025em;line-height:1;
    color:var(--fg);font-variant-numeric:tabular-nums;
  }
  .pg-intro-num--alarm{color:var(--alarm)}
  .pg-intro-num--gold{color:var(--accent)}
  .pg-intro-lbl{
    font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
    margin-top:12px;
  }
  .pg-intro-sub{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);margin-top:6px;
  }
  @media (max-width:820px){
    .pg-intro{grid-template-columns:1fr}
    .pg-intro-cell{border-left:0;padding-left:0;border-top:1px solid var(--rule);padding-top:20px}
    .pg-intro-cell:first-child{border-top:0;padding-top:0}
  }

  .pg-list{border-top:1px solid var(--rule)}
  details.pg-row{border-bottom:1px solid var(--rule-soft);scroll-margin-top:80px}
  details.pg-row summary{
    display:grid;grid-template-columns:36px 1fr auto;gap:24px;align-items:baseline;
    padding:22px 0;cursor:pointer;list-style:none;
  }
  details.pg-row summary::-webkit-details-marker{display:none}
  .pg-rank{
    font-family:var(--font-mono);font-size:12px;color:var(--fg-mute);
    font-variant-numeric:tabular-nums;
  }
  .pg-name-wrap{
    display:flex;flex-direction:column;gap:4px;
  }
  .pg-name{
    font-family:var(--font-display);font-weight:400;
    font-size:clamp(19px,2vw,24px);letter-spacing:-0.02em;color:var(--fg);
  }
  .pg-name-sub{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
  }
  .pg-saldo-wrap{
    display:flex;flex-direction:column;align-items:flex-end;gap:4px;text-align:right;
  }
  .pg-saldo{
    font-family:var(--font-display);font-weight:300;font-size:clamp(19px,2vw,24px);
    letter-spacing:-0.02em;color:var(--fg);font-variant-numeric:tabular-nums;
    display:flex;align-items:baseline;gap:8px;
  }
  .pg-saldo--in{color:var(--accent)}
  .pg-saldo-lbl{
    font-family:var(--font-body);font-size:10px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
  }
  .pg-est{
    font-family:var(--font-body);font-size:9px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;
    color:var(--fg-mute);border:1px solid var(--rule);
    padding:1px 6px;
  }
  .pg-chev{
    font-family:var(--font-mono);font-size:18px;color:var(--fg-mute);
    transition:transform var(--dur-fast) var(--ease);
  }
  details.pg-row[open] .pg-chev{transform:rotate(90deg);color:var(--accent)}

  .pg-body{
    padding:8px 0 32px 60px;
    display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(24px,4vw,48px);
  }
  .pg-context p{
    font-family:var(--font-body);font-size:14px;color:var(--fg-dim);
    line-height:1.6;margin:0 0 12px;max-width:48ch;
  }
  .pg-context .pg-note{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);margin-top:8px;
  }

  table.pg-sub{width:100%;border-collapse:collapse}
  .pg-sub th{
    text-align:left;padding:10px 14px 10px 0;
    border-bottom:1px solid var(--rule);
    font-family:var(--font-body);font-weight:500;font-size:10px;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
  }
  .pg-sub th.num{text-align:right}
  .pg-sub td{
    padding:12px 14px 12px 0;border-bottom:1px solid var(--rule-soft);
    font-family:var(--font-body);font-size:13px;color:var(--fg);
    vertical-align:top;
  }
  .pg-sub td.num{
    text-align:right;font-family:var(--font-mono);
    font-variant-numeric:tabular-nums;
  }
  .pg-sub td.num--in{color:var(--accent)}
  .pg-sub td:last-child,.pg-sub th:last-child{padding-right:0}
  .pg-sub tfoot td{
    border-top:1px solid var(--rule);border-bottom:0;
    padding-top:14px;
    font-family:var(--font-body);font-weight:500;font-size:11px;
    letter-spacing:0.12em;text-transform:uppercase;color:var(--fg);
  }
  .pg-sub tfoot td.num{
    font-family:var(--font-mono);font-weight:400;font-size:14px;
    letter-spacing:0;text-transform:none;
  }
  .pg-sub-code{font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);margin-right:10px}

  @media (max-width:820px){
    details.pg-row summary{grid-template-columns:32px 1fr;grid-template-rows:auto auto;gap:12px}
    .pg-saldo-wrap{grid-column:1/3;align-items:flex-start;text-align:left}
    .pg-body{grid-template-columns:1fr;padding-left:0}
  }

  /* ========== Footer ========== */
  footer.foot{
    background:var(--bg);color:var(--fg-dim);
    padding:clamp(60px,8vw,96px) 0 40px;
    border-top:1px solid var(--rule);
  }
  .foot-grid{
    display:grid;grid-template-columns:1.2fr 1fr 1fr;
    gap:clamp(32px,5vw,72px);
  }
  .foot h4{
    font-family:var(--font-body);font-size:12px;font-weight:500;
    letter-spacing:0.16em;text-transform:uppercase;
    color:var(--fg-mute);margin:0 0 18px;
  }
  .foot p, .foot li{font-size:14px;color:var(--fg-dim);line-height:1.6;margin:0}
  .foot ul{list-style:none;padding:0;margin:0}
  .foot li{margin-bottom:8px}
  .foot a{border-bottom:1px solid var(--rule)}
  .foot a:hover{border-bottom-color:var(--accent)}
  .foot-brand{
    font-family:var(--font-display);font-size:40px;font-weight:300;
    letter-spacing:-0.03em;line-height:1;color:var(--fg);
    display:flex;align-items:baseline;gap:6px;
  }
  .foot-brand-dot{
    width:6px;height:6px;border-radius:50%;background:var(--accent);
    display:inline-block;transform:translateY(-4px);
  }
  .foot-brand-sub{
    font-family:var(--font-body);font-size:12px;
    letter-spacing:0.14em;text-transform:uppercase;
    color:var(--fg-mute);margin-top:14px;
  }
  .foot-disclaimer{
    margin-top:clamp(48px,6vw,72px);padding-top:24px;
    border-top:1px solid var(--rule);
    font-size:12px;color:var(--fg-mute);letter-spacing:0.04em;
    display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  }
  @media (max-width:820px){ .foot-grid{grid-template-columns:1fr} }

  /* ========== §01 Belastingdruk ========== */
  /* §08 hergebruikt .ov-mega, .ov-context/.ov-cx en .ov-rows uit §01.
     De eigen onderdelen hieronder: stacked afdracht-bar + itemized trap. */
  .bd-block-head{
    display:flex;justify-content:space-between;align-items:baseline;
    flex-wrap:wrap;gap:16px;
    margin:clamp(48px,6vw,72px) 0 24px;
    padding-bottom:16px;border-bottom:1px solid var(--rule);
  }
  .bd-block-title{
    font-family:var(--font-display);font-weight:400;
    font-size:clamp(20px,2vw,24px);letter-spacing:-0.02em;color:var(--fg);
  }
  .bd-block-sub{
    font-family:var(--font-body);font-size:12px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);
  }

  /* Stacked afdracht-bar — van loonkosten naar besteedbaar */
  .bd-bar{
    display:flex;width:100%;height:64px;overflow:hidden;
    border:1px solid var(--rule);
  }
  .bd-seg{
    display:flex;align-items:flex-end;
    padding:8px 10px;min-width:0;width:0;
    border-right:1px solid var(--bg);
    font-family:var(--font-mono);font-size:11px;
    font-variant-numeric:tabular-nums;line-height:1.2;
    overflow:hidden;white-space:nowrap;
    transition:width var(--dur-slow) var(--ease);
  }
  .bd-bar.in .bd-seg{width:var(--w)}
  .bd-seg:last-child{border-right:0}
  .bd-seg--p1{background:var(--gg-blood-dark);color:var(--gg-bone)}
  .bd-seg--p2{background:var(--gg-blood);color:var(--gg-bone)}
  .bd-seg--p3{background:var(--gg-gold-dark);color:var(--gg-black)}
  .bd-seg--keep{background:var(--gg-bone);color:var(--gg-black)}
  .bd-seg-pct{font-weight:500}
  .bd-legend{
    display:grid;grid-template-columns:repeat(4,1fr);
    gap:0;margin-top:20px;border-top:1px solid var(--rule);
  }
  .bd-leg{
    padding:18px 18px 18px 0;border-right:1px solid var(--rule-soft);
    display:flex;flex-direction:column;gap:6px;
  }
  .bd-leg:last-child{border-right:0}
  .bd-leg-key{
    display:flex;align-items:center;gap:8px;
    font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.12em;text-transform:uppercase;color:var(--fg-mute);
  }
  .bd-leg-dot{width:10px;height:10px;flex-shrink:0;display:inline-block}
  .bd-leg-dot--p1{background:var(--gg-blood-dark)}
  .bd-leg-dot--p2{background:var(--gg-blood)}
  .bd-leg-dot--p3{background:var(--gg-gold-dark)}
  .bd-leg-dot--keep{background:var(--gg-bone)}
  .bd-leg-num{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(22px,2.4vw,30px);letter-spacing:-0.02em;line-height:1;
    color:var(--fg);font-variant-numeric:tabular-nums;
  }
  .bd-leg-sub{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint)}
  @media (max-width:820px){
    .bd-bar{height:auto;flex-direction:column}
    .bd-seg{width:100% !important;height:44px;align-items:center}
    .bd-seg{border-right:0;border-bottom:1px solid var(--bg)}
    .bd-legend{grid-template-columns:1fr 1fr}
    .bd-leg{padding:16px 14px 16px 0}
    .bd-leg:nth-child(even){border-right:0}
  }

  /* Itemized trap — loonkosten → reëel besteedbaar */
  .bd-trap{border-top:1px solid var(--rule);margin-top:8px}
  .bd-step{
    display:grid;grid-template-columns:auto 1fr auto;
    gap:18px;align-items:baseline;
    padding:15px 0;border-bottom:1px solid var(--rule-soft);
  }
  .bd-step-op{
    font-family:var(--font-mono);font-size:13px;color:var(--fg-mute);
    width:14px;text-align:center;
  }
  .bd-step-name{font-family:var(--font-body);font-size:15px;color:var(--fg-dim)}
  .bd-step-name span{
    display:block;font-family:var(--font-mono);font-size:10px;
    color:var(--fg-faint);margin-top:2px;letter-spacing:0.04em;
  }
  .bd-step-num{
    font-family:var(--font-mono);font-size:14px;color:var(--fg);
    font-variant-numeric:tabular-nums;
  }
  .bd-step--tax .bd-step-op{color:var(--alarm)}
  .bd-step--tax .bd-step-num{color:var(--alarm)}
  .bd-step--mid{background:rgba(255,255,255,0.015)}
  .bd-step--mid .bd-step-name{color:var(--fg)}
  .bd-step--sum{
    border-bottom:0;border-top:1px solid var(--rule);margin-top:6px;
    padding-top:20px;align-items:baseline;
  }
  .bd-step--sum .bd-step-name{
    font-family:var(--font-display);font-style:italic;font-weight:300;
    font-size:clamp(17px,1.8vw,21px);color:var(--fg);
  }
  .bd-step--sum .bd-step-num{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(22px,2.4vw,30px);letter-spacing:-0.02em;
    color:var(--accent);
  }
  .bd-note{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
    margin:18px 0 0;max-width:90ch;line-height:1.55;
  }
  @media (max-width:820px){
    .bd-step{grid-template-columns:14px 1fr;grid-template-rows:auto auto}
    .bd-step-num{grid-column:1 / 3;text-align:left;padding-left:32px}
  }

  /* Nested doughnut — privé vs overheid + bestemming */
  .bd-chart{
    display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);
    gap:clamp(32px,5vw,64px);align-items:center;margin-bottom:8px;
  }
  .bd-chart-figure{
    position:relative;width:100%;max-width:400px;margin:0 auto;aspect-ratio:1/1;
  }
  .bd-chart-center{
    position:absolute;inset:0;display:flex;flex-direction:column;
    align-items:center;justify-content:center;text-align:center;pointer-events:none;
  }
  .bd-chart-center-num{
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(26px,3.2vw,40px);letter-spacing:-0.02em;line-height:1;
    color:var(--fg);font-variant-numeric:tabular-nums;
  }
  .bd-chart-center-lbl{
    font-family:var(--font-body);font-size:10px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);margin-top:8px;
  }
  .bd-legend2{display:flex;flex-direction:column}
  .bd-l2-split{
    display:flex;gap:clamp(20px,3vw,32px);
    padding-bottom:18px;margin-bottom:6px;border-bottom:1px solid var(--rule);
  }
  .bd-l2-item{flex:1;display:flex;flex-direction:column;gap:6px}
  .bd-l2-cap{
    font-family:var(--font-body);font-size:10px;font-weight:500;
    letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-mute);
    margin:16px 0 4px;
  }
  .bd-l2-row{
    display:grid;grid-template-columns:12px 1fr auto auto;gap:14px;align-items:center;
    padding:8px 0;border-bottom:1px solid var(--rule-soft);
  }
  .bd-l2-row:last-child{border-bottom:0}
  .bd-l2-dot{width:10px;height:10px;display:inline-block}
  .bd-l2-name{font-family:var(--font-body);font-size:13px;color:var(--fg-dim)}
  .bd-l2-eur{
    font-family:var(--font-mono);font-size:12px;color:var(--fg);
    font-variant-numeric:tabular-nums;text-align:right;
  }
  .bd-l2-pct{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-mute);
    font-variant-numeric:tabular-nums;text-align:right;min-width:44px;
  }
  .bd-l2-local{
    display:flex;flex-direction:column;gap:6px;
    margin:14px 0 2px;padding:14px 16px;
    background:rgba(201,169,97,0.07);
    border-left:2px solid var(--accent);
  }
  .bd-l2-local .bd-leg-key{color:var(--fg)}
  .bd-chart-mark{
    position:absolute;top:2%;left:0;
    font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);
    line-height:1.3;text-align:left;pointer-events:none;
  }
  .bd-chart-mark span{
    display:block;font-family:var(--font-mono);font-size:11px;
    letter-spacing:0;text-transform:none;color:var(--fg-mute);margin-top:2px;
  }

  /* Calculator controls */
  .bd-calc{
    display:grid;grid-template-columns:1.4fr 1fr;
    gap:clamp(28px,5vw,64px);align-items:start;
    border:1px solid var(--rule);background:var(--bg);
    padding:clamp(24px,3vw,36px);margin-bottom:clamp(32px,4vw,48px);
  }
  .bd-calc label{
    display:block;font-family:var(--font-body);font-size:11px;font-weight:500;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:10px;
  }
  .bd-calc-input{
    display:flex;align-items:baseline;gap:8px;
    border-bottom:1px solid var(--rule);padding-bottom:8px;
  }
  .bd-calc-input:focus-within{border-bottom-color:var(--accent)}
  .bd-calc-input span{
    font-family:var(--font-display);font-weight:300;font-size:clamp(26px,3vw,38px);color:var(--fg-mute);
  }
  .bd-calc-input input{
    background:transparent;border:0;outline:0;width:100%;
    font-family:var(--font-display);font-weight:300;
    font-size:clamp(30px,3.6vw,46px);letter-spacing:-0.02em;color:var(--fg);
    font-variant-numeric:tabular-nums;
  }
  .bd-calc-input input::-webkit-outer-spin-button,
  .bd-calc-input input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
  #bdRange{
    -webkit-appearance:none;appearance:none;width:100%;height:2px;
    background:var(--rule);margin:22px 0 18px;cursor:pointer;
  }
  #bdRange::-webkit-slider-thumb{
    -webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;
    background:var(--accent);cursor:pointer;border:0;
  }
  #bdRange::-moz-range-thumb{
    width:16px;height:16px;border-radius:50%;background:var(--accent);border:0;cursor:pointer;
  }
  .bd-presets{display:flex;flex-wrap:wrap;gap:0}
  .bd-presets button,.bd-toggle button{
    font-family:var(--font-body);font-size:12px;font-weight:500;
    letter-spacing:0.06em;color:var(--fg-mute);background:transparent;
    border:1px solid var(--rule);padding:8px 14px;margin:0 8px 8px 0;cursor:pointer;
    transition:color var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease);
  }
  .bd-presets button:hover,.bd-toggle button:hover{color:var(--fg);border-color:var(--fg-faint)}
  .bd-presets button.active,.bd-toggle button.active{color:var(--gg-black);background:var(--accent);border-color:var(--accent)}
  .bd-presets button:focus-visible,.bd-toggle button:focus-visible{outline:2px solid var(--focus);outline-offset:2px}
  .bd-toggle{display:flex;gap:0}
  .bd-toggle button{margin-right:0;border-right:0}
  .bd-toggle button:last-child{border-right:1px solid var(--rule)}
  .bd-toggle button.active{border-color:var(--accent)}
  .bd-stepper{display:flex;align-items:center;gap:0;width:fit-content}
  .bd-stepper button{
    font-family:var(--font-mono);font-size:18px;color:var(--fg);background:transparent;
    border:1px solid var(--rule);width:40px;height:40px;cursor:pointer;line-height:1;
    transition:border-color var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease);
  }
  .bd-stepper button:hover{border-color:var(--accent);color:var(--accent)}
  .bd-stepper span{
    font-family:var(--font-display);font-weight:300;font-size:24px;color:var(--fg);
    min-width:52px;text-align:center;font-variant-numeric:tabular-nums;
    border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);height:40px;
    display:flex;align-items:center;justify-content:center;
  }

  /* Legend extra rows: toeslagen-terug + netto bijdrage */
  .bd-l2-back{
    display:flex;flex-direction:column;gap:6px;
    margin:6px 0 0;padding:14px 16px;
    background:rgba(79,143,99,0.08);border-left:2px solid #4f8f63;
  }
  .bd-l2-back .bd-leg-num{color:#6fae86}
  .bd-l2-net{
    display:flex;flex-direction:column;gap:6px;
    margin:8px 0 2px;padding:16px 16px;
    background:rgba(255,255,255,0.02);border-top:1px solid var(--rule);
  }
  .bd-l2-net .bd-leg-key{color:var(--fg)}
  .bd-l2-net .bd-leg-num{color:var(--fg)}
  .bd-step--back .bd-step-op,.bd-step--back .bd-step-num{color:#6fae86}
  .bd-calc-hint{
    font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);
    line-height:1.5;margin:16px 0 0;max-width:42ch;
  }
  .bd-calc-input--sm span{font-size:18px}
  .bd-calc-input--sm input{font-size:clamp(20px,2.2vw,26px)}
  .bd-koop-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
  @media (max-width:520px){ .bd-koop-grid{grid-template-columns:1fr} }

  /* Lijngrafiek — % overhouden vs % naar overheid per inkomen */
  .bd-line-legend{
    display:flex;gap:24px;flex-wrap:wrap;margin:2px 0 18px;
  }
  .bd-line-key{
    display:flex;align-items:center;gap:8px;
    font-family:var(--font-body);font-size:12px;font-weight:500;
    letter-spacing:0.08em;color:var(--fg-dim);
  }
  .bd-line-key i{width:18px;height:2px;display:inline-block}
  .bd-line{position:relative;height:360px;width:100%}
  @media (max-width:820px){ .bd-line{height:300px} }

  @media (max-width:820px){
    .bd-calc{grid-template-columns:1fr;gap:28px}
    .bd-chart{grid-template-columns:1fr;gap:32px}
    .bd-chart-figure{max-width:300px}
    .bd-l2-split{flex-direction:column;gap:16px}
  }

  /* ========== Motion ========== */
  .rise{
    opacity:0;transform:translateY(14px);
    transition:opacity var(--dur-slow) var(--ease),transform var(--dur-slow) var(--ease);
  }
  .rise.in{opacity:1;transform:none}
  .rise.d1{transition-delay:80ms}
  .rise.d2{transition-delay:160ms}
  .rise.d3{transition-delay:240ms}
  .rise.d4{transition-delay:320ms}

  @media (prefers-reduced-motion:reduce){
    .rise{opacity:1;transform:none;transition:none}
    html{scroll-behavior:auto}
  }

/* ========== Subsidie-dossier kaart (link naar eigen pagina) ========== */
.sub-cards{display:grid;gap:16px;margin-top:8px}
.sub-card{
  display:block;text-decoration:none;color:inherit;
  border:1px solid var(--rule);padding:28px 32px;
  background:rgba(255,255,255,0.012);transition:border-color .2s,background .2s;
}
.sub-card:hover{border-color:var(--accent);background:rgba(201,169,97,0.04)}
.sub-card-head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;flex-wrap:wrap}
.sub-card-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--fg-mute)}
.sub-card-cta{font-family:var(--font-mono);font-size:12px;color:var(--accent)}
.sub-card-title{font-family:var(--font-display);font-weight:300;font-size:clamp(26px,3vw,34px);color:var(--fg);margin:10px 0 6px}
.sub-card-desc{font-family:var(--font-body);font-size:15px;line-height:1.6;color:var(--fg-dim);max-width:72ch;margin:0 0 20px}
.sub-card-stats{display:flex;flex-wrap:wrap;gap:24px;border-top:1px solid var(--rule-soft);padding-top:18px}
.sub-card-stats span{font-family:var(--font-mono);font-size:12px;color:var(--fg-mute)}
.sub-card-stats strong{color:var(--accent);font-weight:500}
