/* ============================================================
   Objectcheck — premium designsysteem (light & strak)
   Bold redesign: warm-neutraal canvas, near-black acties,
   verfijnd groen accent, fijne schaduwen, ruime spacing.
   Alle class-namen 1:1 behouden i.v.m. door JS gegenereerde markup.
   ============================================================ */
:root{
  /* merk-accent (groen, verdiept) */
  --primary:#0f7a4e; --primary-d:#0b633f; --primary-l:#3a9b71; --primary-xl:#7cc0a1;
  /* near-black inkt = premium primaire knoppen/teksten */
  --ink:#15171a; --ink-2:#22262b; --ink-btn:#181a1d; --ink-btn-h:#000;
  /* neutralen: licht, warm-neutraal canvas */
  --bg:#f6f6f3; --surface:#ffffff; --surface-2:#fbfbf9;
  --muted:#5b6168; --faint:#949aa1;
  --line:#ececE6; --line2:#dfe0d9; --border-strong:#cfd0c8;
  --tint:#f1f1ec; --primary-tint:#e7f2ec; --primary-tint-2:#d6e9df;
  /* statussen */
  --green:#13864f; --green-bg:#e6f3ec; --amber:#9a6b10; --amber-bg:#f8efd9;
  --red:#bb3528; --red-bg:#fae8e5; --blue:#2b5cab; --blue-bg:#e7eefa;
  /* vorm */
  --r-sm:8px; --r:10px; --r-lg:14px; --r-xl:18px; --r-2xl:24px; --maxw:1200px;
  /* schaduwen: fijn en gelaagd */
  --sh-xs:0 1px 2px rgba(16,24,32,.05);
  --sh-sm:0 1px 2px rgba(16,24,32,.04), 0 4px 12px -6px rgba(16,24,32,.08);
  --sh:0 1px 2px rgba(16,24,32,.04), 0 10px 28px -14px rgba(16,24,32,.16);
  --sh-lg:0 2px 6px rgba(16,24,32,.05), 0 24px 56px -22px rgba(16,24,32,.22);
  --sh-ring:0 0 0 4px rgba(15,122,78,.14);
  --ease:cubic-bezier(.4,0,.2,1);
  --t-fast:.16s var(--ease); --t:.24s var(--ease);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  font-feature-settings:"cv05" 1,"ss01" 1;text-rendering:optimizeLegibility}
p{max-width:66ch;margin:0}
button{font-family:inherit}
a{color:inherit;text-decoration:none}
img{max-width:100%}
h1,h2,h3,h4{margin:0;line-height:1.12;letter-spacing:-.022em;font-weight:700}
.inner{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}
::selection{background:var(--primary-tint-2);color:var(--ink)}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:6px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---- scroll-reveal (alleen met JS actief) ---- */
.js-reveal [data-rv]{opacity:0;transform:translateY(14px)}
.js-reveal [data-rv].in{opacity:1;transform:none;transition:opacity .55s var(--ease),transform .55s var(--ease)}
@media (prefers-reduced-motion:reduce){
  .js-reveal [data-rv]{opacity:1!important;transform:none!important}
  html{scroll-behavior:auto}
}

/* ============================================================ NAV */
.nav{position:sticky;top:0;z-index:40;background:rgba(246,246,243,.72);
  backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--line);transition:box-shadow var(--t),background var(--t)}
.nav.scrolled{box-shadow:0 1px 0 var(--line),0 8px 24px -18px rgba(16,24,32,.3);background:rgba(246,246,243,.88)}
.nav .inner{display:flex;align-items:center;gap:4px;height:66px}
.brand{display:flex;align-items:center;gap:11px;margin-right:28px;cursor:pointer}
.brand .mk{width:34px;height:34px;border-radius:10px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;letter-spacing:.3px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06),0 2px 8px -3px rgba(0,0,0,.4)}
.brand .bn{font-weight:800;font-size:18px;letter-spacing:-.03em}
.brand .bn-g{color:#2EBE75}
.mklogo{width:38px;height:38px;display:block;object-fit:contain}
.mklogo.lg{width:48px;height:48px;margin:0 auto 4px}
.mklogo.tile{background:#fff;border-radius:10px;padding:3px}
.brand .bs{display:block;font-size:10.5px;color:var(--muted);font-weight:500;letter-spacing:.01em;margin-top:-2px}
.navlink{position:relative;border:none;background:transparent;color:var(--muted);font-size:14px;font-weight:500;padding:8px 13px;border-radius:9px;cursor:pointer;display:flex;align-items:center;gap:7px;transition:color var(--t-fast),background var(--t-fast)}
.navlink:hover{background:var(--tint);color:var(--ink)}
.navlink.on{color:var(--ink);font-weight:600}
.navlink.on::after{content:"";position:absolute;left:13px;right:13px;bottom:1px;height:2px;border-radius:2px;background:var(--primary)}
.navlink .cnt{background:var(--ink);color:#fff;border-radius:20px;font-size:11px;padding:1px 7px;font-weight:700;font-variant-numeric:tabular-nums}
.nav .right{margin-left:auto;display:flex;align-items:center;gap:14px}
.nav-desktop{display:flex;align-items:center;gap:2px}
.src-ind{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--line);padding:5px 11px;border-radius:20px;font-weight:500}
.src-ind .led{width:7px;height:7px;border-radius:50%;background:var(--faint);position:relative}
.src-ind.live .led{background:var(--green)}
.src-ind.live .led::after{content:"";position:absolute;inset:-3px;border-radius:50%;border:1px solid var(--green);opacity:.5;animation:pulse 2s var(--ease) infinite}
.src-ind.demo .led{background:var(--amber)}
@keyframes pulse{0%{transform:scale(.8);opacity:.6}70%{transform:scale(1.9);opacity:0}100%{opacity:0}}
.hamburger{display:none;border:1px solid var(--line2);background:var(--surface);border-radius:10px;width:42px;height:42px;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);transition:var(--t-fast)}
.hamburger:hover{background:var(--tint)}
.mobile-overlay{position:fixed;inset:0;z-index:50;background:var(--bg);display:none;flex-direction:column;padding:22px 24px}
.mobile-overlay.open{display:flex;animation:moIn .28s var(--ease)}
@keyframes moIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.mobile-overlay .mo-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.mobile-overlay a,.mobile-overlay button.mlink{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;border:none;background:none;font-size:19px;font-weight:600;color:var(--ink);padding:17px 2px;border-bottom:1px solid var(--line);cursor:pointer}
.mobile-overlay button.mlink:active{color:var(--primary)}

/* ============================================================ BUTTONS */
.btn{position:relative;height:46px;border:none;border-radius:11px;background:var(--ink-btn);color:#fff;font-size:14.5px;font-weight:600;letter-spacing:-.01em;padding:0 22px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:9px;white-space:nowrap;
  box-shadow:0 1px 2px rgba(0,0,0,.16),inset 0 1px 0 rgba(255,255,255,.08);transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-fast)}
