/* VanderWielen Imports : warm trade, nuchter premium */
:root{
  --bg:oklch(96.8% .012 75);            /* warm crème, brand-hue tinted */
  --bg-deep:oklch(93.5% .018 75);
  --ink:oklch(26% .02 55);
  --ink-soft:oklch(44% .02 55);
  --red:oklch(51% .145 32);             /* zegelrood */
  --red-deep:oklch(43% .14 32);
  --red-ink:oklch(32% .1 32);
  --gold:oklch(72% .11 80);
  --gold-deep:oklch(62% .1 80);
  --surface:#fff;
  --line:oklch(26% .02 55 / .13);
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --body:"Source Serif 4",Georgia,serif;
  --radius:18px;
  --shadow:0 18px 50px -22px oklch(26% .02 55 / .3);
  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-expo:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--bg);color:var(--ink);font-size:17px;line-height:1.68;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit}
h1,h2,h3{font-family:var(--display);font-weight:650;line-height:1.08;letter-spacing:-.015em;text-wrap:balance}
p{text-wrap:pretty}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
section{padding:clamp(72px,9vw,120px) 0;position:relative}
.lead{font-size:19px;color:var(--ink-soft);max-width:62ch}
[id]{scroll-margin-top:88px}
:focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:4px}

/* ---------- sectiekoppen: gevarieerde cadans, geen eyebrow-grammatica ---------- */
.sec-head{position:relative;margin-bottom:14px}
.sec-head h2{font-size:clamp(30px,3.8vw,46px);max-width:18ch}
.sec-head .sub{margin-top:12px;font-size:18px;color:var(--ink-soft);max-width:58ch}
.zh-mark{position:absolute;top:50%;right:0;transform:translateY(-58%);font-family:var(--body);font-weight:600;font-size:clamp(110px,16vw,210px);line-height:1;color:transparent;-webkit-text-stroke:1.5px oklch(51% .145 32 / .16);pointer-events:none;user-select:none}
.dark .zh-mark{-webkit-text-stroke-color:oklch(72% .11 80 / .22)}
.seal-note{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:10px;background:var(--red);color:#fff;font-family:var(--body);font-size:20px;margin-bottom:16px;box-shadow:0 8px 18px -8px oklch(51% .145 32/.6);rotate:-3deg}

/* ---------- nav ---------- */
nav{position:fixed;inset:0 0 auto 0;z-index:100;background:oklch(96.8% .012 75 / .9);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-in{max-width:1180px;margin:0 auto;padding:0 24px;height:72px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.logo{font-family:var(--display);font-size:20px;font-weight:700;text-decoration:none;display:flex;align-items:center;gap:10px;letter-spacing:-.01em}
.logo .seal{width:34px;height:34px;border-radius:8px;background:var(--red);color:#fff;display:grid;place-items:center;font-size:15px;font-weight:500;font-family:var(--body);transition:rotate .3s var(--ease-out)}
.logo:hover .seal{rotate:-6deg}
.nav-links{display:flex;gap:26px;list-style:none}
.nav-links a{text-decoration:none;font-family:var(--display);font-size:15px;font-weight:600;color:var(--ink-soft);position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--red);transition:right .25s var(--ease-out)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{right:0}
.nav-side{display:flex;align-items:center;gap:14px}
.lang{display:flex;gap:2px;border:1px solid var(--line);border-radius:999px;padding:3px;background:var(--surface)}
.lang a{font-family:var(--display);font-size:12.5px;font-weight:700;text-decoration:none;color:var(--ink-soft);padding:4px 9px;border-radius:999px;transition:background .2s,color .2s}
.lang a:hover{color:var(--ink)}
.lang a[aria-current]{background:var(--red);color:#fff}

/* ---------- knoppen ---------- */
.btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:9px;background:var(--red);color:#fff;text-decoration:none;font-family:var(--display);font-weight:700;font-size:15.5px;padding:14px 28px;border-radius:999px;border:1px solid var(--red);transition:background .25s,transform .15s var(--ease-out),box-shadow .25s;cursor:pointer}
.btn::before{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 35%,oklch(100% 0 0/.35) 50%,transparent 65%);translate:-110% 0;transition:translate .6s var(--ease-expo)}
.btn:hover{background:var(--red-deep);box-shadow:0 12px 26px -12px oklch(51% .145 32/.6)}
.btn:hover::before{translate:110% 0}
.btn:active{transform:scale(.97)}
.btn.ghost{background:transparent;color:var(--ink);border-color:oklch(26% .02 55/.3)}
.btn.ghost::before{display:none}
.btn.ghost:hover{background:var(--ink);color:var(--bg);border-color:var(--ink);box-shadow:none}

/* ---------- hero ---------- */
header{padding:clamp(140px,16vh,180px) 0 0;position:relative;overflow:clip}
.hero-watermark{position:absolute;top:30px;right:-70px;font-family:var(--body);font-size:clamp(280px,34vw,500px);line-height:1;font-weight:600;color:transparent;-webkit-text-stroke:1px oklch(51% .145 32/.1);pointer-events:none;user-select:none}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--display);font-size:13.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:18px}
.kicker::before{content:"";width:26px;height:2px;background:var(--red)}
.kicker .zh{font-family:var(--body);color:var(--gold-deep);text-transform:none;letter-spacing:0;font-weight:600}
h1{font-size:clamp(42px,5.5vw,76px);margin:0 0 24px;font-weight:700}
h1 em{font-style:normal;color:var(--red)}
.hero-cta{display:flex;gap:14px;margin:34px 0 0;flex-wrap:wrap}
.hero-note{margin-top:20px;font-size:15px;color:var(--ink-soft);display:flex;align-items:center;gap:9px}
.hero-note .dot{width:8px;height:8px;border-radius:50%;background:oklch(58% .12 150);box-shadow:0 0 0 4px oklch(58% .12 150/.16);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{50%{box-shadow:0 0 0 7px oklch(58% .12 150/.05)}}
.hero-img{position:relative}
.hero-img .main{border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:4/5;object-fit:cover;object-position:center 18%;width:100%;height:auto}
.hero-img .float{position:absolute;right:-44px;bottom:-46px;width:200px;aspect-ratio:5/4;object-fit:cover;border-radius:14px;box-shadow:var(--shadow);border:5px solid var(--bg)}
.hero-img .tag{position:absolute;top:22px;right:-14px;background:var(--ink);color:var(--bg);font-family:var(--display);font-size:13px;font-weight:600;padding:10px 16px;border-radius:10px;box-shadow:var(--shadow)}
.hero-img .tag span{color:var(--gold)}

/* hero entrance: choreografie op één moment */
.rise{animation:rise .8s var(--ease-expo) both;animation-delay:calc(var(--i,0)*90ms)}
@keyframes rise{from{opacity:0;transform:translateY(26px)}}
.hero-img{animation:frame-in 1s var(--ease-expo) .25s both}
@keyframes frame-in{from{opacity:0;transform:translateY(30px) scale(.97)}}
.hero-img .float{animation:float-in .7s var(--ease-expo) .85s both}
@keyframes float-in{from{opacity:0;transform:translateY(18px) rotate(-2deg)}}
.hero-img .tag{animation:tag-in .5s var(--ease-expo) 1.1s both}
@keyframes tag-in{from{opacity:0;transform:translateX(10px)}}

/* ---------- stats ---------- */
.stats{margin-top:clamp(56px,8vw,88px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-deep)}
.stats-in{display:grid;grid-template-columns:repeat(4,1fr);max-width:1180px;margin:0 auto;padding:0 24px}
.stat{padding:30px 18px;text-align:center;border-left:1px solid var(--line)}
.stat:first-child{border-left:none}
.stat b{display:block;font-family:var(--display);font-size:30px;font-weight:700;color:var(--red)}
.stat span{font-family:var(--display);font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft)}

/* ---------- waarom ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:48px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:transform .3s var(--ease-out),box-shadow .3s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card .ico{width:46px;height:46px;border-radius:12px;background:oklch(51% .145 32/.09);color:var(--red);display:grid;place-items:center;margin-bottom:18px}
.card h3{font-size:20px;margin-bottom:10px}
.card p{font-size:15.5px;color:var(--ink-soft)}

/* ---------- werkwijzen (donker) ---------- */
.dark{background:var(--ink);color:var(--bg)}
.dark h2{color:var(--bg)}
.dark .sub{color:oklch(96.8% .012 75/.6)}
.optie-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px;position:relative}
.of-chip{position:absolute;left:50%;top:50%;translate:-50% -50%;z-index:2;background:var(--gold);color:var(--ink);font-family:var(--display);font-weight:800;font-size:15px;letter-spacing:.06em;width:56px;height:56px;border-radius:50%;display:grid;place-items:center;box-shadow:0 12px 28px -10px oklch(0% 0 0/.6);rotate:-6deg}
.optie{position:relative;border:1px solid oklch(96.8% .012 75/.16);border-radius:var(--radius);overflow:hidden;background:oklch(96.8% .012 75/.04);display:flex;flex-direction:column}
.optie .letter{position:absolute;top:16px;left:16px;z-index:1;width:48px;height:48px;border-radius:13px;background:var(--gold);color:var(--ink);font-family:var(--display);font-weight:800;font-size:22px;display:grid;place-items:center;box-shadow:0 10px 22px -8px oklch(0% 0 0/.55)}
.optie img{aspect-ratio:16/9;object-fit:cover;object-position:center 30%;width:100%}
.optie .body{padding:30px}
.optie .ab{font-family:var(--display);font-size:14px;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;font-weight:700}
.optie h3{font-size:25px;margin:10px 0 12px;color:var(--bg)}
.optie p{color:oklch(96.8% .012 75/.72);font-size:15.5px}
.optie ul{margin:16px 0 0;padding:0;list-style:none}
.optie li{padding:9px 0 9px 30px;position:relative;font-size:15px;color:oklch(96.8% .012 75/.85);border-top:1px solid oklch(96.8% .012 75/.1)}
.optie li::before{content:"";position:absolute;left:4px;top:16px;width:14px;height:8px;border-left:2px solid var(--gold);border-bottom:2px solid var(--gold);transform:rotate(-45deg)}

/* ---------- galerij ---------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.gallery figure{border-radius:14px;overflow:hidden;position:relative;margin:0}
.gallery img{width:100%;object-fit:cover;aspect-ratio:4/3;transition:transform .6s var(--ease-out)}
.gallery .tall img{height:100%;aspect-ratio:auto}
.gallery figure:hover img{transform:scale(1.045)}
.gallery figcaption{position:absolute;inset:auto 0 0 0;padding:36px 16px 14px;font-family:var(--display);font-size:13.5px;font-weight:600;color:#fff;background:linear-gradient(transparent,oklch(20% .02 55/.8))}
.gallery .tall{grid-row:span 2}

/* ---------- praktische hulp ter plaatse ---------- */
.praktisch{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.prak-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:16px;margin-top:44px}
.prak{display:flex;gap:16px;align-items:flex-start;padding:22px;border:1px solid var(--line);border-radius:14px;background:var(--bg);transition:transform .3s var(--ease-out),box-shadow .3s,border-color .3s}
.prak:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:oklch(51% .145 32/.3)}
.prak .pico{flex:0 0 44px;width:44px;height:44px;border-radius:11px;background:oklch(51% .145 32/.09);color:var(--red);display:grid;place-items:center;transition:rotate .3s var(--ease-out)}
.prak:hover .pico{rotate:-6deg}
.prak h3{font-size:17px;margin-bottom:5px}
.prak p{font-size:14.5px;color:var(--ink-soft);line-height:1.55}
.prak p b{color:var(--ink);font-weight:600}

