/* ============================================================
   HandelWerk — gedeeld designsysteem (productie)
   Donker & krachtig · merkrood #e30613 · Space Grotesk + Hanken
   Gebruikt door homepage + alle landingspagina's.
   ============================================================ */
:root{
  --brand:#e30613;
  --bg:#0B0C0F;--bg2:#0F1116;--surface:#15171D;--surface2:#1B1E26;
  --line:rgba(255,255,255,.07);--line2:rgba(255,255,255,.13);
  --tx:#EDEEF2;--mut:#9CA0AC;--mut2:#666B78;
  --red:#e30613;
  --red2:color-mix(in oklab,var(--red),white 24%);
  --redsoft:color-mix(in srgb,var(--red),transparent 86%);
  --redline:color-mix(in srgb,var(--red),transparent 70%);
  --green:#37D481;
  --disp:"Space Grotesk",system-ui,sans-serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
  --maxw:1180px;
  --r-sm:11px;--r:14px;--r-lg:18px;--r-xl:24px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--tx);font-family:var(--sans);-webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--red);color:#fff}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:2}

.ey{font-family:var(--disp);font-size:13px;font-weight:500;letter-spacing:.02em;color:var(--red2);
  display:inline-flex;align-items:center;gap:9px;background:var(--redsoft);border:1px solid var(--redline);padding:7px 14px;border-radius:100px}
.ey .pulse{width:7px;height:7px;border-radius:50%;background:var(--red2);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(227,6,19,.5)}70%{box-shadow:0 0 0 8px rgba(227,6,19,0)}100%{box-shadow:0 0 0 0 rgba(227,6,19,0)}}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:14.5px;cursor:pointer;border:1px solid transparent;border-radius:var(--r-sm);padding:11px 18px;transition:transform .16s var(--ease),background .16s,border-color .16s,box-shadow .16s;white-space:nowrap;position:relative}
.btn-ghost{color:var(--mut)}.btn-ghost:hover{color:var(--tx)}
.btn-line{border-color:var(--line2);color:var(--tx)}.btn-line:hover{background:var(--surface2);border-color:rgba(255,255,255,.28)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 8px 22px var(--redsoft)}
.btn-red:hover{background:var(--red2);transform:translateY(-2px);box-shadow:0 14px 34px var(--redsoft)}
.btn-red::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.22) 50%,transparent 70%);background-size:240% 100%;background-position:140% 0;transition:background-position .6s var(--ease)}
.btn-red:hover::after{background-position:-40% 0}
.btn-lg{padding:14px 24px;font-size:16px;border-radius:13px}

.logo{display:flex;align-items:center;gap:11px}
.logo img{height:22px;width:auto;display:block}
.logo.lg img{height:24px}

/* nav */
.nav-shell{position:sticky;top:16px;z-index:30;padding:0 16px}
.nav{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:30px;height:60px;padding:0 12px 0 18px;background:rgba(17,19,25,.66);backdrop-filter:blur(18px);border:1px solid var(--line2);border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.42);transition:box-shadow .25s,background .25s}
.nav.scrolled{background:rgba(14,16,21,.86);box-shadow:0 16px 50px rgba(0,0,0,.6)}
.nlinks{display:flex;gap:26px;margin-left:6px}
.nlinks a{font-size:14.5px;color:var(--mut);transition:color .15s;font-weight:500;position:relative}
.nlinks a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--red2);border-radius:2px;transition:right .25s var(--ease)}
.nlinks a:hover{color:var(--tx)}.nlinks a:hover::after{right:0}
.ncta{margin-left:auto;display:flex;align-items:center;gap:8px}
.burger{display:none;margin-left:auto;width:40px;height:40px;border:1px solid var(--line2);border-radius:10px;background:transparent;cursor:pointer;position:relative}
.burger span{position:absolute;left:11px;right:11px;height:2px;background:var(--tx);border-radius:2px;transition:transform .25s var(--ease),opacity .2s}
.burger span:nth-child(1){top:14px}.burger span:nth-child(2){top:19px}.burger span:nth-child(3){top:24px}
.burger.open span:nth-child(1){transform:translateY(5px) rotate(45deg)}.burger.open span:nth-child(2){opacity:0}.burger.open span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}
.mobnav-panel{position:fixed;inset:0;z-index:25;background:rgba(11,12,15,.97);backdrop-filter:blur(10px);display:flex;flex-direction:column;justify-content:center;gap:6px;padding:40px 32px;opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .25s,transform .25s}
.mobnav-panel.open{opacity:1;pointer-events:auto;transform:none}
.mobnav-panel a{font-family:var(--disp);font-size:28px;font-weight:600;color:var(--tx);padding:12px 0;border-bottom:1px solid var(--line)}
.mobnav-panel .btn{margin-top:24px;font-size:18px;padding:16px}