.btn:hover{background:var(--ink-btn-h);box-shadow:0 2px 4px rgba(0,0,0,.18),0 10px 22px -10px rgba(0,0,0,.5);transform:translateY(-1px)}
.btn:active{transform:translateY(0) scale(.985)}
.btn .i{width:18px;height:18px}
.btn.accent{background:var(--primary)}.btn.accent:hover{background:var(--primary-d)}
.btn.ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line2);box-shadow:var(--sh-xs)}
.btn.ghost:hover{background:var(--surface);border-color:var(--border-strong);box-shadow:var(--sh-sm);transform:translateY(-1px)}
.btn.lg{height:54px;font-size:15.5px;padding:0 30px;border-radius:13px}
.btn.sm{height:38px;font-size:13.5px;padding:0 15px;border-radius:9px}
.btn.onlight{background:#fff;color:var(--ink)}.btn.onlight:hover{background:#f3f3ef}
.btn[disabled]{opacity:.6;cursor:not-allowed;transform:none}

/* ============================================================ SECTIONS */
.section{padding:clamp(56px,8vw,116px) 0}
.section.tint{background:var(--tint)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--primary-d);margin-bottom:18px}
.eyebrow .dotg{width:6px;height:6px;border-radius:50%;background:var(--primary)}
.sec-head{max-width:700px;margin-bottom:54px}
.sec-head h2{font-size:clamp(26px,4.6vw,40px);font-weight:800;line-height:1.08;margin-bottom:16px;letter-spacing:-.03em}
.sec-head p{font-size:17.5px;color:var(--muted);line-height:1.55}

/* ============================================================ HERO */
.hero{position:relative;padding:clamp(40px,7vw,96px) 0 clamp(48px,8vw,104px);display:flex;align-items:center;min-height:calc(100vh - 200px);overflow:hidden}
.hero::before{content:"";position:absolute;top:-30%;right:-10%;width:60%;height:120%;
  background:radial-gradient(60% 50% at 70% 30%,rgba(15,122,78,.10),transparent 70%);pointer-events:none}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:46px 46px;-webkit-mask-image:radial-gradient(70% 60% at 50% 30%,#000,transparent 75%);mask-image:radial-gradient(70% 60% at 50% 30%,#000,transparent 75%);opacity:.5}
.hero .inner{width:100%;position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.hero .tagbadge{display:inline-flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line2);color:var(--ink);font-size:12.5px;font-weight:600;padding:7px 14px;border-radius:30px;margin-bottom:26px;box-shadow:var(--sh-xs)}
.hero .tagbadge::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 3px var(--primary-tint)}
.hero h1{font-size:clamp(34px,6.6vw,62px);font-weight:800;line-height:1.04;letter-spacing:-.04em;margin-bottom:22px}
.hero h1 .hl{color:var(--primary)}
.hero .sub{font-size:clamp(16px,2.2vw,19.5px);line-height:1.6;color:var(--muted);max-width:540px;margin-bottom:34px}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap}
.trust{display:flex;gap:36px;flex-wrap:wrap;margin-top:42px;padding-top:32px;border-top:1px solid var(--line)}
.trust .t .v{font-size:22px;font-weight:800;color:var(--ink);letter-spacing:-.02em}
.trust .t .l{font-size:13px;color:var(--muted);margin-top:2px}

/* ---- mock cards (hero/landing previews) ---- */
.mock{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--sh-lg);overflow:hidden}
.hero-grid .mock{transform:perspective(1600px) rotateY(-3deg) rotateX(1.5deg);transition:transform .5s var(--ease)}
.hero-grid .mock:hover{transform:perspective(1600px) rotateY(0) rotateX(0)}
.mock .mhead{display:flex;align-items:center;justify-content:space-between;padding:15px 22px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.mock .mhead .lbl{font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--primary-d);background:var(--primary-tint);padding:4px 10px;border-radius:20px}
.mock .mhead .dot-live{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--green)}
.mock .mhead .dot-live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green)}
.mock .mbody{padding:24px 26px}
.pv-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}
.pv-addr{font-weight:700;font-size:16px}
.pv-meta{font-size:12.5px;color:var(--muted)}
.pv-pill{background:var(--red-bg);color:var(--red);font-size:11px;font-weight:600;padding:4px 9px;border-radius:7px}
.pv-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.pv-stat{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.pv-stat .l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.pv-stat .v{font-size:19px;font-weight:800;margin-top:2px;letter-spacing:-.02em}
.pv-line{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-top:1px solid var(--line);font-size:13.5px}
.pv-line .lead{color:var(--primary);font-weight:600;font-size:12.5px}
.lbadge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:22px;border-radius:6px;font-weight:800;font-size:12px;color:#fff;padding:0 7px;letter-spacing:.02em}

/* ============================================================ STEPS */
.stepcard{display:grid;grid-template-columns:60px 1fr 1.05fr;gap:34px;align-items:center;padding:38px 0;border-top:1px solid var(--line)}
.stepcard:first-of-type{border-top:none}
.stepcard .num{font-size:16px;font-weight:800;color:#fff;background:var(--ink);width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm)}
.stepcard h3{font-size:23px;font-weight:700;margin-bottom:9px;letter-spacing:-.02em}
.stepcard p{color:var(--muted);font-size:15.5px}
.stepmock{font-size:13px}
.sm-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line)}
.sm-row:last-child{border-bottom:none}
.sm-row .k{color:var(--muted)}.sm-row .v{font-weight:600}
.sm-field{border:1px solid var(--line2);border-radius:9px;padding:9px 12px;margin-bottom:8px;font-size:13px;background:var(--surface-2)}
.sm-field .lab{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.sm-field .val{font-weight:700;margin-top:1px}

/* ============================================================ FEATURES */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:16px}
.feat{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.feat:hover{transform:translateY(-3px);box-shadow:var(--sh);border-color:var(--line2)}
.feat .ic{width:44px;height:44px;border-radius:12px;background:var(--primary-tint);color:var(--primary-d);display:flex;align-items:center;justify-content:center;margin-bottom:16px;transition:var(--t)}
.feat:hover .ic{background:var(--ink);color:#fff}
.feat .ic .i{width:22px;height:22px}
.feat h3{font-size:16.5px;font-weight:700;margin-bottom:6px;letter-spacing:-.01em}
.feat p{font-size:14px;color:var(--muted);line-height:1.5}

/* ============================================================ SPLIT + CHECKLIST */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.checklist{list-style:none;padding:0;margin:24px 0 0}
.checklist li{display:flex;gap:13px;padding:12px 0;border-top:1px solid var(--line);font-size:15.5px;align-items:flex-start}
.checklist li:first-child{border-top:none}
.checklist .ck{color:var(--primary);flex:none;margin-top:1px;width:24px;height:24px;border-radius:50%;background:var(--primary-tint);display:flex;align-items:center;justify-content:center}
.checklist .ck .i{width:15px;height:15px}

/* ============================================================ DASHBOARD PREVIEW */
.dash-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;font-size:13.5px;background:var(--surface);transition:var(--t-fast)}
.dash-row:hover{border-color:var(--line2);box-shadow:var(--sh-xs)}
.dash-row:last-child{margin-bottom:0}
.dash-row .da .s{font-weight:700;font-size:14px}.dash-row .da .m{font-size:12px;color:var(--muted);margin-top:1px}
.dash-row .dv{text-align:right;display:flex;align-items:center;gap:10px}.dash-row .dv .p{font-weight:800;font-variant-numeric:tabular-nums}.dash-row .dv .e{font-size:12px;color:var(--muted)}
.tagk{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:20px;background:var(--primary-tint);color:var(--primary-d)}

/* ============================================================ NEWS */
.news-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px}
.news{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;cursor:pointer;transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.news:hover{box-shadow:var(--sh);transform:translateY(-3px);border-color:var(--line2)}
.news .cat{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary-d);background:var(--primary-tint);padding:3px 9px;border-radius:6px;margin-bottom:14px}
.news h3{font-size:18.5px;font-weight:700;margin-bottom:10px;line-height:1.25;letter-spacing:-.01em}
.news p{font-size:14px;color:var(--muted);margin-bottom:16px;line-height:1.5}
.news .meta{font-size:12.5px;color:var(--faint);font-weight:500}

