/* ===== Canoniek — design system (hand-off 2026-06-26) ===== */
:root{
  --char:#1D1D1D; --cream:#F5F3EF; --yellow:#F3F764; --dot:#F3F764;
  --sand:#E8E0D4; --sandline:#D8CFC0; --body:#3A3A3A; --body2:#2A2A2A;
  --grey:#7A7A7A; --line:#E2DFD8; --cline:#3A3A3A; --gold:#C9A23A;
  --cascbg:#FBFAF7; --cascarrow:#B8B0A2;
  --ontxt:#F5F3EF; --onbody:rgba(245,243,239,.82); --onmut:rgba(245,243,239,.6); --onfaint:rgba(245,243,239,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--char);font-family:'DM Sans',sans-serif;font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Archivo',sans-serif;font-weight:800;letter-spacing:-.02em;line-height:1.1}
a{color:inherit}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
@keyframes revealUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* type helpers */
.eyebrow{display:block;font-size:13px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--grey);margin-bottom:18px}
.eyebrow.geel{color:var(--yellow)} .eyebrow.gold{color:var(--gold)}
.lead{font-family:'Archivo',sans-serif;font-weight:700;font-size:22px;line-height:1.4;letter-spacing:-.015em;margin-top:6px}
h1{font-size:clamp(34px,3.6vw,46px);line-height:1.08;letter-spacing:-.025em}
h2{font-size:30px}
.bodytext p{color:var(--body)} .bodytext p+p{margin-top:16px}

/* buttons */
.btn{display:inline-block;font-family:'Archivo';font-weight:800;font-size:15px;padding:14px 22px;border-radius:2px;text-decoration:none;transition:all .25s ease;border:1px solid transparent;cursor:pointer}
.btn-accent{background:var(--yellow);color:var(--char)} .btn-accent:hover{background:#e7ea50}
.btn-ghost-light{border-color:rgba(245,243,239,.45);color:var(--cream)} .btn-ghost-light:hover{background:var(--cream);color:var(--char)}
.btn-ghost-dark{border-color:var(--char);color:var(--char)} .btn-ghost-dark:hover{background:var(--char);color:var(--cream)}

/* nav (charcoal solid; over = transparent on hero) */
.nav{position:sticky;top:0;z-index:30;background:var(--char);border-bottom:1px solid var(--cline)}
.nav.over{position:absolute;left:0;right:0;background:transparent;border-bottom:none}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{font-family:'Archivo';font-weight:800;font-size:25px;letter-spacing:-.04em;text-decoration:none;color:var(--cream);display:inline-flex;align-items:baseline}
.brand .dot{display:inline-block;width:7px;height:7px;background:var(--yellow);margin-left:3px}
.nav .links{display:flex;gap:26px;align-items:center}
.nav .links a{font-size:13px;font-weight:500;color:var(--cream);opacity:.8;text-decoration:none;padding-bottom:3px;border-bottom:1px solid transparent}
.nav .links a:hover{opacity:1;border-bottom-color:var(--yellow)}
.nav .links a.active{opacity:1;border-bottom-color:var(--yellow)}
.nav .links .cta{background:var(--yellow);color:var(--char);opacity:1;padding:9px 16px;border-radius:2px;font-family:'Archivo';font-weight:700;border:none}
.nav .links .cta:hover{background:#e7ea50}
.navtoggle{display:none}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;margin:-8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--cream);transition:.2s}

/* sections */
section{padding:clamp(72px,11vh,112px) 0}
.bg-cream{background:var(--cream);color:var(--char)}
.bg-char{background:var(--char);color:var(--ontxt)}
.bg-char .eyebrow{color:var(--onmut)} .bg-char .eyebrow.geel{color:var(--yellow)}
.bg-char h1,.bg-char h2,.bg-char h3,.bg-char h4{color:var(--ontxt)}
.bg-char .bodytext p{color:var(--onbody)} .bg-char .lead{color:var(--ontxt)}
.seam{border-top:1px solid var(--line)}