/* ---------- over ---------- */
.over-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center}
.over-img{position:relative}
.over-img .main{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover;aspect-ratio:3/4}
.over-img .badge{position:absolute;right:-18px;bottom:34px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 20px;box-shadow:var(--shadow);text-align:center}
.over-img .badge b{font-family:var(--display);font-size:26px;color:var(--red);display:block}
.over-img .badge span{font-family:var(--display);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.over h2{font-size:clamp(30px,3.8vw,46px);margin-bottom:20px}
.over p{color:var(--ink-soft);margin-bottom:16px}
.quote{margin:26px 0;padding:24px 28px;background:var(--bg-deep);border:1px solid var(--line);border-radius:14px;font-size:21px;font-style:italic;line-height:1.5;position:relative}
.quote::before{content:"言";position:absolute;top:-14px;left:22px;background:var(--red);color:#fff;width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-size:15px;font-style:normal;rotate:-3deg}
.talen{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.taal{font-family:var(--display);font-size:13.5px;font-weight:700;padding:8px 16px;border-radius:999px;border:1px solid var(--line);background:var(--surface)}
.taal b{color:var(--red)}

/* ---------- stappen (echte sequentie: nummers verdiend) ---------- */
.stappen{background:var(--bg-deep)}
.stap-rij{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:54px;counter-reset:stap}
.stap{position:relative;padding-top:22px}
.stap::before{counter-increment:stap;content:"0" counter(stap);font-family:var(--display);font-size:52px;font-weight:700;color:oklch(51% .145 32/.18);position:absolute;top:-16px;left:0;line-height:1}
.stap h3{font-size:18px;margin-bottom:8px;padding-top:18px;border-top:2px solid var(--red)}
.stap p{font-size:15px;color:var(--ink-soft)}

/* ---------- cases ---------- */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.case{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s var(--ease-out),box-shadow .3s}
.case:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.case img{aspect-ratio:16/10;object-fit:cover;object-position:center 30%;width:100%}
.case .body{padding:26px;display:flex;flex-direction:column;gap:12px;flex:1}
.case .land{font-family:var(--display);font-size:12.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red)}
.case h3{font-size:21px}
.case p{font-size:15.5px;color:var(--ink-soft)}
.case .result{margin-top:auto;padding-top:14px;border-top:1px solid var(--line);font-family:var(--display);font-weight:700;font-size:15px}
.case .result b{color:var(--red)}

/* ---------- testimonials ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.testi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px;display:flex;flex-direction:column;gap:16px}
.testi .sterren{color:var(--gold-deep);letter-spacing:3px;font-size:15px}
.testi blockquote{font-size:17.5px;font-style:italic;line-height:1.55}
.testi .wie{margin-top:auto;display:flex;align-items:center;gap:12px}
.testi .wie .av{width:42px;height:42px;border-radius:50%;background:var(--bg-deep);color:var(--red);font-weight:700;display:grid;place-items:center;font-family:var(--display);font-size:15px}
.testi .wie b{display:block;font-family:var(--display);font-size:14.5px}
.testi .wie span{color:var(--ink-soft);font-size:13.5px}

/* ---------- investering: rood gedrenkt ---------- */
.invest{background:linear-gradient(160deg,var(--red) 0%,var(--red-deep) 70%,var(--red-ink) 100%);color:#fff;text-align:center;overflow:clip}
.invest::before{content:"值";position:absolute;top:50%;left:50%;translate:-50% -54%;font-family:var(--body);font-size:clamp(300px,40vw,560px);font-weight:600;color:oklch(100% 0 0/.05);pointer-events:none;line-height:1}
.invest>.wrap{position:relative}
.invest h2{color:#fff;font-size:clamp(30px,3.8vw,46px);max-width:24ch;margin:0 auto}
.prijs{font-family:var(--display);font-size:clamp(54px,7vw,88px);font-weight:700;color:#fff;margin:24px 0 8px;letter-spacing:-.02em}
.prijs small{font-size:.32em;color:oklch(100% 0 0/.65);font-weight:600;letter-spacing:0}
.invest p{color:oklch(100% 0 0/.82);max-width:56ch;margin:0 auto 14px}
.invest .pakketten{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:960px;margin:44px auto 0;text-align:left}
.pakket{position:relative;border-radius:18px;padding:32px 30px;border:1px solid oklch(100% 0 0/.25);background:oklch(100% 0 0/.07);backdrop-filter:blur(4px)}
.pakket h3{color:#fff;font-size:22px}
.pakket .p-prijs{font-family:var(--display);font-size:clamp(32px,4vw,44px);font-weight:700;color:#fff;margin:10px 0 6px;letter-spacing:-.02em}
.pakket .p-prijs small{font-size:.42em;font-weight:600;color:oklch(100% 0 0/.7)}
.pakket .p-sub{font-size:15px;color:oklch(100% 0 0/.78);margin-bottom:16px}
.pakket ul{list-style:none;margin:0;padding:0}
.pakket li{padding:9px 0 9px 30px;position:relative;font-size:15px;color:oklch(100% 0 0/.92);border-top:1px solid oklch(100% 0 0/.16)}
.pakket li::before{content:"";position:absolute;left:4px;top:16px;width:14px;height:8px;border-left:2px solid var(--gold);border-bottom:2px solid var(--gold);transform:rotate(-45deg)}
.pakket.compleet{background:var(--bg);border-color:var(--bg);box-shadow:0 30px 60px -25px oklch(0% 0 0/.5)}
.pakket.compleet h3,.pakket.compleet .p-prijs{color:var(--ink)}
.pakket.compleet .p-prijs small,.pakket.compleet .p-sub{color:var(--ink-soft)}
.pakket.compleet li{color:var(--ink);border-top-color:var(--line)}
.pakket.compleet li::before{border-color:var(--red)}
.pakket .chip{position:absolute;top:-13px;right:22px;background:var(--gold);color:var(--ink);font-family:var(--display);font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:6px 14px;border-radius:999px;box-shadow:0 8px 18px -8px oklch(0% 0 0/.5)}
.invest .gratis{margin-top:28px;font-size:15.5px;color:oklch(100% 0 0/.85);max-width:62ch}
.invest .gratis b{color:#fff}
.invest .btn{margin-top:24px;background:#fff;border-color:#fff;color:var(--red-deep)}
.invest .btn:hover{background:var(--bg);box-shadow:0 14px 30px -12px oklch(0% 0 0/.4)}

/* ---------- faq ---------- */
.faq-list{max-width:820px;margin:48px auto 0}
details{border-bottom:1px solid var(--line)}
summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:24px 4px;font-family:var(--display);font-size:20px;font-weight:650}
summary::-webkit-details-marker{display:none}
summary .plus{flex:0 0 30px;height:30px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;font-size:17px;color:var(--red);transition:transform .3s var(--ease-out),background .25s;font-weight:500}
details[open] .plus{transform:rotate(45deg);background:var(--red);color:#fff;border-color:var(--red)}
details .antwoord{padding:0 44px 26px 4px;color:var(--ink-soft)}
@supports (interpolate-size: allow-keywords){
  :root{interpolate-size:allow-keywords}
  details::details-content{block-size:0;overflow-y:clip;transition:block-size .35s var(--ease-out),content-visibility .35s allow-discrete}
  details[open]::details-content{block-size:auto}
}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.contact h2{font-size:clamp(30px,3.8vw,46px);margin-bottom:18px}
.c-rij{display:flex;flex-direction:column;gap:14px;margin-top:30px}
.c-item{display:flex;align-items:center;gap:16px;padding:18px 22px;background:var(--surface);border:1px solid var(--line);border-radius:14px;text-decoration:none;font-family:var(--display);font-weight:600;transition:transform .25s var(--ease-out),box-shadow .25s}
a.c-item:hover{transform:translateX(6px);box-shadow:var(--shadow)}
.c-item .ico{width:42px;height:42px;border-radius:11px;background:oklch(51% .145 32/.09);color:var(--red);display:grid;place-items:center;flex:0 0 42px}
.c-item span{display:block;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.contact-img img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;aspect-ratio:4/5;object-fit:cover}

footer{border-top:1px solid var(--line);padding:34px 0;background:var(--bg-deep)}
.foot{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:14.5px;color:var(--ink-soft)}
.foot strong{font-family:var(--display);color:var(--ink)}
.foot .zh{color:var(--gold-deep)}

/* ---------- scroll-motion: progressive enhancement, content altijd zichtbaar ---------- */
@supports (animation-timeline: view()){
  .view-rise{animation:view-rise linear both;animation-timeline:view();animation-range:entry 0% entry 75%}
  @keyframes view-rise{from{opacity:.2;transform:translateY(34px)}to{opacity:1;transform:none}}
  .view-stagger>*{animation:view-rise linear both;animation-timeline:view();animation-range:entry calc(var(--i,0)*6%) entry calc(60% + var(--i,0)*6%)}
  .gallery figure{animation:gal-reveal linear both;animation-timeline:view();animation-range:entry 0% entry 65%}
  @keyframes gal-reveal{from{opacity:.25;clip-path:inset(8% 8% 8% 8% round 14px)}to{opacity:1;clip-path:inset(0 0 0 0 round 14px)}}
  .hero-watermark{animation:wm-drift linear both;animation-timeline:scroll();animation-range:0 120vh}
  @keyframes wm-drift{to{transform:translateY(90px)}}
  .invest::before{animation:invest-drift linear both;animation-timeline:view();animation-range:cover 0% cover 100%}
  @keyframes invest-drift{from{translate:-50% -60%}to{translate:-50% -46%}}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-delay:0ms !important;transition-duration:.01ms !important}
  html{scroll-behavior:auto}
  .hero-note .dot{animation:none}
}

/* ---------- responsive ---------- */
/* ====================================================================
   v3 : gelaagde achtergrond, rustige motion overal, procesvensters
   ==================================================================== */

/* achtergrond: warme gloed + fijne korrel over de hele site */
body{background:
  radial-gradient(900px 600px at 85% -5%, oklch(72% .11 80 / .1), transparent 60%),
  radial-gradient(1100px 700px at -10% 30%, oklch(51% .145 32 / .055), transparent 55%),
  radial-gradient(800px 600px at 110% 75%, oklch(72% .11 80 / .07), transparent 60%),
  var(--bg)}
body::after{content:"";position:fixed;inset:0;z-index:2000;pointer-events:none;opacity:.05;mix-blend-mode:multiply;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='160' height='160' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E")}

/* scroll-voortgang */
.progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:300;background:linear-gradient(90deg,var(--red),var(--gold-deep));transform-origin:0 50%;transform:scaleX(0)}
@supports (animation-timeline: scroll()){
  .progress{animation:progress linear both;animation-timeline:scroll()}
  @keyframes progress{from{transform:scaleX(0)}to{transform:scaleX(1)}}
}

/* hero aurora: trage warme gloed, alleen sfeer */
.aurora{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.aurora i{position:absolute;border-radius:50%;filter:blur(70px)}
.aurora i:first-child{width:520px;height:520px;top:-180px;right:6%;background:oklch(72% .11 80/.2);animation:aur-a 26s ease-in-out infinite alternate}
.aurora i:last-child{width:420px;height:420px;bottom:-140px;left:-120px;background:oklch(51% .145 32/.12);animation:aur-b 32s ease-in-out infinite alternate}
@keyframes aur-a{to{transform:translate(-70px,50px) scale(1.12)}}
@keyframes aur-b{to{transform:translate(60px,-40px) scale(1.08)}}

/* productstrip: trage marquee */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface);overflow:hidden;padding:16px 0;position:relative}
.strip::before,.strip::after{content:"";position:absolute;top:0;bottom:0;width:90px;z-index:1;pointer-events:none}
.strip::before{left:0;background:linear-gradient(90deg,var(--surface),transparent)}
.strip::after{right:0;background:linear-gradient(-90deg,var(--surface),transparent)}
.strip-track{display:flex;gap:0;width:max-content;animation:strip 46s linear infinite}
.strip:hover .strip-track{animation-play-state:paused}
.strip-track span{font-family:var(--display);font-size:14px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);padding:0 26px;white-space:nowrap;border-right:1px solid var(--line)}
.strip-track span i{font-style:normal;font-family:var(--body);color:var(--gold-deep);text-transform:none;letter-spacing:0}
@keyframes strip{to{transform:translateX(-50%)}}

/* skylineband met parallax */
.band{position:relative;height:clamp(280px,40vw,420px);overflow:hidden;display:flex;align-items:flex-start;justify-content:center;padding:clamp(34px,6vw,62px) 24px 0}
.band img{position:absolute;inset:0;width:100%;height:130%;object-fit:cover;object-position:center 12%;top:-15%}
.band::after{content:"";position:absolute;inset:0;background:linear-gradient(oklch(26% .02 55/.55),oklch(26% .02 55/.25) 45%,oklch(26% .02 55/.6))}
.band .inner{position:relative;z-index:1;text-align:center;color:#fff;padding:0 24px}
.band .zh-line{font-family:var(--body);font-size:clamp(22px,3vw,32px);color:oklch(96.8% .012 75/.92);letter-spacing:.5em;margin-bottom:10px}
.band p{font-family:var(--display);font-size:clamp(17px,2vw,21px);font-weight:600;color:oklch(96.8% .012 75/.85)}
@supports (animation-timeline: view()){
  .band img{animation:band-par linear both;animation-timeline:view();animation-range:cover 0% cover 100%}
  @keyframes band-par{from{transform:translateY(-7%)}to{transform:translateY(7%)}}
}

/* klikbare kaarten + affordance */
.testi,.case{cursor:pointer}
.testi:hover{transform:translateY(-5px);box-shadow:var(--shadow);transition:transform .3s var(--ease-out),box-shadow .3s}
.meer{display:inline-flex;align-items:center;gap:7px;margin-top:4px;font-family:var(--display);font-size:13.5px;font-weight:700;color:var(--red);background:none;border:none;padding:0;cursor:pointer}
.meer svg{transition:translate .25s var(--ease-out)}
.testi:hover .meer svg,.case:hover .meer svg{translate:4px 0}
.card .ico,.c-item .ico{transition:rotate .3s var(--ease-out),scale .3s var(--ease-out)}
.card:hover .ico{rotate:-5deg;scale:1.06}
a.c-item:hover .ico{rotate:-5deg}
.gallery figcaption{translate:0 6px;opacity:.92;transition:translate .35s var(--ease-out),opacity .35s}
.gallery figure:hover figcaption{translate:0 0;opacity:1}

/* procesvensters */
dialog.proces{margin:auto;width:min(620px,calc(100vw - 32px));max-height:min(82dvh,760px);border:1px solid var(--line);border-radius:20px;padding:0;background:var(--bg);color:var(--ink);box-shadow:0 40px 90px -30px oklch(0% 0 0/.45);overflow:hidden auto}
dialog.proces::backdrop{background:oklch(20% .02 55/.55);backdrop-filter:blur(6px)}
dialog.proces[open]{animation:dlg-in .4s var(--ease-expo)}
@keyframes dlg-in{from{opacity:0;transform:translateY(22px) scale(.97)}}
@starting-style{dialog.proces[open]{opacity:0}}
.d-head{position:relative}
.d-head img{width:100%;aspect-ratio:16/9;object-fit:cover;object-position:center 28%}
.d-head .d-titel{position:absolute;inset:auto 0 0 0;padding:46px 28px 18px;background:linear-gradient(transparent,oklch(20% .02 55/.82))}
.d-head .d-eyebrow{font-family:var(--display);font-size:12.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.d-head h3{color:#fff;font-size:26px;margin-top:4px}
.d-close{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;border:none;background:oklch(20% .02 55/.55);color:#fff;font-size:19px;cursor:pointer;display:grid;place-items:center;backdrop-filter:blur(4px);transition:background .2s,rotate .3s var(--ease-out)}
.d-close:hover{background:var(--red);rotate:90deg}
.d-body{padding:26px 28px 30px}
.d-intro{color:var(--ink-soft);margin-bottom:22px}
.d-steps{list-style:none;counter-reset:dstap;display:flex;flex-direction:column}
.d-steps li{counter-increment:dstap;position:relative;padding:0 0 22px 46px}
.d-steps li::before{content:counter(dstap);position:absolute;left:0;top:0;width:30px;height:30px;border-radius:50%;background:var(--red);color:#fff;font-family:var(--display);font-size:14px;font-weight:700;display:grid;place-items:center}
.d-steps li::after{content:"";position:absolute;left:14.5px;top:34px;bottom:4px;width:1.5px;background:var(--line)}
.d-steps li:last-child::after{display:none}
.d-steps b{display:block;font-family:var(--display);font-size:16.5px;margin-bottom:3px}
.d-steps span{font-size:15px;color:var(--ink-soft)}
.d-foot{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
.d-foot>div{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px 18px}
.d-foot span{display:block;font-family:var(--display);font-size:11.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:4px}
.d-foot b{font-family:var(--display);font-size:15px;color:var(--red)}
dialog.proces[open] .d-steps li{animation:rise .55s var(--ease-expo) both;animation-delay:calc(.15s + var(--i,0)*70ms)}

/* nav: subtiel sterker bij scroll */
nav{transition:box-shadow .3s}
nav.scrolled{box-shadow:0 10px 30px -18px oklch(26% .02 55/.35)}

@media (max-width:820px){
  .d-foot{grid-template-columns:1fr}
  .band img{height:140%}
  .aurora i{filter:blur(50px)}
  .invest .pakketten{grid-template-columns:1fr}
  .of-chip{display:none}
}

@media (prefers-reduced-motion: reduce){
  .strip-track{animation:none}
  .aurora i{animation:none}
}

@media (max-width:1020px){
  .case-grid,.testi-grid{grid-template-columns:1fr 1fr}
  .stap-rij{grid-template-columns:repeat(3,1fr);row-gap:40px}
  .gallery{grid-template-columns:1fr 1fr}
  .zh-mark{display:none}
}
@media (max-width:820px){
  .nav-links{display:none}
  .hero-grid,.over-grid,.contact-grid,.optie-grid{grid-template-columns:1fr;gap:44px}
  header{padding-top:120px}
  .hero-watermark{font-size:240px;right:-50px;top:10px}
  .hero-img .float{right:14px;left:auto;width:150px;bottom:-32px}
  .hero-img{margin-bottom:26px}
  .stats-in{grid-template-columns:1fr 1fr}
  .stat{border-left:none;border-top:1px solid var(--line)}
  .case-grid,.testi-grid,.gallery{grid-template-columns:1fr}
  .stap-rij{grid-template-columns:1fr 1fr}
  .over-img .badge{right:10px}
}
@media (max-width:480px){
  .nav-in{padding:0 12px;gap:8px}
  .nav-side{gap:8px}
  .logo{font-size:16px}
  .logo .word{display:none}
  nav .btn{padding:10px 13px;font-size:13px}
  nav .btn .hide-s{display:none}
  .lang a{padding:4px 7px;font-size:12px}
}

/* ====================================================================
   v6 : stijlvoller, meer cadans, meer motion (rustig en doelgericht)
   ==================================================================== */

/* merkkleur in tekstselectie en scrollbar */
::selection{background:oklch(72% .11 80/.45);color:var(--ink)}
@media (pointer:fine){
  ::-webkit-scrollbar{width:12px}
  ::-webkit-scrollbar-track{background:var(--bg)}
  ::-webkit-scrollbar-thumb{background:oklch(51% .145 32/.32);border-radius:8px;border:3px solid var(--bg)}
  ::-webkit-scrollbar-thumb:hover{background:oklch(51% .145 32/.5)}
}

/* hero: woorden landen een voor een, licht onscherp naar scherp */
h1 .w{display:inline-block;animation:word-in .75s var(--ease-expo) both;animation-delay:calc(.1s + var(--w,0)*95ms)}
@keyframes word-in{from{opacity:0;transform:translateY(24px) rotate(1.2deg);filter:blur(7px)}}
h1 em{isolation:isolate;display:inline-block}
h1 em::after{content:"";position:absolute;left:-.04em;right:-.04em;bottom:.05em;height:.16em;border-radius:3px;background:linear-gradient(90deg,oklch(72% .11 80/.65),oklch(62% .1 80/.55));z-index:-1;transform-origin:0 50%;animation:mark-in .8s var(--ease-expo) .95s both}
h1 em{position:relative}
@keyframes mark-in{from{scale:0 1}}

/* hero: rood 寻源-zegel (sourcing) kroont de kicker en vult de lege ruimte */
.hero-chop{writing-mode:vertical-rl;display:grid;width:fit-content;place-items:center;gap:.12em;font-family:var(--body);font-weight:600;font-size:22px;letter-spacing:.16em;line-height:1;color:#fff;background:linear-gradient(155deg,var(--red),var(--red-deep));padding:14px 10px 13px;border-radius:10px;box-shadow:0 14px 30px -14px oklch(51% .145 32/.55),inset 0 0 0 1.5px oklch(100% 0 0/.3);rotate:-3deg;margin:0 0 28px 2px;animation:chop-in .8s var(--ease-expo) .25s both}
@keyframes chop-in{from{opacity:0;transform:translateY(16px) rotate(-9deg);scale:.82}}

/* hero: gouden sierlijst achter de foto */
.hero-img::before{content:"";position:absolute;inset:-16px auto auto -16px;width:62%;height:62%;border:1.5px solid oklch(62% .1 80/.55);border-radius:calc(var(--radius) + 4px);z-index:-1;animation:rise 1s var(--ease-expo) .55s both}
.hero-img .float{animation:float-in .7s var(--ease-expo) .85s both,float-bob 7s ease-in-out 3s infinite}
@keyframes float-bob{0%,100%{translate:0 0}50%{translate:0 -6px}}

/* knoppen: subtiele lift */
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.97)}

/* sectiekoppen: getekende goudrode regel tussen kop en subregel */
.sec-head h2::after{content:"";display:block;width:64px;height:3px;border-radius:2px;margin-top:18px;background:linear-gradient(90deg,var(--red),var(--gold-deep))}
#faq .sec-head h2::after{margin-inline:auto}
.dark .sec-head h2::after{background:linear-gradient(90deg,var(--gold),var(--gold-deep))}

/* kaarten: goudrode hairline die bij hover binnenglijdt */
.card,.prak{position:relative;overflow:hidden}
.card::before,.prak::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--red),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease-expo)}
.card:hover::before,.prak:hover::before{transform:scaleX(1)}

/* OF-medaillon wiegt heel licht */
.of-chip{animation:chip-sway 5.5s ease-in-out infinite alternate}
@keyframes chip-sway{from{rotate:-7deg}to{rotate:3deg}}

/* citaat: zegel kantelt bij hover */
.quote::before{transition:rotate .35s var(--ease-out)}
.quote:hover::before{rotate:7deg}

/* navigatie: actieve sectie blijft aangelicht */
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{right:0}

/* scroll-motion v6: alleen waar het betekenis heeft */
@supports (animation-timeline: view()){
  .stat{animation:stat-in linear both;animation-timeline:view();animation-range:entry 0% entry 55%}
  .stat:nth-child(2){animation-range:entry 8% entry 63%}
  .stat:nth-child(3){animation-range:entry 16% entry 71%}
  .stat:nth-child(4){animation-range:entry 24% entry 79%}
  @keyframes stat-in{from{opacity:0;transform:translateY(20px)}}
  .optie .letter{animation:pop-in linear both;animation-timeline:view();animation-range:entry 25% entry 65%}
  @keyframes pop-in{from{opacity:0;scale:.3;rotate:-14deg}}
  .sec-head h2::after{animation:rule-in linear both;animation-timeline:view();animation-range:entry 0% entry 80%;transform-origin:left}
  #faq .sec-head h2::after{transform-origin:center}
  @keyframes rule-in{from{transform:scaleX(0)}}
}

@media (prefers-reduced-motion: reduce){
  .of-chip,.hero-img .float{animation:none}
  h1 .w{animation:none}
  h1 em::after{animation:none;scale:1 1}
}