/* ============================================================ TESTIMONIALS */
.quote-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px}
.quote{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;transition:var(--t)}
.quote:hover{box-shadow:var(--sh-sm)}
.quote .ph{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--amber);background:var(--amber-bg);display:inline-block;padding:3px 8px;border-radius:6px;margin-bottom:16px}
.quote p{font-size:15.5px;line-height:1.6;margin-bottom:18px;color:var(--ink-2)}
.quote .who{display:flex;align-items:center;gap:12px}
.quote .av{width:40px;height:40px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.quote .who .n{font-weight:700;font-size:14px}.quote .who .r{font-size:12.5px;color:var(--muted)}

/* ============================================================ LOGO ROW */
.logorow{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.logorow .lg{font-size:13px;font-weight:600;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:9px;padding:10px 16px}

/* ============================================================ CTA BAND */
.ctaband{position:relative;background:var(--ink);color:#fff;border-radius:var(--r-2xl);padding:60px;text-align:center;overflow:hidden;box-shadow:var(--sh-lg)}
.ctaband::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 80% at 50% 0%,rgba(15,122,78,.35),transparent 70%);pointer-events:none}
.ctaband>*{position:relative}
.ctaband h2{font-size:clamp(26px,4vw,34px);font-weight:800;margin-bottom:12px;letter-spacing:-.03em}
.ctaband p{font-size:17px;color:rgba(255,255,255,.74);max-width:560px;margin:0 auto 28px}

/* ============================================================ APP PAGES */
.pagehead{padding:46px 0 6px}
.pagehead h1{font-size:clamp(26px,4vw,34px);font-weight:800;margin-bottom:7px;letter-spacing:-.03em}
.pagehead .sub{color:var(--muted);font-size:15.5px}
.appwrap{padding-bottom:84px;min-height:60vh}
.crumb{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-size:13.5px;font-weight:500;background:var(--surface);border:1px solid var(--line);cursor:pointer;padding:8px 14px;margin-top:18px;border-radius:9px;transition:var(--t-fast)}
.crumb:hover{color:var(--ink);border-color:var(--line2);box-shadow:var(--sh-xs)}

/* ---- rapport-header ---- */
.rep-head{position:relative;display:flex;justify-content:space-between;align-items:flex-start;gap:18px;flex-wrap:wrap;background:var(--ink);color:#fff;border-radius:var(--r-xl);padding:28px 30px;margin:20px 0;overflow:hidden;box-shadow:var(--sh)}
.rep-head::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 120% at 100% 0%,rgba(15,122,78,.3),transparent 60%);pointer-events:none}
.rep-head>*{position:relative}
.rep-head .addr{font-size:23px;font-weight:800;letter-spacing:-.02em}
.rep-head .meta{font-size:13.5px;opacity:.78;margin-top:5px}
.rep-head .acts{display:flex;gap:8px;flex-wrap:wrap}
.rh-btn{height:40px;border-radius:10px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.08);color:#fff;font-size:13.5px;font-weight:600;padding:0 15px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:var(--t-fast);backdrop-filter:blur(4px)}
.rh-btn:hover{background:rgba(255,255,255,.18);transform:translateY(-1px)}
.rh-btn.done{background:var(--primary);border-color:var(--primary)}
.disclaim{font-size:12.5px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:12px 15px;margin-bottom:20px;display:flex;gap:9px;align-items:flex-start;line-height:1.45}
.disclaim::before{content:"";flex:none;width:16px;height:16px;margin-top:1px;border-radius:50%;background:var(--tint) center/13px no-repeat;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235b6168' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M12 16v-4M12 8h.01'/%3E%3C/svg%3E")}

/* ---- KPI-rij ---- */
.rep-hero{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:0 0 20px}
.rep-hero .hstat{position:relative;background:var(--surface);border:1px solid var(--line);padding:18px 18px 16px;border-radius:var(--r-lg);box-shadow:var(--sh-xs);transition:var(--t)}
.rep-hero .hstat:hover{box-shadow:var(--sh-sm);border-color:var(--line2)}
.rep-hero .hk{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);margin-bottom:8px;font-weight:600}
.rep-hero .hv{font-size:23px;font-weight:800;font-variant-numeric:tabular-nums;display:flex;align-items:center;gap:9px;letter-spacing:-.02em}
.rep-hero .hv.hvdot{font-size:15.5px;font-weight:700}
.rep-hero .hdot{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
@media (max-width:720px){.rep-hero{grid-template-columns:repeat(2,1fr);gap:10px}.rep-hero .hv{font-size:19px}}

/* ---- kaarten / data ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:18px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px;box-shadow:var(--sh-xs);transition:box-shadow var(--t),border-color var(--t)}
.card:hover{box-shadow:var(--sh-sm);border-color:var(--line2)}
.card h3{font-size:12.5px;margin-bottom:16px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.05em;display:flex;justify-content:space-between;align-items:center;gap:8px}
.card h3 .hl3{display:inline-flex;align-items:center;gap:9px}
.card h3 .hic{width:28px;height:28px;border-radius:8px;background:var(--primary-tint);color:var(--primary-d);display:inline-flex;align-items:center;justify-content:center;flex:none}
.card h3 .hic .i{width:16px;height:16px}
.src{font-size:9.5px;font-weight:700;letter-spacing:.04em;color:var(--muted);background:var(--tint);border:1px solid var(--line);border-radius:6px;padding:3px 7px;text-transform:uppercase}
.row{display:flex;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.row:last-child{border-bottom:none}
.row .k{color:var(--muted)}.row .v{font-weight:600;text-align:right;font-variant-numeric:tabular-nums}
.na{color:var(--faint);font-weight:500;font-style:italic}
.bars{display:flex;align-items:flex-end;gap:8px;height:82px;margin-top:10px}
.bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}
.bar .b{width:100%;background:var(--primary-tint-2);border-radius:5px 5px 0 0;transition:height .5s var(--ease)}
.bar .b.last{background:var(--primary)}
.bar .yr{font-size:10.5px;color:var(--faint);font-weight:500}
.checks .chk{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.checks .chk:last-child{border-bottom:none}
.dot{width:24px;height:24px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;color:#fff;margin-top:1px}
.dot .i{width:14px;height:14px}
.dot.ok{background:var(--green)}.dot.no{background:var(--red)}.dot.wn{background:var(--amber)}
.chk .ct{font-weight:700;font-size:14.5px}.chk .cd{font-size:13.5px;color:var(--muted);margin-top:2px}
.chk .lead{margin-top:9px}
.lead a{display:inline-flex;align-items:center;gap:6px;background:var(--ink);color:#fff;font-size:12.5px;font-weight:600;padding:8px 14px;border-radius:9px;transition:var(--t-fast)}
.lead a:hover{background:var(--primary);transform:translateY(-1px)}
.pill{border-radius:8px;padding:7px 12px;font-size:12.5px;font-weight:600}
.pill.alert{background:var(--red-bg);color:var(--red)}.pill.clean{background:var(--green-bg);color:var(--green)}

/* ============================================================ OBJECTS */
.obj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:22px}
.obj{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 19px;position:relative;cursor:pointer;box-shadow:var(--sh-xs);transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.obj:hover{box-shadow:var(--sh);border-color:var(--line2);transform:translateY(-2px)}
.obj .star{position:absolute;top:14px;right:14px;cursor:pointer;color:#c7cabf;line-height:1;background:none;border:none;padding:4px;transition:var(--t-fast)}
.obj .star:hover{color:var(--primary-l);transform:scale(1.12)}
.obj .star.on{color:var(--primary)}
.obj .star .i{width:18px;height:18px}
.obj .oa{font-weight:700;font-size:15.5px;padding-right:26px;letter-spacing:-.01em}
.obj .om{font-size:12.5px;color:var(--muted);margin:3px 0 14px}
.obj .orow{display:flex;justify-content:space-between;font-size:13.5px;padding:4px 0}
.obj .orow .k{color:var(--muted)}
.obj .ofoot{display:flex;gap:7px;align-items:center;margin-top:14px;flex-wrap:wrap}
.tagsel{font-size:12px;border:1px solid var(--line2);border-radius:8px;padding:6px 9px;background:var(--surface);color:var(--ink);cursor:pointer;font-weight:500}
.mini{font-size:11px;font-weight:700;padding:3px 9px;border-radius:6px;border:1px solid transparent}
.score-max{font-size:13px;color:var(--faint);font-weight:600;margin-left:1px}
.score-sub{font-size:11.5px;font-weight:600;margin-top:2px}
.mini.r{background:var(--red-bg);color:var(--red)}.mini.g{background:var(--green-bg);color:var(--green)}
.empty{text-align:center;padding:72px 24px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);margin-top:22px;box-shadow:var(--sh-xs)}
.empty .ei{width:56px;height:56px;border-radius:16px;background:var(--tint);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.empty .ei .i{width:28px;height:28px;opacity:.5}
.empty h3{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:6px}
.empty p{max-width:380px;margin:0 auto 20px;font-size:14.5px}

/* ============================================================ TABLES */
.tbl-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg);margin-top:10px;box-shadow:var(--sh-xs);-webkit-overflow-scrolling:touch}
table.tbl{width:100%;border-collapse:collapse;font-size:13.5px;background:var(--surface);min-width:680px}
.tbl-wrap table.tbl{border:none;border-radius:0;margin-top:0}
.tbl th{text-align:left;background:var(--surface-2);color:var(--muted);font-weight:700;font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;padding:13px 15px;border-bottom:1px solid var(--line);position:sticky;top:0;white-space:nowrap}
.tbl td{padding:13px 15px;border-bottom:1px solid var(--line);font-variant-numeric:tabular-nums}
.tbl tr:last-child td{border-bottom:none}
.tbl tr.click{cursor:pointer;transition:var(--t-fast)}.tbl tr.click:hover td{background:var(--surface-2)}
.cmp-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg);margin-top:22px;box-shadow:var(--sh-xs)}
.cmp{width:100%;border-collapse:collapse;font-size:14px;background:var(--surface);min-width:560px}
.cmp th,.cmp td{padding:13px 16px;border-bottom:1px solid var(--line);text-align:left}
.cmp th{background:var(--ink);color:#fff;font-weight:700;font-size:14px}
.cmp td.k{color:var(--muted);font-weight:600;width:200px;background:var(--surface-2)}
.cmp tr:last-child td{border-bottom:none}
.cmp tr:hover td:not(.k){background:var(--surface-2)}
.sel-list{display:flex;flex-wrap:wrap;gap:8px;margin:22px 0}
.sel-pill{display:flex;align-items:center;gap:9px;border:1px solid var(--line2);background:var(--surface);border-radius:20px;padding:7px 9px 7px 15px;font-size:13px;font-weight:500;box-shadow:var(--sh-xs)}
.sel-pill button{border:none;background:var(--tint);border-radius:50%;width:19px;height:19px;cursor:pointer;color:var(--muted);font-size:12px;display:flex;align-items:center;justify-content:center;transition:var(--t-fast)}
.sel-pill button:hover{background:var(--red-bg);color:var(--red)}

/* ============================================================ BULK */
.bulk-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:22px}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px;box-shadow:var(--sh-xs)}
.panel h3{font-size:15.5px;font-weight:700;margin-bottom:4px;letter-spacing:-.01em}
.panel .hint{font-size:13.5px;color:var(--muted);margin-bottom:16px}
.dropzone{border:1.5px dashed var(--line2);border-radius:var(--r-lg);padding:38px 18px;text-align:center;cursor:pointer;transition:var(--t);color:var(--muted);background:var(--surface-2)}
.dropzone:hover,.dropzone.drag{border-color:var(--primary);background:var(--primary-tint);color:var(--ink)}
.dropzone .big{opacity:.5;display:flex;justify-content:center;margin-bottom:10px}
.dropzone:hover .big,.dropzone.drag .big{opacity:1;color:var(--primary)}
.dropzone .big .i{width:32px;height:32px}
.dropzone b{color:var(--primary)}
.filechips{display:flex;flex-direction:column;gap:8px;margin-top:16px}
.filechip{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:10px 13px;font-size:13px}
.filechip .fn{font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.filechip .ct{color:var(--green);font-weight:700}
textarea{width:100%;min-height:158px;border:1px solid var(--line2);border-radius:var(--r);padding:14px 16px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:13.5px;color:var(--ink);outline:none;resize:vertical;background:var(--surface-2);transition:var(--t-fast)}
textarea:focus{border-color:var(--primary);box-shadow:var(--sh-ring);background:var(--surface)}
.bulk-bar{display:flex;gap:11px;align-items:center;margin:22px 0;flex-wrap:wrap}
.stat{display:flex;gap:14px;margin:22px 0;flex-wrap:wrap}
.stat .s{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 22px;min-width:148px;box-shadow:var(--sh-xs)}
.stat .s .n{font-size:27px;font-weight:800;color:var(--ink);letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.stat .s .l{font-size:12.5px;color:var(--muted);margin-top:2px}
.spin{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite;vertical-align:-3px}
.btn.ghost .spin,.dropzone .spin{border-color:var(--line2);border-top-color:var(--primary)}
@keyframes sp{to{transform:rotate(360deg)}}

/* ============================================================ SEARCH CARD */
.searchcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:26px;box-shadow:var(--sh)}
.addr-fields{display:flex;gap:10px;align-items:flex-end}
.af{display:flex;flex-direction:column;gap:7px}
.af label{font-size:11.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.af input{height:52px;border:1px solid var(--line2);border-radius:12px;padding:0 16px;font-size:16px;background:var(--surface-2);color:var(--ink);outline:none;font-family:inherit;transition:var(--t-fast)}
.af input:focus{border-color:var(--primary);box-shadow:var(--sh-ring);background:var(--surface)}
.af input::placeholder{color:var(--faint)}
.af-pc{flex:1}.af-pc input{width:100%;text-transform:uppercase;font-weight:600;letter-spacing:1px}
.af-nr input{width:88px}.af-tv input{width:104px}
.resolved{margin-top:14px;font-size:14px;color:var(--muted);min-height:20px}
.resolved b{color:var(--ink);font-weight:600}
.toggle{display:inline-flex;border:1px solid var(--line2);border-radius:11px;overflow:hidden;background:var(--surface);box-shadow:var(--sh-xs)}
.toggle button{border:none;background:transparent;color:var(--muted);padding:9px 18px;font-size:13.5px;cursor:pointer;font-weight:600;transition:var(--t-fast)}
.toggle button.on{background:var(--ink);color:#fff}
.chips{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:16px}
.chips .lbl{font-size:13px;color:var(--muted)}
.chip{border:1px solid var(--line2);background:var(--surface);border-radius:20px;padding:6px 13px;font-size:13px;cursor:pointer;color:var(--muted);font-weight:500;transition:var(--t-fast)}
.chip:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-tint)}
.toolbar{display:flex;align-items:center;gap:13px;margin-top:18px;flex-wrap:wrap}

/* ---- inline alert / foutmelding ---- */
.alertbox{display:flex;gap:11px;align-items:flex-start;border-radius:11px;padding:13px 15px;font-size:14px;line-height:1.45;margin-top:14px;border:1px solid}
.alertbox.err{background:var(--red-bg);border-color:#eccac4;color:#8a2c22}
.alertbox.warn{background:var(--amber-bg);border-color:#ecd9a6;color:#7a5409}
.alertbox.info{background:var(--blue-bg);border-color:#c3d3ef;color:#274d8c}
.alertbox .i{width:18px;height:18px;flex:none;margin-top:1px}
.alertbox b{font-weight:700}

/* ---- skeletons ---- */
.sk{background:linear-gradient(100deg,var(--tint) 30%,#f6f6f1 50%,var(--tint) 70%);background-size:200% 100%;animation:shimmer 1.3s var(--ease) infinite;border-radius:8px}
@keyframes shimmer{to{background-position:-200% 0}}
.sk-line{height:13px;margin:9px 0;border-radius:6px}
.sk-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px}
.sk-kpi{height:84px;border-radius:var(--r-lg)}

/* ============================================================ FOOTER */
footer.site{background:var(--ink);color:#fff;padding:60px 0 34px}
footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
footer h4{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.5);margin-bottom:16px;font-weight:700}
footer a{display:block;color:rgba(255,255,255,.82);font-size:14.5px;padding:5px 0;cursor:pointer;transition:var(--t-fast)}
footer a:hover{color:#fff;transform:translateX(2px)}
footer .disc{margin-top:38px;padding-top:24px;border-top:1px solid rgba(255,255,255,.14);font-size:12.5px;color:rgba(255,255,255,.55);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ============================================================ RESPONSIVE */
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;gap:36px}.hero{min-height:auto}.hero-grid .mock{transform:none}.sec-head{margin-bottom:36px}}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:36px}}
@media(max-width:820px){.stepcard{grid-template-columns:1fr;gap:18px}.bulk-cols{grid-template-columns:1fr}}
@media(max-width:760px){footer .cols{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.nav-desktop{display:none}.hamburger{display:inline-flex}.nav .right .src-ind{display:none}}
@media(max-width:620px){.addr-fields{flex-wrap:wrap}.af{flex:1}.af input{width:100%}.af-nr input,.af-tv input{width:100%}}
@media(max-width:560px){
  .inner{padding:0 16px}
  .sec-head{margin-bottom:26px}
  .trust{gap:18px 26px;margin-top:28px;padding-top:22px}
  .trust .t .v{font-size:19px}
  .pagehead{padding:26px 0 4px}
  .rep-head{padding:20px 18px}.rep-head .addr{font-size:19px}
  .grid{grid-template-columns:1fr;gap:14px}
  .card{padding:18px}
  .searchcard{padding:20px}
  .ctaband{padding:38px 24px}
  footer.site{padding:42px 0 26px}
  footer .cols{grid-template-columns:1fr;gap:26px}
}

/* ============================================================ BULK EXPORT-CATS */
.exp-cats{display:flex;flex-wrap:wrap;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:13px 15px;margin:0 0 16px;box-shadow:var(--sh-xs)}
.exp-cats .ec-lbl{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);margin-right:6px}
.ec-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:20px;padding:6px 12px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;user-select:none;transition:var(--t-fast)}
.ec-chip:hover{border-color:var(--line2);background:var(--surface-2)}
.ec-chip input{margin:0;accent-color:var(--primary);width:15px;height:15px}
.ec-chip input:disabled{opacity:.5}
.ec-chip .ec-dot{width:10px;height:10px;border-radius:3px;flex:0 0 auto}
.ec-sp{flex:1}
.ec-mini{border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:6px 12px;font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer;transition:var(--t-fast)}
.ec-mini:hover{border-color:var(--primary);color:var(--primary)}
@media(max-width:560px){.exp-cats{padding:10px}.ec-chip{font-size:12px;padding:5px 10px}}

/* ============================================================ PRINT / PDF */
@media print{
  .nav,footer.site,.crumb,.rh-btn,.hamburger,.mobile-overlay,.appwrap>div:last-child{display:none !important}
  body{background:#fff}
  .appwrap{padding:0}
  .rep-head{background:#fff;color:var(--ink);border:1px solid var(--line);margin-top:0;box-shadow:none}
  .rep-head::before{display:none}
  .rep-head .meta{opacity:1;color:var(--muted)}
  .rep-hero .hstat,.card,.mock{box-shadow:none}
  .grid{display:block}
  .card{break-inside:avoid;page-break-inside:avoid;margin-bottom:12px}
  .lead a{background:none;color:var(--primary);padding:0}
}

/* ============================================================================
   ART-DIRECTION LAAG (v3) — "editorial premium meets precisie-instrument"
   Mix A+B: meetraster + RD-coördinaten als signature, mono/tabular cijfers,
   full-bleed cinematische hero, sticky 'adres → dossier', rapport-als-document.
   Bovenop het bestaande systeem; alle class-namen blijven werken.
   ============================================================================ */
:root{
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --grid-line:rgba(21,23,26,.05);
  --grid-line-2:rgba(21,23,26,.08);
}
/* signature meetraster + zachte accent-glow, hergebruikbaar achter secties */
.mesh{position:relative;isolation:isolate}
.mesh::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
  background-size:34px 34px;-webkit-mask-image:radial-gradient(120% 100% at 50% 0%,#000,transparent 78%);mask-image:radial-gradient(120% 100% at 50% 0%,#000,transparent 78%)}

/* mono/tabular cijfers = precisie-instrument */
.trust .t .v,.rep-hero .hv,.stat .s .n,.row .v,.cnt,.pv-stat .v,.bar .yr,.dash-row .dv .p,
.cmp td,.tbl td,.bignum,.coord,.hk,.lbadge{font-variant-numeric:tabular-nums}
.coord,.sigtag,.bignum-lbl{font-family:var(--mono)}

/* signature-tag: uppercase mono microlabel (bron/sectie/status) */
.sigtag{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10.5px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.sigtag::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--primary);flex:none}
.coord{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--faint)}

/* ---------- HERO: cinematisch, bijna full-bleed ---------- */
.hero{padding:clamp(40px,6vw,80px) 0 clamp(48px,7vw,88px)}
.hero::after{background-size:34px 34px;opacity:.4}
.hero-grid{grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,68px);align-items:center}
.hero h1{font-size:clamp(38px,6vw,72px);line-height:1.02;letter-spacing:-.04em;font-weight:800;margin-bottom:22px}
.hero h1 .hl{position:relative;color:var(--primary)}
.hero .sub{font-size:clamp(16px,1.5vw,19px);max-width:46ch}
.hero .tagbadge{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:600}
.hero-cta .btn{height:52px;padding:0 26px;font-size:15px}
/* trust-rij: groot getal-anker met count-up */
.trust{gap:clamp(20px,4vw,48px)}
.trust .t .v{font-size:clamp(30px,3.4vw,46px);font-weight:800;letter-spacing:-.03em;line-height:1}
.trust .t .l{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-top:6px;max-width:20ch}

/* ---------- HERO instrument-paneel + blueprint ---------- */
.hero-panel{position:relative}
.bp{position:relative;background:var(--surface);border:1px solid var(--line2);border-radius:var(--r-xl);
  box-shadow:var(--sh-lg);overflow:hidden}
.bp .bp-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.bp .bp-art{position:relative;height:118px;background:var(--ink);overflow:hidden}
.bp .bp-art svg{position:absolute;inset:0;width:100%;height:100%}
.bp .bp-art .glow{position:absolute;inset:0;background:radial-gradient(60% 90% at 80% 10%,rgba(15,122,78,.4),transparent 70%)}
.bp .bp-chips{position:absolute;left:14px;bottom:12px;right:14px;display:flex;gap:7px;flex-wrap:wrap}
.bp .bp-chip{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.05em;color:#fff;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:7px;padding:4px 8px;backdrop-filter:blur(4px)}
.bp .searchcard{border:none;border-radius:0;box-shadow:none;background:transparent;padding:20px}
/* draw-in van de blueprint-lijnen (op load, niet via scroll-reveal) */
.draw{stroke-dasharray:var(--len,600);stroke-dashoffset:var(--len,600);animation:draw 1.2s var(--ease) .2s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.bp .bp-chip{opacity:0;transform:translateY(6px);animation:chipin .5s var(--ease) forwards}
.bp .bp-chip:nth-child(1){animation-delay:.55s}
.bp .bp-chip:nth-child(2){animation-delay:.67s}
.bp .bp-chip:nth-child(3){animation-delay:.79s}
.bp .bp-chip:nth-child(4){animation-delay:.91s}
@keyframes chipin{to{opacity:1;transform:none}}

/* ---------- SIGNATURE-STRIP (editorial schaalcontrast) ---------- */
.sigstrip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface-2)}
.sigstrip .inner{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:clamp(28px,4vw,64px);padding-top:30px;padding-bottom:30px}
.sigstrip .coord{font-size:11.5px;line-height:1.7}
.bignum{display:flex;align-items:center;gap:14px}
.bignum .n{font-size:clamp(38px,4.4vw,56px);font-weight:800;letter-spacing:-.04em;line-height:.92}
.bignum .n .accent{color:var(--primary)}
.bignum-lbl{font-size:10.5px;letter-spacing:.11em;text-transform:uppercase;color:var(--faint);max-width:13ch;line-height:1.4}
@media(max-width:760px){
  .sigstrip .inner{grid-template-columns:1fr 1fr;gap:22px}
  .sigstrip .coord{grid-column:1 / -1}
}

/* ---------- WERKWIJZE: grote stap-kaarten (à la huurpunten) ---------- */
.stepsec .sec-head{margin-left:auto;margin-right:auto;text-align:center}
.stepbig{position:relative;display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(28px,4vw,60px);align-items:center;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-2xl);padding:clamp(28px,3.6vw,52px);margin-bottom:18px;overflow:hidden;box-shadow:var(--sh-xs)}
.stepbig .ghostnum{position:absolute;top:-14px;right:26px;font-weight:800;font-size:clamp(96px,13vw,180px);color:var(--tint);line-height:1;letter-spacing:-.05em;pointer-events:none;z-index:0}
.stepbig>*{position:relative;z-index:1}
.stepbig .stepbig-badge{width:46px;height:46px;border-radius:14px;background:linear-gradient(140deg,var(--primary-l),var(--primary-d));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:17px;margin-bottom:18px;box-shadow:0 6px 16px -6px rgba(15,122,78,.55)}
.stepbig h3{font-size:clamp(22px,2.5vw,30px);font-weight:800;letter-spacing:-.025em;margin-bottom:10px;line-height:1.07}
.stepbig p{color:var(--muted);font-size:16px;max-width:42ch}
.stepbig .mock{box-shadow:var(--sh)}
@media(max-width:820px){.stepbig{grid-template-columns:1fr;gap:24px;padding:26px}.stepbig .ghostnum{font-size:84px;top:-8px;right:14px}}

/* ---------- RAPPORT compacter (minder verticale ruimte) ---------- */
.appwrap .grid{grid-template-columns:repeat(auto-fit,minmax(264px,1fr));gap:12px}
.appwrap .card{padding:16px 18px}
.appwrap .card h3{margin-bottom:11px}
.appwrap .row{padding:6px 0;font-size:13.5px}
.rep-hero{gap:12px;margin-bottom:16px}
.rep-hero .hstat{padding:14px 16px 13px}
.rep-hero .hk{margin-bottom:6px}
.disclaim{padding:10px 14px;margin-bottom:16px}

/* ---------- "Wat zit er in elk rapport": split + compacte gekleurde lijst ---------- */
.featsplit{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:center}
.featsplit .mock{box-shadow:var(--sh)}
.featsplit .mock .pv-line span:first-child{color:var(--muted)}
.featsplit .mock .pv-line .lead{color:var(--amber);background:var(--amber-bg);font-weight:600;font-size:11.5px;padding:2px 8px;border-radius:6px}
.featlist{display:flex;flex-direction:column;gap:4px}
.fitem{display:grid;grid-template-columns:42px 1fr;gap:14px;align-items:center;padding:11px 12px;border-radius:var(--r-lg);transition:background var(--t-fast),transform var(--t-fast)}
.fitem:hover{background:var(--surface);transform:translateX(2px)}
.fitem .fic{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex:none}
.fitem .fic .i{width:21px;height:21px}
.fitem .fic.g{background:var(--primary-tint);color:var(--primary-d)}
.fitem .fic.b{background:var(--blue-bg);color:var(--blue)}
.fitem .fic.a{background:var(--amber-bg);color:var(--amber)}
.fitem .ft{font-size:14.5px;font-weight:700;letter-spacing:-.01em;line-height:1.2}
.fitem .fd{font-size:13px;color:var(--muted);line-height:1.4;margin-top:2px}
@media(max-width:820px){.featsplit{grid-template-columns:1fr;gap:26px}.featsplit>div:first-child{order:-1}}

/* ---------- MEER KLEUR: groen als primaire kleur i.p.v. near-black ---------- */
.btn{background:var(--primary);box-shadow:0 1px 2px rgba(11,99,63,.25),0 9px 20px -10px rgba(15,122,78,.5),inset 0 1px 0 rgba(255,255,255,.14)}
.btn:hover{background:var(--primary-d);box-shadow:0 2px 5px rgba(11,99,63,.3),0 14px 28px -10px rgba(15,122,78,.55)}
.btn.onlight{background:#fff;color:var(--ink);box-shadow:var(--sh-sm)}
.btn.onlight:hover{background:#f1f1ec}
.brand .mk{background:linear-gradient(140deg,var(--primary-l),var(--primary-d));box-shadow:0 5px 14px -5px rgba(15,122,78,.5),inset 0 0 0 1px rgba(255,255,255,.1)}
.navlink .cnt,.cnt{background:var(--primary)}
.toggle button.on{background:var(--primary)}
.lead a{background:var(--primary)}
.lead a:hover{background:var(--primary-d)}
/* speelse gekleurde kerncijfers (à la huurpunten) */
.trust .t:nth-child(1) .v{color:var(--primary)}
.trust .t:nth-child(2) .v{color:var(--blue)}
.trust .t:nth-child(3) .v{color:var(--amber)}
.sigstrip .bignum:nth-of-type(1) .n{color:var(--primary)}
.sigstrip .bignum:nth-of-type(2) .n{color:var(--blue)}

/* ---------- FEATURES als editorial hairline-index (geen identieke kaartrijen) ---------- */
.feat-grid{grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line)}
.feat{background:transparent;border:none;border-bottom:1px solid var(--line);border-radius:0;padding:26px 28px 26px 0;
  display:grid;grid-template-columns:48px 1fr;gap:18px;align-items:start}
.feat:nth-child(odd){padding-right:40px;border-right:1px solid var(--line)}
.feat:nth-child(even){padding-left:40px}
.feat:hover{transform:none;box-shadow:none;background:linear-gradient(90deg,var(--primary-tint),transparent 60%)}
.feat .ic{margin-bottom:0;width:44px;height:44px}
.feat h3{font-size:17px;margin-bottom:4px}
@media(max-width:680px){.feat-grid{grid-template-columns:1fr}.feat,.feat:nth-child(odd),.feat:nth-child(even){padding:22px 0;border-right:none}}

/* ---------- RAPPORT als uitgegeven document ---------- */
.rep-head{align-items:flex-end}
.rep-head .addr{font-size:clamp(24px,3.4vw,40px);line-height:1.02;letter-spacing:-.03em}
.rep-head .meta{font-family:var(--mono);font-size:12px;letter-spacing:.03em}
.rep-head .repcoord{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:rgba(255,255,255,.55);margin-top:10px;text-transform:uppercase}
.rep-hero .hstat{box-shadow:none;border-color:var(--line)}
.rep-hero .hk{font-family:var(--mono);letter-spacing:.1em}
.rep-hero .hv{font-size:clamp(20px,2.4vw,26px)}
.card{box-shadow:none}
.card:hover{box-shadow:var(--sh-xs)}
.card h3{font-family:var(--mono);letter-spacing:.08em;font-size:11px}
.src{font-family:var(--mono)}
.disclaim{font-family:var(--mono);font-size:11.5px;letter-spacing:.01em}

/* ---------- count-up helper (verbergt sprong vóór animatie niet) ---------- */
[data-count]{font-variant-numeric:tabular-nums}

/* ---------- draw-in voor losse lijnen (sectiemarkeringen) ---------- */
.hairline-draw{height:1px;background:var(--line);transform-origin:left;transform:scaleX(0)}
.js-reveal .hairline-draw.in{animation:drawline .7s var(--ease) forwards}
@keyframes drawline{to{transform:scaleX(1)}}

/* ---------- responsive voor nieuwe blokken ---------- */
@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr}
  .hero{min-height:auto}
  .hero-panel{max-width:520px}
}
@media (prefers-reduced-motion:reduce){
  .draw,.bp .bp-chip,.js-reveal .hairline-draw.in{animation:none!important}
  .draw{stroke-dashoffset:0!important}.bp .bp-chip{opacity:1!important;transform:none!important}
  .hairline-draw{transform:none!important}
}