/* hero */
.hero{position:relative;min-height:clamp(600px,82vh,720px);background:var(--char);color:var(--cream);overflow:hidden;display:flex;align-items:flex-end}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(1.28) saturate(1.04)}
.hero::after{content:"";position:absolute;inset:0;background:rgba(16,13,10,.4)}
.hero .gradL{position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,13,10,.82) 0%,rgba(16,13,10,.4) 34%,rgba(16,13,10,0) 64%)}
.hero .wrap{position:relative;z-index:2;padding:120px 32px 72px}
.hero .eyebrow{display:flex;align-items:center;gap:9px;font-size:12px;letter-spacing:.2em;color:var(--cream);opacity:.92}
.hero .eyebrow::before{content:"";width:9px;height:9px;background:var(--yellow);display:inline-block}
.hero h1{font-size:clamp(40px,4vw,54px);line-height:1.06;letter-spacing:-.025em;color:var(--cream);max-width:16ch}
.hero .sub{font-size:20px;color:rgba(245,243,239,.9);margin-top:20px;max-width:38ch}
.hero .cta-row{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.hero .micro{margin-top:26px;font-size:14px;color:rgba(245,243,239,.7)}
.hero .geo{margin-top:30px;padding-top:16px;border-top:1px solid rgba(245,243,239,.18);font-size:13px;color:rgba(245,243,239,.6);max-width:60ch}

/* split */
.split{display:grid;grid-template-columns:5fr 6fr;gap:72px;align-items:start}
.split.even{grid-template-columns:1fr 1fr}
.split .right{padding-top:4px}

/* 3 hairline cells */
.cols3{display:grid;grid-template-columns:repeat(3,1fr);margin-top:60px;border-top:1px solid var(--line)}
.bg-char .cols3{border-color:var(--cline)}
.cols3 .cell{padding:32px 32px 32px 0;border-bottom:1px solid var(--line)}
.bg-char .cols3 .cell{border-color:var(--cline)}
.cols3 .cell h3{font-size:18px;margin-bottom:8px}
.cols3 .cell p{font-size:16px;color:var(--body)} .bg-char .cols3 .cell p{color:var(--onbody)}

/* raamwerk 3 delen with icon */
.parts{display:flex;flex-direction:column}
.part{display:grid;grid-template-columns:34px 1fr;gap:18px;padding:24px 0;border-bottom:1px solid var(--cline);align-items:start}
.part:first-child{border-top:1px solid var(--cline)}
.part .ic{width:30px;height:30px;color:var(--yellow)}
.part h3{font-size:18px;margin-bottom:6px;color:var(--ontxt)}
.part p{font-size:16px;color:var(--onbody)}
.overline{display:flex;gap:12px;align-items:baseline;margin-top:32px;padding-top:24px;border-top:1px solid var(--cline);font-size:17px;color:var(--ontxt)}
.overline::before{content:"";width:10px;height:10px;background:var(--yellow);flex:0 0 auto;position:relative;top:4px}

/* stepper */
.intro-center{max-width:760px;margin:0 auto;text-align:center}
.stepper{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:64px;position:relative}
.stepper .step .k{font-family:'Archivo';font-weight:800;font-size:44px;letter-spacing:-.03em;color:var(--char);opacity:.18}
.bg-char .stepper .step .k{color:var(--yellow);opacity:1}
.stepper .step h3{font-size:18px;margin:8px 0 8px}
.stepper .step p{font-size:16px;color:var(--body)}

/* workflows examples */
.sidenote{margin-top:22px;font-size:14px;color:var(--onfaint);max-width:52ch;line-height:1.55}
.examples{margin-top:8px;border-top:1px solid var(--cline)}
.examples .ex{padding:20px 0;border-bottom:1px solid var(--cline);font-size:16px;color:var(--onbody);display:grid;grid-template-columns:22px 1fr;gap:8px}
.examples .ex::before{content:"→";color:var(--yellow);font-weight:700}
.lbl{font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);margin-bottom:8px;display:block}