/* section shell */
.band{padding:92px 0;position:relative}
.band.tight{padding:64px 0}
.center{text-align:center;max-width:600px;margin:0 auto}
.lead-h{max-width:580px}
h2.h2{font-family:var(--disp);font-size:clamp(30px,3.8vw,46px);line-height:1.06;font-weight:700;letter-spacing:-.025em;margin-top:16px;text-wrap:balance}
.center h2.h2{margin-left:auto;margin-right:auto}
.sec-sub{margin-top:16px;color:var(--mut);font-size:17.5px;line-height:1.6}
.center .sec-sub{margin-left:auto;margin-right:auto}
.section-split{border-top:1px solid var(--line)}

/* reveal */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:var(--d,0ms)}
[data-reveal="fade"]{transform:none}
[data-reveal="scale"]{transform:translateY(30px) scale(.97)}
.is-in[data-reveal]{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){[data-reveal]{opacity:1!important;transform:none!important}}

/* mock chrome / plate */
.win{background:var(--surface);border:1px solid var(--line2);border-radius:18px 18px 0 0;overflow:hidden;box-shadow:0 50px 120px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.03);transition:transform .4s var(--ease)}
.win-bar{display:flex;align-items:center;gap:8px;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--bg2)}
.win-bar .d{width:11px;height:11px;border-radius:50%;background:#2b2e37}
.win-bar .addr{margin:0 auto;font-size:12.5px;color:var(--mut2);background:#0c0e13;border:1px solid var(--line);border-radius:8px;padding:6px 16px}
.plate{font-family:var(--disp);font-weight:700;font-size:11px;background:#F5C518;color:#111;border-radius:4px;padding:1px 7px;display:inline-block}

/* faq */
.faqwrap{max-width:760px;margin:42px auto 0}
.fitem{border:1px solid var(--line);border-radius:var(--r);margin-bottom:10px;background:var(--surface);overflow:hidden;transition:border-color .18s}
.fitem.open{border-color:var(--line2)}
.fq{width:100%;background:none;border:none;color:var(--tx);font-family:var(--disp);font-size:16.5px;font-weight:600;text-align:left;padding:20px 22px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px}
.fq .pm{width:22px;height:22px;flex:0 0 auto;position:relative;transition:transform .25s var(--ease)}
.fitem.open .pm{transform:rotate(45deg)}
.fq .pm::before,.fq .pm::after{content:"";position:absolute;background:var(--red2);border-radius:2px}
.fq .pm::before{top:10px;left:3px;right:3px;height:2px}.fq .pm::after{left:10px;top:3px;bottom:3px;width:2px}
.fa{max-height:0;overflow:hidden;transition:max-height .32s var(--ease)}
.fa p{color:var(--mut);font-size:15px;line-height:1.65;padding:0 22px 20px;max-width:660px}
.fa a{color:var(--red2)}

/* cta */
.ctabox{position:relative;border-radius:var(--r-xl);overflow:hidden;text-align:center;padding:72px 40px;background:linear-gradient(180deg,var(--surface2),var(--surface));border:1px solid var(--line2)}
.ctabox::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 50% -10%,var(--redsoft),transparent 65%)}
.ctabox>*{position:relative;z-index:1}
.ctabox h2{font-family:var(--disp);font-size:clamp(28px,3.6vw,44px);font-weight:700;letter-spacing:-.025em;line-height:1.05;text-wrap:balance}
.ctabox p{color:var(--mut);font-size:18px;margin:14px auto 0;max-width:480px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.ctabox .hero-actions{justify-content:center;margin-top:28px}

/* footer */
footer{border-top:1px solid var(--line);padding:60px 0 36px;background:var(--bg2);position:relative;z-index:2}
.ftop{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:28px}
.fblurb{color:var(--mut);font-size:14px;line-height:1.6;margin-top:16px;max-width:270px}
.fcol h5{font-family:var(--disp);font-size:13px;font-weight:600;color:var(--tx);margin-bottom:14px}
.fcol a{display:block;color:var(--mut);font-size:14px;padding:5px 0;transition:color .15s}.fcol a:hover{color:var(--tx)}
.fbot{display:flex;justify-content:space-between;margin-top:44px;padding-top:22px;border-top:1px solid var(--line);color:var(--mut2);font-size:13px;flex-wrap:wrap;gap:10px}

/* ================= LANDINGSPAGINA-COMPONENTEN ================= */
.page-hero{position:relative;padding:64px 0 8px;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(640px 300px at 16% -10%,var(--redsoft),transparent 62%)}
.page-hero .wrap{position:relative;z-index:2}
.crumb{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--mut2);font-family:var(--disp);margin-bottom:22px}
.crumb a{color:var(--mut2);transition:color .15s}.crumb a:hover{color:var(--tx)}
.crumb .sep{opacity:.5}
.page-hero h1{font-family:var(--disp);font-size:clamp(34px,5vw,60px);line-height:1.02;font-weight:700;letter-spacing:-.028em;margin-top:16px;max-width:16ch;text-wrap:balance}
.page-hero .lead{margin-top:18px;color:var(--mut);font-size:19px;line-height:1.6;max-width:600px}
.page-hero .hero-actions{margin-top:28px}

.twocol{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.twocol.narrow{grid-template-columns:1.1fr .9fr}
.prose>*+*{margin-top:18px}
.prose h2{font-family:var(--disp);font-size:clamp(24px,2.6vw,32px);font-weight:700;letter-spacing:-.02em;line-height:1.12}
.prose h3{font-family:var(--disp);font-size:19px;font-weight:600;margin-top:28px}
.prose p{color:var(--mut);font-size:16px;line-height:1.7}
.prose strong{color:var(--tx);font-weight:600}
.prose a{color:var(--red2);border-bottom:1px solid var(--redline);transition:border-color .15s}.prose a:hover{border-color:var(--red2)}

.checklist{list-style:none;display:flex;flex-direction:column;gap:14px;margin-top:8px}
.checklist li{display:flex;gap:12px;font-size:15.5px;color:var(--tx);line-height:1.5;align-items:flex-start}
.checklist li svg{flex:0 0 auto;margin-top:3px;color:var(--red2)}
.checklist li small{display:block;color:var(--mut);font-weight:400;margin-top:3px;font-size:13.5px}

.cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.cardgrid.two{grid-template-columns:repeat(2,1fr)}
.infocard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;transition:transform .2s var(--ease),border-color .2s;display:block;color:inherit}
.infocard:hover{transform:translateY(-4px);border-color:var(--line2)}
.infocard .tagline{font-family:var(--disp);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--red2);margin-bottom:12px}
.infocard h3{font-family:var(--disp);font-size:18px;font-weight:600;letter-spacing:-.01em}
.infocard p{margin-top:9px;color:var(--mut);font-size:14.5px;line-height:1.6}