/* ===== Accounts: navigatie-knop + modal ===================================== */
.oc-auth{display:inline-flex;align-items:center}
.oc-acc{display:inline-flex;align-items:center;gap:9px}
.oc-acc-dot{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex:0 0 auto}
.oc-acc-email{font-size:13px;color:var(--muted);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media (max-width:900px){ .oc-auth .oc-acc-email{display:none} }

.oc-modal{position:fixed;inset:0;z-index:1000}
.oc-modal-bg{position:absolute;inset:0;background:rgba(16,24,32,.46);backdrop-filter:blur(2px);animation:ocfade .18s var(--ease)}
.oc-modal-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:min(440px,calc(100vw - 32px));background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-xl);box-shadow:var(--sh-lg);padding:30px 30px 26px;
  animation:ocpop .2s var(--ease)}
.oc-modal-x{position:absolute;top:14px;right:14px;width:34px;height:34px;border:none;background:transparent;
  color:var(--faint);border-radius:9px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.oc-modal-x:hover{background:var(--tint);color:var(--ink)}
.oc-modal-head{text-align:center;margin-bottom:20px}
.oc-modal-head .mk{width:42px;height:42px;border-radius:11px;background:var(--ink-btn);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-weight:800;letter-spacing:.5px;margin-bottom:12px}
.oc-modal-head h2{font-size:21px;font-weight:800;color:var(--ink);margin:0 0 6px}
.oc-modal-head p{font-size:14px;color:var(--muted);margin:0;line-height:1.5}
.oc-modal-body{display:flex;flex-direction:column;gap:13px}
.oc-fld{display:flex;flex-direction:column;gap:6px;font-size:12.5px;font-weight:600;color:var(--ink-2)}
.oc-fld .opt{color:var(--faint);font-weight:500}
.oc-fld input{padding:11px 13px;border:1px solid var(--border-strong);border-radius:var(--r);
  font-size:15px;font-family:inherit;color:var(--ink);background:var(--surface);transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.oc-fld input:focus{outline:none;border-color:var(--primary);box-shadow:var(--sh-ring)}
.oc-modal-body .btn{margin-top:4px;justify-content:center}
.oc-link{background:none;border:none;color:var(--primary);font-size:13px;font-weight:600;cursor:pointer;
  padding:2px;font-family:inherit;text-align:center}
.oc-link:hover{text-decoration:underline}
.oc-auth-switch{text-align:center;font-size:13px;color:var(--muted);margin-top:6px}
.oc-auth-msg:empty{display:none}
.oc-auth-msg .am{font-size:13px;line-height:1.45;padding:10px 12px;border-radius:var(--r-sm)}
.oc-auth-msg .am.err{background:var(--red-bg);color:var(--red)}
.oc-auth-msg .am.ok{background:var(--green-bg);color:var(--green)}
.oc-social{display:flex;flex-direction:column;gap:9px}
.oc-sso{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  padding:11px 14px;border:1px solid var(--border-strong);border-radius:var(--r);
  background:var(--surface);color:var(--ink);font-size:14.5px;font-weight:600;font-family:inherit;
  cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast)}
.oc-sso:hover{background:var(--tint);border-color:var(--muted)}
.oc-sso svg{flex:0 0 auto}
.oc-or{display:flex;align-items:center;gap:12px;color:var(--faint);font-size:12px;margin:4px 0}
.oc-or::before,.oc-or::after{content:"";flex:1;height:1px;background:var(--line)}
@keyframes ocfade{from{opacity:0}to{opacity:1}}
@keyframes ocpop{from{opacity:0;transform:translate(-50%,-46%) scale(.98)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}

/* ===== Vastgoedmappen (Fase 2) ============================================= */
.folderbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:0 0 22px}
.fchip{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border:1px solid var(--line2);
  border-radius:999px;background:var(--surface);color:var(--ink-2);font-size:13.5px;font-weight:600;
  font-family:inherit;cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast)}