/* bewijs portrait + points */
.bewijs-top{display:grid;grid-template-columns:4fr 7fr;gap:48px;align-items:start}
.portrait{aspect-ratio:3/4;background:#ddd6cb center/cover no-repeat;border:1px solid var(--line);filter:grayscale(100%) sepia(32%) contrast(1.08) brightness(.92)}
.portrait-wrap .cap{font-size:13px;color:var(--grey);margin-top:10px}
.points{display:grid;grid-template-columns:repeat(4,1fr);margin-top:56px;border-top:1px solid var(--line)}
.points .pt{padding:26px 22px 26px 0;border-bottom:1px solid var(--line)}
.points .pt h3{font-size:17px;margin-bottom:6px}
.points .pt p{font-size:15px;color:var(--body)}

/* framed panel + faq + begrippen grid */
.panel{background:var(--sand);border:1px solid var(--sandline);border-radius:2px;padding:40px;margin-top:36px}
.panel .qrow{border-top:1px solid var(--sandline);padding:24px 0}
.panel .qrow:first-child{border-top:none;padding-top:2px}
.panel .qrow:last-child{padding-bottom:2px}
.panel .qrow .q{font-family:'Archivo';font-weight:700;font-size:19px;margin-bottom:8px}
.panel .qrow .a{font-size:16px;color:var(--body)}
.gridpanel{background:var(--sand);border:1px solid var(--sandline);border-radius:2px;margin-top:36px;display:grid;grid-template-columns:repeat(3,1fr)}
.gridpanel .gcell{padding:26px 28px;border-right:1px solid var(--sandline);border-bottom:1px solid var(--sandline)}
.gridpanel .gcell .term{font-family:'Archivo';font-weight:700;font-size:17px;margin-bottom:6px}
.gridpanel .gcell .def{font-size:15px;color:var(--body);line-height:1.5}

/* cta band */
.ctaband{background:var(--char);color:var(--ontxt);padding:clamp(64px,9vh,96px) 0;text-align:center}
.ctaband .inner{max-width:640px;margin:0 auto}
.ctaband h2{color:var(--ontxt);font-size:34px}
.ctaband p{color:var(--onbody);margin-top:14px}
.ctaband .cta-row{margin-top:26px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* routes */
.routes{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:8px}
.route .rk{font-family:'Archivo';font-weight:800;font-size:13px;letter-spacing:.06em;color:var(--gold);margin-bottom:8px;display:block}
.bg-char .route .rk{color:var(--yellow)}
.route h3{font-size:18px;margin-bottom:8px}
.route p{font-size:16px;color:var(--body);margin-bottom:14px} .bg-char .route p{color:var(--onbody)}

/* footer */
footer{background:var(--char);color:var(--ontxt);padding:60px 0 36px;border-top:1px solid var(--cline)}
footer .fcols{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
footer .brand{color:var(--cream)}
footer .fdesc{font-size:14px;color:var(--onmut);margin-top:10px;max-width:28ch}
footer .fcol h4{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--onmut);margin-bottom:12px;font-family:'Archivo';font-weight:700}
footer .fcol a,footer .fcol span{display:block;font-size:14px;color:rgba(245,243,239,.78);text-decoration:none;margin-bottom:8px}
footer .fcol a:hover{color:var(--yellow)}
footer .legal{width:100%;border-top:1px solid var(--cline);margin-top:36px;padding-top:20px;font-size:12.5px;line-height:1.6;color:var(--onfaint)}
footer .legal a{color:var(--onmut)}

/* methodiek: drop-cap */
.dropcap::first-letter{font-family:'Archivo';font-weight:800;font-size:68px;float:left;line-height:.8;margin:6px 14px 0 0;color:var(--char)}

/* methodiek: table */
.mtable{margin-top:40px;width:100%;border-collapse:collapse}
.mtable caption{text-align:left;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--onmut);margin-bottom:16px}
.mtable th,.mtable td{text-align:left;padding:16px 18px 16px 0;border-bottom:1px solid var(--cline);vertical-align:top;font-size:15px}
.mtable thead th{color:var(--yellow);font-family:'Archivo';font-weight:700;font-size:13px;letter-spacing:.04em}
.mtable tbody th{color:var(--ontxt);font-family:'Archivo';font-weight:700;font-weight:700;width:22%}
.mtable tbody td{color:var(--onbody)}
.mtable tbody tr:hover{background:rgba(243,247,100,.06)}
.mcap{margin-top:18px;font-size:14px;color:var(--onmut)}

/* methodiek: cascade schema */
.cascade{margin-top:8px}
.casc{background:var(--cascbg);border:1px solid var(--line);border-radius:2px;padding:20px 22px;margin-bottom:6px}
.casc .ct{font-family:'Archivo';font-weight:700;font-size:16px}
.casc .cd{font-size:15px;color:var(--body);margin-top:4px}
.casc.l1{margin-left:0} .casc.l2{margin-left:40px} .casc.l3{margin-left:80px} .casc.l4{margin-left:120px}
.casc.leaf{background:var(--char);border-color:var(--char)}
.casc.leaf .ct{color:var(--ontxt)} .casc.leaf .cd{color:var(--onbody)}
.cascarrow{color:var(--cascarrow);font-size:18px;margin:2px 0 2px 18px}

/* methodiek: ecosysteem plaat */
.plate{border:1px solid var(--cline);border-radius:2px;padding:28px}
.plate .siglabel{display:inline-block;background:var(--yellow);color:var(--char);font-family:'Archivo';font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;padding:4px 8px}
.plate .sigrow{font-size:13px;color:var(--onmut);margin:10px 0 22px}
.plate .layers{position:relative;padding-left:22px}
.plate .layers::before{content:"";position:absolute;left:4px;top:6px;bottom:6px;width:2px;background:var(--yellow)}
.plate .lay{padding:10px 0;border-bottom:1px solid var(--cline);font-size:14px}
.plate .lay:last-child{border-bottom:none}
.plate .lay b{font-family:'Archivo';font-weight:700;color:var(--ontxt)} .plate .lay span{color:var(--onmut)}
.plate .lay.leaf b{color:var(--yellow)}
.plate .platecap{font-size:13px;color:var(--onmut);margin-top:18px;line-height:1.5}
.moves{margin-top:6px}
.move{display:grid;grid-template-columns:30px 1fr;gap:14px;padding:20px 0;border-bottom:1px solid var(--cline)}
.move:first-child{border-top:1px solid var(--cline)}
.move .mi{font-size:18px;color:var(--yellow);font-family:'Archivo';font-weight:800}
.move h3{font-size:18px;margin-bottom:6px} .move p{font-size:16px;color:var(--onbody)}

/* agenten / generic 3 blocks on cream */
.blocks3{display:grid;grid-template-columns:repeat(3,1fr);margin-top:56px;border-top:1px solid var(--line)}
.blocks3 .b{padding:28px 28px 28px 0;border-bottom:1px solid var(--line)}
.blocks3 .b h3{font-size:18px;margin-bottom:8px} .blocks3 .b p{font-size:16px;color:var(--body)}

/* vliegwiel two examples */
.twoex{margin-top:8px}
.twoex .e{padding:22px 0;border-top:1px solid var(--cline)}
.twoex .e:last-child{border-bottom:1px solid var(--cline)}
.twoex .e h3{font-size:18px;margin-bottom:6px} .twoex .e p{font-size:16px;color:var(--onbody)}
.hl{color:var(--char);background:var(--yellow);padding:0 .12em}.bg-char .hl{color:var(--char)}

/* voor wie rows / bewijs data rows */
.rows{margin-top:48px;border-top:1px solid var(--cline)}
.bg-cream .rows{border-color:var(--line)}
.rows .r{display:grid;grid-template-columns:240px 1fr;gap:40px;padding:24px 0;border-bottom:1px solid var(--cline)}
.bg-cream .rows .r{border-color:var(--line)}
.rows .r .rt{font-family:'Archivo';font-weight:700;font-size:18px}
.rows .r .rd{font-size:16px;color:var(--onbody)} .bg-cream .rows .r .rd{color:var(--body)}
.slot{margin-top:24px;font-size:16px;color:var(--onmut)} .bg-cream .slot{color:var(--grey)}

/* contact */
.contact2{display:grid;grid-template-columns:1.2fr 1fr;gap:56px;margin-top:8px}
.field{margin-bottom:22px}
.field label{display:block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--onmut);margin-bottom:8px}
.field input,.field textarea{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(245,243,239,.3);color:var(--cream);font-family:'DM Sans';font-size:16px;padding:8px 0}
.field input:focus,.field textarea:focus{outline:none;border-bottom-color:var(--yellow)}
.field textarea{min-height:90px;resize:vertical}
.cinfo .ci{padding:18px 0;border-bottom:1px solid var(--cline)}
.cinfo .ci .k{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--onmut);margin-bottom:6px}
.cinfo .ci a,.cinfo .ci span{font-size:16px;color:var(--ontxt)}