.callout{border:1px solid var(--redline);border-radius:var(--r-lg);padding:24px 26px;background:var(--redsoft);display:flex;gap:16px;align-items:flex-start}
.callout .ic{flex:0 0 auto;width:40px;height:40px;border-radius:11px;background:var(--red);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--disp)}
.callout h4{font-family:var(--disp);font-size:16px;font-weight:600;margin-bottom:6px}
.callout p{color:var(--mut);font-size:14.5px;line-height:1.6}
.callout a{color:var(--red2);border-bottom:1px solid var(--redline)}

.panelcard{background:var(--surface);border:1px solid var(--line2);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.4)}
.panelcard .ph{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line);background:var(--bg2)}
.panelcard .ph .t{font-family:var(--disp);font-weight:700;font-size:16px}
.panelcard .ph .t small{display:block;font-family:var(--sans);font-weight:400;color:var(--mut2);font-size:12px;margin-top:2px}
.panelcard .pb{padding:8px 22px 16px}
.linerow{display:flex;justify-content:space-between;gap:14px;padding:12px 0;border-bottom:1px solid var(--line);font-size:14px}
.linerow:last-child{border-bottom:none}
.linerow .muted{color:var(--mut)}
.linerow.total{font-family:var(--disp);font-weight:700;font-size:17px;border-top:1px solid var(--line2);margin-top:4px;padding-top:14px}
.linerow .g{color:var(--green)}
.typetabs{display:flex;gap:8px;padding:14px 22px 0;flex-wrap:wrap}
.typetab{font-size:12.5px;font-weight:600;padding:7px 13px;border-radius:9px;border:1px solid var(--line);color:var(--mut);font-family:var(--sans)}
.typetab.on{background:var(--red);color:#fff;border-color:var(--red)}

.steprow{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px}
.scard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 26px;transition:transform .2s var(--ease),border-color .2s}
.scard:hover{transform:translateY(-4px);border-color:var(--line2)}
.scard .n{width:38px;height:38px;border-radius:11px;background:var(--bg2);border:1px solid var(--line2);display:grid;place-items:center;font-family:var(--disp);font-weight:700;color:var(--red2);font-size:16px}
.scard h3{font-family:var(--disp);font-size:18px;font-weight:600;margin:16px 0 8px}
.scard p{color:var(--mut);font-size:14.5px;line-height:1.6}

