/* Finance MCP — marketingsite v3 "Grootboek".
   Verfijnd editorial/ledger-ontwerp. Huisstijl B-28: Grootboekblauw #16324F,
   Saldogroen #15A38B. Self-hosted fonts (AVG: geen externe font-calls).
   Eén contentbreedte (--maxb) en één gootmaat (--pad) over de hele site, zodat
   banden en tekst overal even breed uitlijnen. Geen frameworks, geen inline
   styles (CSP: style-src 'self'). */

/* ── Fonts (variabel, self-hosted) ──────────────────────────────────────── */
@font-face {
  font-family: "Fraunces";
  src: url("/assets/fonts/fraunces-var.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Fraunces";
  src: url("/assets/fonts/fraunces-italic-var.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Hanken Grotesk";
  src: url("/assets/fonts/hanken-var.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --blauw: #16324F;
  --blauw-d: #0d1f33;
  --blauw-l: #24557d;
  --groen: #15A38B;
  --groen-d: #0c7d6a;
  --groen-l: #43c9af;

  --ink: #16242f;
  --muted: #5a6772;
  --paper: #faf8f3;        /* warm grootboekpapier */
  --paper-2: #f2eee4;
  --kaart: #ffffff;
  --rule: #e6e0d2;         /* warme liniaal */
  --rule-koel: #d6dee6;

  --maxb: 76rem;
  --pad: clamp(1.25rem, 5vw, 4.5rem);
  --rad: 14px;
  --rad-s: 9px;
  --schaduw: 0 18px 50px -24px rgb(13 31 51 / .35);
  --schaduw-s: 0 2px 14px -6px rgb(13 31 51 / .25);

  --display: "Fraunces", Georgia, "Times New Roman", serif;
  --sans: "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono: ui-monospace, "SFMono-Regular", "Cascadia Code", Menlo, monospace;

  --vt: cubic-bezier(.22, .61, .36, 1);
}

@view-transition { navigation: auto; }
::view-transition-old(root) { animation: vt-uit .2s var(--vt) both; }
::view-transition-new(root) { animation: vt-in .32s var(--vt) both; }
@keyframes vt-uit { to { opacity: 0; transform: translateY(-8px); } }
@keyframes vt-in { from { opacity: 0; transform: translateY(12px); } }

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--sans);
  font-weight: 400;
  color: var(--ink);
  line-height: 1.62;
  background: var(--paper);
  font-feature-settings: "ss01";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Subtiele grootboek-liniatuur achter de hele pagina */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(60rem 32rem at 88% -8%, rgb(21 163 139 / .10), transparent 62%),
    radial-gradient(48rem 30rem at -8% 8%, rgb(22 50 79 / .07), transparent 60%),
    var(--paper);
}

img, svg { max-width: 100%; }
::selection { background: var(--groen); color: #fff; }

/* ── Typografie ──────────────────────────────────────────────────────────── */
h1, h2, h3 { font-family: var(--display); color: var(--blauw); font-weight: 560; line-height: 1.08; margin: 0 0 .6rem; letter-spacing: -.012em; }
h1 { font-size: clamp(2.5rem, 6vw, 4.4rem); font-weight: 540; letter-spacing: -.02em; }
h2 { font-size: clamp(1.8rem, 3.6vw, 2.7rem); }
h3 { font-size: 1.2rem; font-weight: 600; letter-spacing: -.005em; }
p { margin: 0 0 1rem; }
strong { font-weight: 650; color: var(--blauw); }

.lead { font-size: clamp(1.1rem, 1.7vw, 1.32rem); color: var(--muted); line-height: 1.55; max-width: 56ch; }
.band.donker .lead { color: #cfdae5; }
.optioneel { font-weight: 400; color: #9fb0bf; }
.eyebrow {
  font-family: var(--mono);
  font-size: .76rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--groen-d);
  margin: 0 0 1.1rem;
  display: flex;
  align-items: center;
  gap: .7rem;
}
.eyebrow::before { content: ""; width: 1.6rem; height: 2px; background: var(--groen); display: inline-block; }

a { color: var(--groen-d); text-underline-offset: .18em; text-decoration-thickness: 1px; }
a:hover { color: var(--groen); }

/* ── Eén breedte: banden full-bleed, .binnen overal gelijk uitgelijnd ────── */
.band { padding-block: clamp(3rem, 7vw, 5.5rem); position: relative; }
.binnen { max-width: var(--maxb); margin-inline: auto; padding-inline: var(--pad); }

.band.papier, .band.fond { background: var(--paper-2); border-block: 1px solid var(--rule); }
.band.donker {
  background:
    radial-gradient(50rem 30rem at 80% 0%, rgb(21 163 139 / .22), transparent 60%),
    linear-gradient(165deg, var(--blauw-d), var(--blauw) 60%, var(--blauw-l));
  color: #cfdae5;
}
.band.donker h2, .band.donker h3 { color: #fff; }
.band.donker a:not(.button) { color: var(--groen-l); }

/* dunne grootboek-scheidingsregel met margekleur */
.regel { border: 0; height: 1px; background: var(--rule); max-width: var(--maxb); margin: 0 auto; }

/* ── Header: rustige glasbalk, inhoud uitgelijnd op --pad ────────────────── */
.site-header {
  position: sticky; top: 0; z-index: 30;
  background: rgb(250 248 243 / .82);
  backdrop-filter: blur(12px) saturate(1.5);
  -webkit-backdrop-filter: blur(12px) saturate(1.5);
  border-bottom: 1px solid var(--rule);
}
.site-header > .balk {
  max-width: var(--maxb); margin-inline: auto; padding: .7rem var(--pad);
  display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
}
.logo-link { display: inline-flex; line-height: 0; }
.site-header nav { display: flex; gap: .15rem; flex-wrap: wrap; align-items: center; }
.site-header nav a {
  color: var(--blauw); text-decoration: none; font-weight: 550; font-size: .96rem;
  padding: .4rem .78rem; border-radius: var(--rad-s);
  transition: background .16s, color .16s;
}
.site-header nav a:hover { background: rgb(22 50 79 / .07); color: var(--groen-d); }
.site-header nav a.actief { color: var(--groen-d); }
.site-header nav a.cta {
  background: var(--blauw); color: #fff; margin-left: .35rem;
}
.site-header nav a.cta:hover { background: var(--blauw-l); color: #fff; }
/* Hamburger: knop verborgen op desktop, menu klapt uit op mobiel. */
.nav-toggle { display: none; background: none; border: 0; padding: .4rem; color: var(--blauw); cursor: pointer; line-height: 0; border-radius: var(--rad-s); }
.nav-toggle:hover { background: rgb(22 50 79 / .07); }
@media (max-width: 760px) {
  .site-header > .balk { flex-wrap: nowrap; }
  .nav-toggle { display: inline-flex; }
  .site-header nav {
    display: none; position: absolute; top: 100%; left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: .1rem; flex-wrap: nowrap;
    background: var(--paper); border-bottom: 1px solid var(--rule);
    padding: .5rem var(--pad) 1.1rem; box-shadow: 0 22px 34px -22px rgba(13, 31, 51, .35);
  }
  .site-header nav.open { display: flex; }
  .site-header nav a { padding: .7rem .8rem; font-size: 1rem; }
  .site-header nav a.cta { margin-left: 0; text-align: center; margin-top: .25rem; }
}

/* ── Knoppen ─────────────────────────────────────────────────────────────── */
.cta-row { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: 1.8rem; }
.button {
  --bg: #fff; --fg: var(--blauw); --bd: var(--rule);
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .8rem 1.4rem; border-radius: var(--rad-s);
  border: 1.5px solid var(--bd); background: var(--bg); color: var(--fg);
  text-decoration: none; font-family: var(--sans); font-weight: 600; font-size: 1rem;
  cursor: pointer; line-height: 1.2;
  transition: transform .16s var(--vt), box-shadow .16s, background .16s, border-color .16s;
}
.button:hover { transform: translateY(-2px); box-shadow: var(--schaduw-s); }
.button.primary { --bg: var(--groen); --fg: #fff; --bd: var(--groen); box-shadow: 0 10px 26px -10px rgb(21 163 139 / .7); }
.button.primary:hover { --bg: var(--groen-d); --bd: var(--groen-d); }
.button.invert { --bg: transparent; --fg: #fff; --bd: rgb(255 255 255 / .4); }
.button.invert:hover { --bg: rgb(255 255 255 / .1); }
.button .pijl { transition: transform .18s var(--vt); }
.button:hover .pijl { transform: translateX(3px); }

/* ── Hero ────────────────────────────────────────────────────────────────── */
.hero { overflow: clip; padding-block: clamp(2.5rem, 6vw, 5rem); }
.hero .binnen {
  display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
  gap: clamp(1.5rem, 4vw, 3.5rem); align-items: center;
}
.hero h1 { margin-bottom: 1.1rem; }
.hero h1 em { font-style: italic; color: var(--groen-d); font-weight: 500; }
.hero-kaart {
  background: linear-gradient(180deg, #fff, var(--paper));
  border: 1px solid var(--rule); border-radius: var(--rad);
  box-shadow: var(--schaduw);
  padding: clamp(2.1rem, 4vw, 3rem) clamp(1.1rem, 2.5vw, 1.8rem) clamp(1.1rem, 2.5vw, 1.8rem);
  position: relative;
}
.hero-kaart::before {
  content: "grootboek → AI";
  position: absolute; top: -1rem; left: 1.4rem;
  font-family: var(--mono); font-size: .95rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  color: var(--groen-d); background: var(--paper); padding: 0 .65rem;
}
@media (max-width: 880px) { .hero .binnen { grid-template-columns: 1fr; } .hero-kaart { order: -1; } }

/* Geanimeerd koppeling-motief (zes bronnen → knooppunt → uitgang, B-28) */
.hero-visual { width: 100%; height: auto; display: block; }
.hero-visual .bron {
  stroke: var(--blauw); stroke-width: 2.2; fill: none; stroke-linecap: round;
  stroke-dasharray: 620; animation: tekenen 1.3s var(--vt) backwards;
}
.hero-visual .bron:nth-child(2) { animation-delay: .12s; }
.hero-visual .bron:nth-child(3) { animation-delay: .24s; }
.hero-visual .bron:nth-child(4) { animation-delay: .36s; }
.hero-visual .bron:nth-child(5) { animation-delay: .48s; }
.hero-visual .bron:nth-child(6) { animation-delay: .60s; }
.hero-visual .bron:nth-child(7) { animation-delay: .72s; }
.hero-visual .bron:nth-child(8) { animation-delay: .84s; }
.hero-visual .uitgang { stroke: var(--groen); stroke-width: 3.4; fill: none; stroke-linecap: round; stroke-dasharray: 620; animation: tekenen .9s var(--vt) .9s backwards; }
.hero-visual .knoop { fill: #fff; stroke: var(--groen); stroke-width: 6; transform-origin: center; transform-box: fill-box; animation: pulseren 3.4s ease-in-out 1.8s infinite; }
.hero-visual .knoopring { fill: none; stroke: rgb(21 163 139 / .22); stroke-width: 14; }
.hero-visual .chip rect { fill: #fff; stroke: var(--rule); }
.hero-visual .chip text { font: 600 13px var(--sans); fill: var(--blauw); }
.hero-visual .chip.accent rect { fill: var(--blauw); stroke: var(--blauw); }
.hero-visual .chip.accent text { fill: #fff; }
@keyframes tekenen { from { stroke-dashoffset: 620; } }
@keyframes pulseren { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.13); } }

/* kerngetallen onder de hero */
.kerncijfers { display: flex; flex-wrap: wrap; gap: 1.6rem 2.6rem; margin-top: 2.2rem; padding-top: 1.6rem; border-top: 1px solid var(--rule); }
.kerncijfers div { display: grid; }
.kerncijfers dt { font-family: var(--display); font-size: 1.9rem; font-weight: 560; color: var(--blauw); line-height: 1; font-feature-settings: "tnum"; }
.kerncijfers dd { margin: .35rem 0 0; font-size: .9rem; color: var(--muted); }

/* ── Sectiekop ───────────────────────────────────────────────────────────── */
.sectiekop { max-width: 66ch; margin-bottom: clamp(1.8rem, 4vw, 2.8rem); }
.sectiekop p { color: var(--muted); font-size: 1.08rem; max-width: 66ch; }

/* Tweekolomsindeling die de volle breedte benut (tekst links, kaarten/visual rechts) */
.split { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
@media (max-width: 820px) { .split { grid-template-columns: 1fr; } }
.navkaarten { display: grid; gap: 1rem; }
.navkaart { position: relative; display: block; background: var(--kaart); border: 1px solid var(--rule); border-radius: var(--rad); padding: 1.5rem 3.2rem 1.5rem 1.6rem; text-decoration: none; box-shadow: var(--schaduw-s); transition: transform .2s var(--vt), box-shadow .2s, border-color .2s; }
.navkaart:hover { transform: translateY(-3px); box-shadow: var(--schaduw); border-color: var(--groen); }
.navkaart h3 { margin-bottom: .3rem; }
.navkaart p { margin: 0; color: var(--muted); }
.navkaart .navpijl { position: absolute; right: 1.4rem; top: 1.5rem; color: var(--groen-d); font-size: 1.3rem; transition: transform .18s var(--vt); }
.navkaart:hover .navpijl { transform: translateX(4px); }

/* Inzet-band (bijv. prijzen: aankondiging + inschrijven) met lucht eromheen */
.opmerking-band { margin-top: clamp(2rem, 4vw, 3rem); background: #fff; border: 1px solid var(--rule); border-left: 4px solid var(--groen); border-radius: var(--rad); padding: clamp(1.4rem, 3vw, 2.1rem); box-shadow: var(--schaduw-s); }
.opmerking-band p { margin: 0; color: var(--muted); max-width: 74ch; }
.opmerking-band .cta-row { margin-top: 1.3rem; }

/* ── Genummerde grootboek-rijen ─────────────────────────────────────────── */
.grootboek { list-style: none; margin: 0; padding: 0; border-top: 1px solid var(--rule); }
.grootboek li {
  display: grid; grid-template-columns: 4.5rem 1fr; gap: 1.4rem;
  padding: 1.6rem 0; border-bottom: 1px solid var(--rule); align-items: start;
}
.grootboek .nr { font-family: var(--display); font-size: 1.5rem; color: var(--groen-d); font-feature-settings: "tnum"; font-weight: 500; }
.grootboek h3 { margin-bottom: .35rem; }
.grootboek p { margin: 0; color: var(--muted); max-width: 58ch; }
@media (max-width: 560px) { .grootboek li { grid-template-columns: 1fr; gap: .3rem; } }

/* ── Kaarten ─────────────────────────────────────────────────────────────── */
.kaarten { display: grid; gap: 1.1rem; grid-template-columns: repeat(auto-fit, minmax(15.5rem, 1fr)); margin: 0; padding: 0; list-style: none; }
/* Vaste 3 kolommen (bijv. zes blokken → nette 3×2 over de volle breedte) */
.kaarten.kol-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 900px) { .kaarten.kol-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) { .kaarten.kol-3 { grid-template-columns: 1fr; } }
.kaart {
  background: var(--kaart); border: 1px solid var(--rule); border-radius: var(--rad);
  padding: 1.5rem 1.55rem; box-shadow: var(--schaduw-s);
  transition: transform .2s var(--vt), box-shadow .2s, border-color .2s;
}
.kaart:hover { transform: translateY(-4px); box-shadow: var(--schaduw); border-color: var(--rule-koel); }
.kaart .icoon {
  width: 2.7rem; height: 2.7rem; display: grid; place-items: center; border-radius: 10px;
  background: linear-gradient(140deg, var(--groen), var(--groen-d)); color: #fff; font-size: 1.3rem;
  margin-bottom: 1rem; box-shadow: 0 8px 18px -8px rgb(21 163 139 / .7);
}
.kaart p { color: var(--muted); margin-bottom: 0; }
.kaart .prijs { color: var(--blauw); margin: .1rem 0 .8rem; font-size: 1.05rem; }
.kaart .prijs strong { font-family: var(--display); font-weight: 560; font-size: 1.9rem; letter-spacing: -.01em; }
.prijslijst { list-style: none; margin: 1.1rem 0 0; padding: 1.1rem 0 0; border-top: 1px solid var(--rule); display: grid; gap: .55rem; }
.prijslijst li { color: var(--muted); display: grid; grid-template-columns: 1fr auto 4.75rem; align-items: baseline; column-gap: 1rem; }
.prijslijst .bedrag { color: var(--blauw); font-weight: 650; white-space: nowrap; text-align: right; }
.prijslijst .eenh { white-space: nowrap; }
.band.donker .kaart { background: rgb(255 255 255 / .05); border-color: rgb(255 255 255 / .14); color: #cfdae5; backdrop-filter: blur(4px); }
.band.donker .kaart h3 { color: #fff; }

/* ── Niveau-uitlegger: "Leg het me uit als…" (CSS-tabs, geen JS) ─────────── */
.niveaus { margin-top: 1.5rem; }
.niveaus .keuze { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.4rem; }
.niveaus input { position: absolute; opacity: 0; pointer-events: none; }
.niveaus label {
  font-family: var(--mono); font-size: .82rem; letter-spacing: .02em;
  padding: .5rem .95rem; border: 1.5px solid var(--rule); border-radius: 2rem;
  background: #fff; color: var(--blauw); cursor: pointer; user-select: none;
  transition: background .16s, color .16s, border-color .16s;
}
.niveaus label:hover { border-color: var(--groen); color: var(--groen-d); }
.niveaus .paneel {
  display: none;
  background: var(--kaart); border: 1px solid var(--rule); border-left: 4px solid var(--groen);
  border-radius: var(--rad); padding: clamp(1.4rem, 3vw, 2.2rem);
  box-shadow: var(--schaduw-s);
}
.niveaus .paneel h3 { margin-bottom: .5rem; }
.niveaus .paneel p { margin-bottom: 0; color: var(--ink); font-size: 1.08rem; max-width: 64ch; }
.niveaus .paneel p + p { margin-top: .8rem; }
.niveaus .paneel .voorbeeld {
  margin-top: 1.1rem; font-family: var(--mono); font-size: .92rem; color: var(--blauw);
  background: var(--paper-2); border-radius: var(--rad-s); padding: .8rem 1rem;
}
/* koppel elke radio aan zijn label en paneel */
#niv-1:checked ~ .keuze label[for="niv-1"],
#niv-2:checked ~ .keuze label[for="niv-2"],
#niv-3:checked ~ .keuze label[for="niv-3"],
#niv-4:checked ~ .keuze label[for="niv-4"],
#niv-5:checked ~ .keuze label[for="niv-5"] {
  background: var(--blauw); color: #fff; border-color: var(--blauw);
}
#niv-1:checked ~ #paneel-1,
#niv-2:checked ~ #paneel-2,
#niv-3:checked ~ #paneel-3,
#niv-4:checked ~ #paneel-4,
#niv-5:checked ~ #paneel-5 { display: block; animation: opduiken .4s var(--vt) both; }

/* ── Stappen ─────────────────────────────────────────────────────────────── */
.stappen { list-style: none; margin: 0; padding: 0; counter-reset: stap; display: grid; gap: 1.6rem; }
.stappen li { position: relative; padding-left: 4rem; counter-increment: stap; }
.stappen li::before {
  content: counter(stap, decimal-leading-zero);
  position: absolute; left: 0; top: -.1rem;
  font-family: var(--display); font-size: 1.5rem; font-weight: 560; color: var(--groen-d);
  font-feature-settings: "tnum";
}
.stappen li:not(:last-child)::after { content: ""; position: absolute; left: 1rem; top: 2.1rem; bottom: -1.6rem; width: 1px; background: linear-gradient(var(--groen), transparent); }
.stappen strong { color: var(--blauw); }
/* Slotalinea onder de stappen lijnt uit met de staptekst (achter de nummergoot) */
.stappen-voet { padding-left: 4rem; max-width: 66ch; margin-top: 1.6rem; }
@media (max-width: 560px) { .stappen-voet { padding-left: 0; } }

/* ── Doorgeefluik-diagram (veiligheid) ──────────────────────────────────── */
.stroom { display: flex; align-items: center; gap: .8rem; flex-wrap: wrap; justify-content: center; margin: 1.8rem 0; }
.stroom .blok { background: #fff; border: 1.5px solid var(--blauw); border-radius: var(--rad-s); padding: .8rem 1.2rem; font-weight: 600; color: var(--blauw); }
.band.donker .stroom .blok { background: rgb(255 255 255 / .08); border-color: rgb(255 255 255 / .35); color: #fff; }
.stroom .blok.accent { border-color: var(--groen); color: var(--groen-d); }
.band.donker .stroom .blok.accent { color: var(--groen-l); border-color: var(--groen); }
.stroom .pijl { color: var(--groen); font-size: 1.4rem; animation: schuiven 1.7s ease-in-out infinite; }
@keyframes schuiven { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(6px); } }

/* Veiligheidssectie: twee kolommen die de volle breedte benutten; de doorgeefluik-
   stroom staat rechts verticaal. */
.veiligheid-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, .8fr); gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
@media (max-width: 820px) { .veiligheid-grid { grid-template-columns: 1fr; } }
.stroom.verticaal { flex-direction: column; align-items: stretch; gap: .9rem; margin: 0; }
.stroom.verticaal .blok { text-align: center; padding: 1rem 1.2rem; }
.stroom.verticaal .pijl { align-self: center; animation: zakken 1.7s ease-in-out infinite; }
@keyframes zakken { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(6px); } }

/* Leesbaarheid op de donkere band: lichtgroene eyebrow i.p.v. donkergroen. */
.band.donker .eyebrow { color: var(--groen-l); }
.band.donker .eyebrow::before { background: var(--groen-l); }

/* ── Beta-aanmelding ─────────────────────────────────────────────────────── */
.beta { position: relative; overflow: clip; }
.beta .binnen { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr); gap: clamp(1.6rem, 4vw, 3.5rem); align-items: center; }
@media (max-width: 820px) { .beta .binnen { grid-template-columns: 1fr; } }
.beta-form {
  background: rgb(255 255 255 / .07); border: 1px solid rgb(255 255 255 / .16);
  border-radius: var(--rad); padding: clamp(1.4rem, 3vw, 2rem); backdrop-filter: blur(6px);
}
.beta-form label { display: block; font-weight: 600; color: #fff; margin-bottom: .5rem; font-size: .95rem; }
.beta-form .veld { display: flex; gap: .6rem; flex-wrap: wrap; }
.beta-form input[type="email"], .beta-form input[type="text"], .beta-form select, .beta-form textarea {
  flex: 1 1 12rem; min-width: 0; width: 100%;
  font-family: var(--sans); font-size: 1rem; color: var(--blauw);
  padding: .85rem 1rem; border-radius: var(--rad-s); border: 1.5px solid transparent; background: #fff;
  transition: box-shadow .16s, border-color .16s;
}
.beta-form textarea { resize: vertical; min-height: 7rem; line-height: 1.5; }
.beta-form input::placeholder, .beta-form textarea::placeholder { color: #97a3ad; }
.beta-form input:focus-visible, .beta-form select:focus-visible, .beta-form textarea:focus-visible { outline: none; border-color: var(--groen); box-shadow: 0 0 0 4px rgb(21 163 139 / .3); }
.beta-form .rij { display: grid; gap: .8rem; margin-bottom: .9rem; }
.beta-form .rij[hidden] { display: none; }
.beta-form button { width: 100%; justify-content: center; }
.beta-form .klein { font-size: .82rem; color: rgb(207 218 229 / .85); margin: .9rem 0 0; }
.beta-form .melding { margin: .9rem 0 0; font-weight: 600; color: var(--groen-l); min-height: 1.2rem; }
.beta-form .melding[data-fout="ja"] { color: #ffb4a8; }
.beta-lijst { list-style: none; margin: 1.4rem 0 0; padding: 0; display: grid; gap: .7rem; }
.beta-lijst li { display: flex; gap: .7rem; align-items: start; color: #cfdae5; }
.beta-lijst li::before { content: "→"; color: var(--groen-l); font-weight: 700; }

/* ── Contactpagina: bericht + aanmelding naast elkaar ───────────────────── */
.contact-grid { display: grid; gap: clamp(1.6rem, 4vw, 3rem); align-items: start; }
@media (min-width: 60rem) { .contact-grid { grid-template-columns: 1fr 1fr; } }
.contact-grid > div > .eyebrow { margin-top: 0; }
.contact-grid h2 { margin-top: .2rem; }

/* ── Tabellen (pakketten) ───────────────────────────────────────────────── */
.tabel-wrap { overflow-x: auto; border: 1px solid var(--rule); border-radius: var(--rad); background: #fff; }
table.dekking { width: 100%; border-collapse: collapse; font-size: .95rem; min-width: 38rem; }
table.dekking caption { text-align: left; color: var(--muted); margin-bottom: .6rem; caption-side: top; padding: 0 0 .6rem; }
table.dekking th, table.dekking td { border-bottom: 1px solid var(--rule); padding: .7rem .9rem; text-align: left; }
table.dekking thead th { background: var(--blauw); color: #fff; position: sticky; top: 0; font-family: var(--sans); font-weight: 600; }
table.dekking tbody th { background: var(--paper-2); font-weight: 600; color: var(--blauw); }
.badge { display: inline-block; padding: .12rem .6rem; border-radius: 1rem; background: var(--paper-2); border: 1px solid var(--rule); color: var(--muted); font-size: .82rem; white-space: nowrap; }
.badge.live { background: var(--groen); border-color: var(--groen); color: #fff; }

/* ── FAQ ─────────────────────────────────────────────────────────────────── */
details.faq-item { border: 1px solid var(--rule); border-radius: var(--rad); background: #fff; margin-bottom: .8rem; overflow: clip; }
details.faq-item summary { cursor: pointer; padding: 1.1rem 1.3rem; font-weight: 600; color: var(--blauw); list-style: none; display: flex; justify-content: space-between; gap: 1rem; font-family: var(--display); font-size: 1.08rem; }
details.faq-item summary::-webkit-details-marker { display: none; }
details.faq-item summary::after { content: "+"; color: var(--groen); font-size: 1.4rem; line-height: 1; transition: transform .2s var(--vt); }
details.faq-item[open] summary::after { transform: rotate(45deg); }
details.faq-item .antwoord { padding: 0 1.3rem 1.2rem; max-width: 64ch; color: var(--muted); }
@supports (interpolate-size: allow-keywords) {
  :root { interpolate-size: allow-keywords; }
  details.faq-item::details-content { block-size: 0; overflow: clip; transition: block-size .3s var(--vt), content-visibility .3s allow-discrete; }
  details.faq-item[open]::details-content { block-size: auto; }
}

/* ── Reveals ─────────────────────────────────────────────────────────────── */
.reveal { opacity: 1; }
@supports (animation-timeline: view()) {
  html.heeft-at .reveal { animation: opduiken linear both; animation-timeline: view(); animation-range: entry 0% entry 36%; }
}
@keyframes opduiken { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: none; } }
html.io-reveal .js-reveal { opacity: 0; transform: translateY(26px); transition: opacity .6s var(--vt), transform .6s var(--vt); }
html.io-reveal .js-reveal.zichtbaar { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  html { scroll-behavior: auto; }
  .js-reveal { opacity: 1 !important; transform: none !important; }
}

/* ── Footer ─────────────────────────────────────────────────────────────── */
.site-footer { background: linear-gradient(180deg, var(--blauw-d), #0a1929); color: #aebccb; }
.site-footer .binnen { display: grid; gap: 2rem; grid-template-columns: 1.4fr repeat(2, 1fr); padding-block: clamp(2.5rem, 5vw, 3.5rem); }
@media (max-width: 700px) { .site-footer .binnen { grid-template-columns: 1fr 1fr; } .site-footer .binnen > :first-child { grid-column: 1 / -1; } }
.site-footer img { margin-bottom: .9rem; }
.site-footer p { max-width: 30ch; }
.site-footer a { color: #cdd9e4; text-decoration: none; }
.site-footer h3 { color: #7fd4c4; font-family: var(--mono); font-size: .74rem; text-transform: uppercase; letter-spacing: .14em; margin-bottom: .8rem; }
.site-footer nav a { display: block; padding: .2rem 0; color: #aebccb; }
.site-footer nav a:hover { color: #fff; }
/* hidden wint van de display:block hierboven, zodat de prelaunch-toggle (login=0) de
   portal/docs-links in de footer echt verbergt (anders blijven ze zichtbaar). */
.site-footer nav a[hidden] { display: none; }
.site-footer .voet { border-top: 1px solid rgb(255 255 255 / .1); margin-top: .5rem; }
.site-footer .klein { max-width: var(--maxb); margin-inline: auto; padding: 1.2rem var(--pad); font-size: .82rem; color: #7d8aa0; opacity: .85; font-family: var(--mono); letter-spacing: .03em; }
.site-footer .klein .details { display: block; margin-top: .4rem; }
.site-footer .klein .details a { color: #9fb0bf; }

/* Merknaam in logokleuren: Finance = Grootboekblauw, MCP = Saldogroen */
.merk-f { color: var(--blauw); }
.merk-m { color: var(--groen); }
.site-footer .merk-f { color: #fff; }
.site-footer .merk-m { color: #43c9af; }

/* ── Cookie-banner ───────────────────────────────────────────────────────── */
#cookie-banner {
  position: fixed; inset-inline: 1rem; bottom: 1rem; max-width: 27rem; margin: 0 auto;
  background: #fff; border: 1px solid var(--rule); border-radius: var(--rad);
  box-shadow: var(--schaduw); padding: 1.1rem 1.3rem; z-index: 40;
}
#cookie-banner p { margin: 0 0 .8rem; font-size: .92rem; }
#cookie-banner .knoppen { display: flex; gap: .6rem; }

/* ── Algemene inhoudspagina (subpagina-koppen) ──────────────────────────── */
.pagkop { padding-block: clamp(2.5rem, 6vw, 4rem) clamp(1.5rem, 3vw, 2rem); }
.pagkop .lead { max-width: 62ch; }

/* ── 404 ─────────────────────────────────────────────────────────────────── */
.foutpagina { text-align: center; padding: clamp(3.5rem, 12vw, 7rem) var(--pad); max-width: 40rem; margin-inline: auto; }
.foutpagina img { margin-bottom: 1.6rem; }
.foutpagina .cta-row { justify-content: center; }