.fchip:hover{background:var(--tint);border-color:var(--border-strong)}
.fchip.on{background:var(--ink-btn);border-color:var(--ink-btn);color:#fff}
.fchip.on .fc{background:rgba(255,255,255,.22);color:#fff}
.fchip .fdot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.fchip .fc{display:inline-flex;align-items:center;justify-content:center;min-width:19px;height:19px;
  padding:0 5px;border-radius:999px;background:var(--tint);color:var(--muted);font-size:11.5px;font-weight:700}
.fchip.add{border-style:dashed;color:var(--primary);background:transparent}
.fchip.add:hover{background:var(--primary-tint);border-color:var(--primary-l)}
.fbar-actions{display:inline-flex;gap:8px;margin-left:6px}
.ofoot .folsel{max-width:140px}

/* ===== Gericht zoeken & filteren in Mijn objecten ========================== */
.objfilter{display:flex;flex-direction:column;gap:12px;margin:0 0 20px;padding:16px;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}
.of-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.objsearch{flex:1 1 280px;min-width:200px;padding:10px 14px;border:1px solid var(--border-strong);
  border-radius:var(--r);font-size:14.5px;font-family:inherit;color:var(--ink);background:var(--surface);
  transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.objsearch:focus{outline:none;border-color:var(--primary);box-shadow:var(--sh-ring)}
.objfilter .tagsel{height:40px;padding:0 12px;border:1px solid var(--border-strong);border-radius:var(--r);
  background:var(--surface);font-size:13.5px;color:var(--ink-2);font-family:inherit;cursor:pointer}
.of-lbl{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-right:2px}
.lchip{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:34px;padding:0 12px;
  border:1.5px solid var(--border-strong);border-radius:999px;background:var(--surface);color:var(--ink-2);
  font-weight:700;font-size:13px;font-family:inherit;cursor:pointer;transition:all var(--t-fast)}
.lchip:hover{border-color:var(--lc);color:var(--lc)}
.lchip.on{background:var(--lc);border-color:var(--lc);color:#fff}
.of-group{display:inline-flex;align-items:center;gap:6px}
.of-sep{color:var(--muted)}
.rng{width:110px;height:38px;padding:0 10px;border:1px solid var(--border-strong);border-radius:var(--r);
  font-size:13.5px;font-family:inherit;color:var(--ink);background:var(--surface)}
.rng.sm{width:84px}
.rng:focus{outline:none;border-color:var(--primary);box-shadow:var(--sh-ring)}
.of-ranges{padding-top:10px;border-top:1px dashed var(--border)}
.stepnum{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:999px;
  background:var(--primary);color:#fff;font-size:11px;font-weight:800;vertical-align:middle}
.stepnum.big{width:26px;height:26px;font-size:13px;flex:0 0 auto}

/* ===== Waarom-band (feitelijke trust-kaarten) =============================== */
.why-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:26px;box-shadow:var(--sh-sm);transition:transform var(--t-fast),box-shadow var(--t-fast)}
.why-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.why-ic{width:44px;height:44px;border-radius:12px;background:rgba(46,190,117,.12);color:#1e8a55;
  display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.why-card h3{font-size:16.5px;font-weight:700;margin-bottom:8px;letter-spacing:-.01em}
.why-card p{font-size:14px;color:var(--muted);line-height:1.65}

/* ===== FAQ =================================================================== */
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}
.faq summary{display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer;
  padding:16px 20px;font-weight:600;font-size:15px;list-style:none;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq .faq-ic{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:26px;height:26px;
  border-radius:999px;border:1px solid var(--border-strong);color:var(--muted);transform:rotate(45deg);
  transition:transform .25s ease,background .25s ease}
.faq[open] .faq-ic{transform:rotate(0deg);background:var(--ink);border-color:var(--ink);color:#fff}
.faq .faq-a{padding:0 20px 18px;font-size:14.5px;color:var(--muted);line-height:1.7;max-width:62ch}

/* ===== KPI-dashboard-strip (werkruimte) ====================================== */
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin:0 0 18px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:14px 16px;box-shadow:var(--sh-sm);min-width:0}
.kpi-l{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.kpi-v{font-size:22px;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kpi-v.warn{color:var(--red)}
.kpi-s{font-size:12px;color:var(--faint);margin-top:2px}
.kpi-bars{display:flex;align-items:flex-end;gap:5px;height:44px;padding-top:2px}
.kb{display:flex;flex-direction:column;align-items:center;gap:2px}
.kb-bar{width:11px;border-radius:3px 3px 0 0}
.kb span{font-size:9.5px;color:var(--faint);font-weight:600}
@media(max-width:920px){.kpis{grid-template-columns:repeat(2,1fr)}.kpi:last-child{grid-column:span 2}}

/* ===== Registratie-voordelen in modal ======================================== */
.oc-benefits{list-style:none;margin:12px auto 0;padding:0;max-width:330px;text-align:left}
.oc-benefits li{display:flex;align-items:flex-start;gap:8px;font-size:13.5px;color:var(--ink-2);padding:4px 0}
.oc-benefits li .i{flex:0 0 auto;color:#1e8a55;margin-top:2px}

/* ===== Simpele footer (doorverwijzing naar Label & Lens) ===================== */
.foot-simple{display:flex;align-items:center;gap:28px;flex-wrap:wrap;padding-bottom:26px}
.foot-tag{flex:1 1 380px;color:rgba(255,255,255,.78);font-size:14.5px;line-height:1.65;max-width:560px;margin:0}
.foot-tag a{display:inline;color:#2EBE75;text-decoration:none;font-weight:600;padding:0}
.foot-tag a:hover{text-decoration:underline}
.foot-simple .btn{flex:0 0 auto}
@media(max-width:720px){.foot-simple{flex-direction:column;align-items:flex-start;gap:18px}}