/* responsive */
@media(max-width:900px){
  .nlinks,.ncta .btn-ghost{display:none}
  .burger{display:block}
  .ftop{grid-template-columns:1fr 1fr}
  .steprow,.cardgrid,.cardgrid.two{grid-template-columns:1fr}
}
@media(max-width:860px){
  .twocol,.twocol.narrow{grid-template-columns:1fr;gap:32px}
}
@media(max-width:560px){
  .wrap{padding:0 18px}
  .ftop{grid-template-columns:1fr}
  .band{padding:56px 0}.band.tight{padding:44px 0}
  .nav-shell{top:10px;padding:0 12px}
  .nav{gap:14px;height:56px;padding:0 10px 0 16px}
  .ncta{display:none} /* CTA's blijven bereikbaar via het mobiele menu */
  .sec-sub{font-size:16px}
  .page-hero{padding:48px 0 8px}
  .page-hero .lead{font-size:17px}
  .hero-actions{width:100%}
  .hero-actions .btn-lg{flex:1 1 100%}
  .ctabox{padding:52px 22px}
  .ctabox p{font-size:16px}
  .fq{font-size:15px;padding:16px}
  .fa p{padding:0 16px 16px}
  .callout{flex-direction:column;padding:20px}
  .panelcard .ph{padding:14px 16px}
  .panelcard .pb{padding:6px 16px 14px}
  .typetabs{padding:12px 16px 0}
  .infocard,.scard{padding:22px 20px}
  .fbot{flex-direction:column;align-items:center;text-align:center}
}
