:root{
  --ink-900:#0F2240; --ink-700:#1E3A5F; --ink-500:#3D5A80;
  --text:#16243A; --text-soft:#5A6B82;
  --accent:#13935F; --accent-hover:#0F7E51; --accent-soft:#E4F3EC;
  --meter-low:#C7D0DC; --meter-mid:#8FB8A6; --meter-high:#2F8F6B;
  --line:#E3E8EF; --line-strong:#CDD5E0; --bg:#FFFFFF; --bg-tint:#F6F8FB; --bg-ink:#0F2240;
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px; --s-9:88px;
  --r-sm:8px; --r-md:12px; --r-lg:20px; --r-pill:999px;
  --sh-1:0 1px 2px rgba(15,34,64,.06); --sh-2:0 4px 16px rgba(15,34,64,.08); --sh-3:0 24px 60px -20px rgba(15,34,64,.45);
  --focus:0 0 0 3px rgba(47,143,107,.30);
  --scanw:560px; --maxw:1080px;
  --font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{ box-sizing:border-box; }
body{ margin:0; font-family:var(--font); color:var(--text); background:var(--bg); line-height:1.55; -webkit-font-smoothing:antialiased; }
a{ color:inherit; }
h1,h2,h3{ color:var(--ink-900); letter-spacing:-.015em; }
.muted{ color:var(--text-soft); } .small{ font-size:13px; color:var(--text-soft); }

/* ---------- LANDING (breed, full-bleed secties) ---------- */
.header{ position:sticky; top:0; z-index:30; display:flex; align-items:center; justify-content:space-between;
  padding:12px 24px; background:rgba(15,34,64,.94); backdrop-filter:blur(8px); color:#fff; }
.logo{ display:flex; align-items:center; gap:10px; font-weight:700; font-size:17px; color:#fff; }
.logo svg{ width:26px; height:26px; }
.logo b{ font-weight:800; } .logo span{ font-weight:500; opacity:.85; }
.btn-sm{ background:var(--accent-hover); color:#fff; border:0; border-radius:var(--r-pill); padding:9px 16px; font:600 14px var(--font); cursor:pointer; }
.btn-sm:hover{ background:#0B6A44; }

.section{ width:100%; }
.section > .wrap{ max-width:var(--maxw); margin-inline:auto; padding:var(--s-9) 24px; }
.section--dark{ background:linear-gradient(165deg,#0D1F3A 0%,#143055 60%,#0F2A4E 100%); color:#E9EFF6; position:relative; overflow:hidden; }
.section--dark h1,.section--dark h2{ color:#fff; }
.section--mist{ background:var(--bg-tint); }
.section--accent{ background:var(--accent); color:#fff; }
.section--accent h2{ color:#fff; }
.dots{ position:absolute; inset:0; background-image:radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px); background-size:24px 24px; pointer-events:none; }

.hero{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; position:relative; }
.hero .kicker{ display:inline-block; font:600 12px var(--font); letter-spacing:.08em; text-transform:uppercase; color:#8FB8A6; margin-bottom:14px; }
.hero h1{ font-size:clamp(2rem,4.2vw,3.1rem); line-height:1.08; margin:0 0 16px; }
.hero p.sub{ font-size:18px; color:#C4D2E2; margin:0 0 24px; max-width:30em; }
.hero .cta-row{ display:flex; flex-direction:column; gap:10px; max-width:340px; }
.hero .micro{ font-size:13px; color:#9FB2C8; }
.hero .chips{ display:flex; flex-wrap:wrap; gap:8px; margin-top:22px; }
.hero .chip{ background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14); color:#E9EFF6; }
@media(max-width:840px){ .hero{ grid-template-columns:1fr; gap:32px; } }

/* product-mock van de uitslag */
.mock{ position:relative; background:#fff; color:var(--text); border-radius:18px; padding:24px; box-shadow:0 30px 70px -24px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.05); }
.hero .mock::before{ content:""; position:absolute; inset:-40px -24px; background:radial-gradient(closest-side, rgba(19,147,95,.40), transparent 72%); z-index:-1; filter:blur(22px); }
.mock .bar{ display:flex; gap:6px; margin-bottom:18px; }
.mock .bar i{ width:10px; height:10px; border-radius:50%; background:#D7DEE4; }
.mock .verdict{ font:700 14px var(--font); color:var(--accent); margin:0 0 6px; }
.mock .amt{ font:800 38px var(--font); color:var(--ink-900); letter-spacing:-.025em; font-variant-numeric:tabular-nums; }
.mock .amt small{ font:600 14px var(--font); color:var(--text-soft); }

.stat-strip{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; text-align:center; }
.stat-strip > div{ padding:6px 10px; }
.stat-strip > div + div{ border-left:1px solid var(--line); }
.stat-strip .v{ font:800 42px var(--font); color:var(--accent); letter-spacing:-.025em; line-height:1; }
.stat-strip .k{ font:500 15px var(--font); color:var(--text-soft); margin-top:10px; }
@media(max-width:640px){ .stat-strip > div + div{ border-left:0; } }
@media(max-width:640px){ .stat-strip{ grid-template-columns:1fr; gap:16px; } }

.section h2.sec-title{ font-size:clamp(1.7rem,3.4vw,2.3rem); font-weight:800; margin:0 0 10px; }
.section .sec-intro{ color:var(--text-soft); max-width:34em; margin:0 0 var(--s-6); }

.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media(max-width:760px){ .grid-3{ grid-template-columns:1fr; } }
.feature{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:28px; box-shadow:0 2px 10px rgba(15,34,64,.05); transition:box-shadow .2s,transform .2s; }
.feature:hover{ box-shadow:0 14px 34px rgba(15,34,64,.10); transform:translateY(-2px); }
.feature svg{ width:24px; height:24px; padding:11px; background:var(--accent-soft); border-radius:12px; box-sizing:content-box; color:var(--accent); margin-bottom:16px; }
.feature h3{ font-size:17px; margin:0 0 6px; }
.feature p{ margin:0; color:var(--text-soft); font-size:15px; }
.feature .step-n{ font:800 14px var(--font); color:var(--accent-hover); }

/* rekenvoorbeeld */
.calc{ display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:center; }
@media(max-width:760px){ .calc{ grid-template-columns:1fr; } }
.calc-table{ width:100%; border-collapse:collapse; }
.calc-table td,.calc-table th{ padding:12px 14px; border-bottom:1px solid var(--line); text-align:left; font-size:15px; }
.calc-table th{ color:var(--text-soft); font-weight:600; }
.calc-table td:last-child{ text-align:right; font-weight:700; color:var(--ink-900); font-variant-numeric:tabular-nums; }
.calc-note{ background:var(--accent-soft); border-radius:var(--r-md); padding:18px; font-size:15px; }

/* faq */
.faq details{ border:1px solid var(--line); border-radius:var(--r-md); margin-bottom:10px; background:#fff; }
.faq summary{ padding:16px 18px; font:600 16px var(--font); color:var(--ink-900); cursor:pointer; list-style:none; display:flex; justify-content:space-between; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; color:var(--accent); font-weight:700; }
.faq details[open] summary::after{ content:"–"; }
.faq p{ padding:0 18px 16px; margin:0; color:var(--text-soft); }

.cta-band{ text-align:center; }
.cta-band h2{ font-size:clamp(1.5rem,3vw,2rem); margin:0 0 10px; }
.cta-band p{ color:#E6F2EC; margin:0 0 22px; }
.cta-band .btn{ max-width:340px; margin-inline:auto; background:#fff; color:var(--accent); }
.cta-band .btn:hover{ background:#F0F7F4; }

.site-footer{ background:var(--ink-900); color:#9FB2C8; }
.site-footer .wrap{ padding:40px 24px; display:flex; flex-wrap:wrap; gap:24px; justify-content:space-between; align-items:flex-start; }
.site-footer a{ color:#C4D2E2; text-decoration:underline; }
.site-footer a:hover{ color:#fff; }
.site-footer .disc{ max-width:42em; font-size:12px; line-height:1.6; }

/* ---------- SCAN (smal, gefocust) ---------- */
#scan-app{ max-width:var(--scanw); margin:0 auto; padding:var(--s-5) var(--s-4) var(--s-7); }
.brand{ display:flex; align-items:center; gap:8px; font-weight:700; color:var(--ink-900); font-size:16px; margin-bottom:var(--s-6); background:none; border:0; cursor:pointer; font-family:var(--font); }
.brand .mark{ width:12px; height:12px; border-radius:50%; background:var(--accent); }
.screen{ display:none; } .screen.active{ display:block; animation:fade .3s ease; }
@keyframes fade{ from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:none;} }
@keyframes fadeUp{ to{opacity:1; transform:none;} }
h2{ font-size:22px; line-height:1.2; font-weight:700; margin:0 0 var(--s-3); }
.lead{ font-size:17px; color:var(--text-soft); }

.btn{ font:600 17px/1 var(--font); padding:16px 24px; border-radius:var(--r-md); border:0; cursor:pointer; min-height:52px; width:100%; transition:background .18s,transform .06s; }
.btn--primary{ background:var(--accent-hover); color:#fff; box-shadow:0 8px 20px -6px rgba(19,147,95,.45); }
.btn--primary:hover{ background:#0B6A44; } .btn--primary:active{ transform:translateY(1px); }
.btn--primary:focus-visible{ outline:0; box-shadow:var(--focus); }
.micro{ font-size:13px; color:var(--text-soft); margin-top:var(--s-3); }

.chip{ display:inline-flex; align-items:center; gap:6px; font:600 13px var(--font); color:var(--ink-700); background:var(--bg-tint); border:1px solid var(--line); padding:6px 12px; border-radius:var(--r-pill); }
.chip .c{ color:var(--accent); font-weight:800; }

.progress{ height:6px; background:var(--line); border-radius:var(--r-pill); overflow:hidden; }
.progress__fill{ height:100%; background:var(--accent); border-radius:var(--r-pill); transition:width .4s cubic-bezier(.4,0,.2,1); }
.progress__meta{ font:500 13px var(--font); color:var(--text-soft); margin:var(--s-2) 0 var(--s-5); }
.qtext{ font-size:22px; font-weight:700; color:var(--ink-900); line-height:1.2; margin:0 0 var(--s-2); }
.qhelp{ color:var(--text-soft); font-size:15px; margin:0 0 var(--s-4); }
.option{ display:flex; align-items:center; gap:var(--s-3); width:100%; text-align:left; padding:18px 20px; background:#fff; border:1.5px solid var(--line-strong); border-radius:var(--r-md); font:500 17px/1.3 var(--font); color:var(--text); cursor:pointer; margin:10px 0; transition:border-color .15s,background .15s; }
.option:hover{ border-color:var(--ink-500); background:var(--bg-tint); }
.option .dot{ width:22px; height:22px; border-radius:50%; border:2px solid var(--line-strong); flex:0 0 auto; }
.back{ background:none; border:0; color:var(--text-soft); cursor:pointer; padding:0; font:500 14px var(--font); margin-bottom:var(--s-3); }

/* verplichte disclaimer boven de uitslag — WBS-10 §2.1 MUST-fix #2 */
.result-disclaimer{ background:#FFF7E6; border:1.5px solid #F2D9A0; color:#5A4218; border-radius:var(--r-md); padding:14px 16px; font:500 14px/1.45 var(--font); margin-bottom:var(--s-4); }
.result-disclaimer strong{ color:#3F2E0F; }

.card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-2); padding:var(--s-6); }
.card.center{ text-align:center; } .big{ font-size:40px; }
.amount{ font-weight:800; font-size:44px; line-height:1; letter-spacing:-.02em; color:var(--accent); font-variant-numeric:tabular-nums; opacity:0; transform:translateY(8px); animation:fadeUp .5s ease .25s forwards; }
.amount .euro{ font-size:.6em; font-weight:700; }
.per{ font:600 16px var(--font); color:var(--text-soft); margin-top:2px; }
@media(min-width:768px){ .amount{ font-size:56px; } }
.meter{ position:relative; height:14px; border-radius:var(--r-pill); margin:var(--s-5) 0 var(--s-2); background:linear-gradient(90deg,var(--meter-low) 0%,var(--meter-mid) 55%,var(--meter-high) 100%); }
.meter__thumb{ position:absolute; top:50%; width:26px; height:26px; border-radius:50%; background:#fff; border:3px solid var(--accent); box-shadow:var(--sh-2); transform:translate(-50%,-50%); left:8%; transition:left 1.1s cubic-bezier(.34,1.2,.4,1); }
.meter.is-revealed .meter__thumb{ left:var(--pos,86%); }
.meter__ends{ display:flex; justify-content:space-between; font:500 13px var(--font); color:var(--text-soft); }
.gap{ display:flex; gap:var(--s-3); margin:var(--s-5) 0; }
.gap > div{ flex:1; background:var(--bg-tint); border:1px solid var(--line); border-radius:var(--r-md); padding:var(--s-4); text-align:center; }
.gap .k{ font:600 12px var(--font); letter-spacing:.04em; text-transform:uppercase; color:var(--text-soft); }
.gap .v{ font:800 20px var(--font); color:var(--ink-900); margin-top:2px; font-variant-numeric:tabular-nums; }
.gap .v.accent{ color:var(--accent); }
.field{ margin:var(--s-4) 0; }
.label{ font:600 14px var(--font); color:var(--text); display:block; margin-bottom:var(--s-2); }
.input{ width:100%; font:400 17px/1.4 var(--font); color:var(--text); padding:14px 16px; background:#fff; border:1.5px solid var(--line-strong); border-radius:var(--r-sm); transition:border-color .15s,box-shadow .15s; }
.input:focus{ outline:0; border-color:var(--accent); box-shadow:var(--focus); }
.consent{ display:flex; gap:10px; align-items:flex-start; margin:var(--s-4) 0; font-size:14px; color:var(--text-soft); }
.consent input{ margin-top:3px; width:18px; height:18px; flex:0 0 auto; }
.reassure{ font-size:13px; color:var(--text-soft); margin-top:var(--s-2); }
.err{ color:#B42318; font-size:14px; margin:var(--s-2) 0 0; min-height:1px; }
#scan-app footer{ border-top:1px solid var(--line); margin-top:var(--s-7); padding-top:var(--s-5); }
.disclaimer{ font-size:12px; color:var(--text-soft); } .disclaimer a{ color:var(--text-soft); }

@media(prefers-reduced-motion:reduce){ *{ animation:none!important; transition:none!important; } .meter__thumb{ left:var(--pos,86%); } .amount{ opacity:1; transform:none; } }