/* privacy text page */
.legalpage{max-width:760px;margin:0 auto}
.legalpage h1{margin-bottom:20px}
.legalpage .intro{font-size:18px;color:var(--body);margin-bottom:32px}
.legalpage h3{font-size:18px;margin:28px 0 8px}
.legalpage p{font-size:16px;color:var(--body)}
.legalpage .upd{margin-top:40px;font-size:13px;color:var(--grey)}

@media(max-width:880px){
  .hamburger{display:flex}
  .nav .links{display:none;position:absolute;top:72px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--char);border-bottom:1px solid var(--cline);padding:8px 32px 22px}
  .navtoggle:checked ~ .links{display:flex;animation:revealUp .25s ease both}
  .nav .links a{font-size:16px;padding:14px 0;border-bottom:1px solid var(--cline);opacity:.92}
  .nav .links .cta{text-align:center;margin-top:14px;padding:13px 16px;border-bottom:none}
  .hero h1{font-size:34px} .hero .wrap{padding:104px 24px 56px}
  .split,.split.even,.routes,.bewijs-top,.contact2,.cols3,.stepper,.points,.gridpanel,.blocks3{grid-template-columns:1fr;gap:28px}
  .rows .r{grid-template-columns:1fr;gap:6px}
  .casc.l2,.casc.l3,.casc.l4{margin-left:20px}
}
