/* === Reset: layout fix voor Windows/Chrome === */
html, body {
  overflow-x: hidden;
  box-sizing: border-box;
}

/* rest van je bestaande CSS hieronder */

:root{
  --purple:#951B81; --pink:#D60B52; --ink:#0a0a0f;
  --grad:linear-gradient(90deg,#951B81,#D60B52);
  --grad-135:linear-gradient(135deg,#951B81,#D60B52);
  --text:#1a1a22; --muted:#6b6b78; --line:#ececf1; --bg:#ffffff; --soft:#faf7fb;
  --display:'Poppins',system-ui,sans-serif; --body:'Manrope',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--display);line-height:1.1;letter-spacing:-.01em}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
.wrap-wide{max-width:1320px;margin:0 auto;padding:0 24px}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:700;font-size:15px;padding:14px 26px;border-radius:12px;cursor:pointer;border:none;transition:transform .2s,box-shadow .2s,background .2s}
.btn-primary{background:var(--grad-135);color:#fff;box-shadow:0 8px 24px rgba(149,27,129,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(149,27,129,.45)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.85)}
.btn-ghost:hover{border-color:#fff;color:#fff}
.btn-outline{background:#fff;border:1px solid var(--line);color:var(--purple)}
.btn-outline:hover{border-color:var(--pink);transform:translateY(-2px)}
.eyebrow{font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--pink)}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* Utility bar */
.ubar{background:var(--purple);color:#fff;font-size:13.5px}
.ubar .wrap-wide{display:flex;flex-wrap:wrap;align-items:center;gap:8px 26px;padding-top:9px;padding-bottom:9px}
.ubar a{display:inline-flex;align-items:center;gap:7px;opacity:.92}
.ubar a:hover{opacity:1}
.ubar .sep{margin-left:auto;opacity:.8;font-weight:500}
.ico{width:16px;height:16px;flex:none}

/* Header */
.hdr{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line);transition:box-shadow .3s,background .3s}
.hdr.scrolled{box-shadow:0 6px 24px rgba(20,10,30,.07);background:rgba(255,255,255,.96);backdrop-filter:blur(10px)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;min-height:120px;gap:18px}
.hdr-logo img{height:74px;width:auto}
.nav{display:flex;align-items:center;gap:4px}
.nav a,.nav .has-sub>span{font-family:var(--display);font-weight:600;font-size:15.5px;color:var(--text);padding:10px 16px;position:relative;display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.nav a::after,.nav .has-sub>span::after{content:"";position:absolute;left:16px;right:16px;bottom:4px;height:2px;background:var(--pink);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.nav a:hover::after,.nav .has-sub:hover>span::after{transform:scaleX(1)}
.has-sub{position:relative}
.submenu{position:absolute;top:100%;left:8px;min-width:230px;background:#fff;border:1px solid var(--line);box-shadow:0 14px 34px rgba(20,10,30,.12);border-radius:12px;padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.22s}
.has-sub:hover .submenu{opacity:1;visibility:visible;transform:none}
.submenu a{display:block;font-size:14.5px;font-weight:600;padding:9px 14px;border-radius:8px;color:var(--text)}
.submenu a::after{display:none}
.submenu a:hover{background:var(--soft);color:var(--pink)}
.hdr-right{display:flex;align-items:center;gap:18px}
.socials{display:flex;gap:8px}
.socials a{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--purple);transition:background .2s,color .2s}
.socials a:hover{background:var(--soft);color:var(--pink)}
.burger{display:none;background:none;border:none;cursor:pointer;color:var(--text);padding:8px}
.mobile-panel{display:none;border-top:1px solid var(--line);background:#fff;padding:14px 24px 26px}
.mobile-panel.open{display:block}
.mobile-panel a,.mobile-panel .m-sub>button{display:flex;width:100%;align-items:center;justify-content:space-between;font-family:var(--display);font-weight:600;font-size:17px;padding:13px 6px;color:var(--text);background:none;border:none;cursor:pointer;text-align:left}
.m-sub-list{display:none;padding-left:14px;border-left:2px solid var(--line);margin-left:6px}
.m-sub-list.open{display:block}
.m-sub-list a{font-size:15px;color:var(--muted);padding:9px 6px}
.mobile-cta{margin-top:14px}
.mobile-cta .btn{width:100%;justify-content:center}

/* Hero */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.hero .blob{position:absolute;border-radius:50%;filter:blur(120px);pointer-events:none}
.hero .b1{width:600px;height:600px;background:var(--purple);opacity:.22;top:-220px;left:-160px}
.hero .b2{width:420px;height:420px;background:var(--pink);opacity:.18;top:60px;right:-120px}
.hero .bows{position:absolute;top:-40px;right:4%;width:430px;max-width:46vw;opacity:.5;pointer-events:none}
.hero-top{position:relative;z-index:2;padding:78px 0 52px}
.badge{display:inline-flex;align-items:center;gap:8px;padding:7px 15px;border-radius:999px;font-size:14px;font-weight:500;background:rgba(149,27,129,.22);border:1px solid rgba(149,27,129,.45);margin-bottom:30px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:end}
.hero h1{font-size:clamp(40px,5.4vw,64px);font-weight:800;margin-bottom:22px}
.hero .lede{font-size:18px;color:rgba(255,255,255,.6);max-width:30em}
.hero-actions{display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.hero-actions .row{display:flex;gap:12px;flex-wrap:wrap}
.trust{display:flex;flex-wrap:wrap;gap:8px 22px;font-size:14.5px}
.trust span{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.55)}
.trust .ico{color:var(--pink)}
.hr-faint{border-top:1px solid rgba(255,255,255,.08);position:relative;z-index:2}

/* Diensten grid */
.diensten{position:relative;z-index:2;padding:46px 0 80px}
.diensten h2{font-size:clamp(24px,3vw,32px);font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.16em}
.diensten .underline{height:2px;margin-top:14px;background:linear-gradient(90deg,rgba(149,27,129,.7),rgba(214,11,82,.3) 42%,transparent)}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.dcard{position:relative;display:block;height:380px;border-radius:16px;overflow:hidden;background:#15151c}
.dcard img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.dcard:hover img{transform:scale(1.06)}
.dcard .svgfill{position:absolute;inset:0;background:var(--grad-135);display:flex;align-items:center;justify-content:center}
.dcard .svgfill svg{width:140px;height:140px;opacity:.92}
.dcard .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(149,27,129,.9) 0%,rgba(10,10,15,.15) 100%)}
.dcard.promo .ov{background:linear-gradient(to top,rgba(214,11,82,.9) 0%,rgba(10,10,15,.18) 100%)}
.dcard .badge-ic{position:absolute;top:16px;left:16px;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(149,27,129,.45);border:1px solid rgba(255,255,255,.25)}
.dcard.promo .badge-ic{background:rgba(214,11,82,.5)}
.dcard .tag{position:absolute;top:16px;right:16px;font-family:var(--display);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:5px 10px;border-radius:6px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.4);color:#fff}
.dcard .meta{position:absolute;left:0;bottom:0;width:100%;padding:22px;z-index:2}
.dcard .meta p{color:rgba(255,255,255,.72);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px}
.dcard .meta h3{color:#fff;font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.dcard .arr{position:absolute;right:20px;bottom:22px;color:#fff;font-size:20px;opacity:0;transform:translateX(-6px);transition:.3s;z-index:3}
.dcard:hover .arr{opacity:1;transform:none}
.networks{margin-top:38px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-wrap:wrap;align-items:center;gap:14px}
.networks .lbl{font-family:var(--display);font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.3)}
.networks .chip{font-family:var(--display);font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.32);border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:5px 12px}

/* Section base */
.sec{padding:88px 0}
.sec-soft{background:var(--soft)}
.sec h2.title{font-size:clamp(26px,3.4vw,38px);font-weight:700;color:var(--purple)}
.center{text-align:center}

/* Intro band */
.intro{display:flex;align-items:center;gap:42px;flex-wrap:wrap}
.intro .iconwrap{position:relative;width:112px;height:112px;flex:none}
.intro .ring{position:absolute;inset:0;border:2px solid rgba(214,11,82,.35);border-radius:14px;animation:ping 3s cubic-bezier(0,0,.2,1) infinite}
.intro .ring2{inset:12px;border-color:rgba(214,11,82,.5);animation-duration:2s;animation-delay:.5s}
.intro .core{position:absolute;inset:24px;border-radius:12px;background:rgba(214,11,82,.1);display:flex;align-items:center;justify-content:center;color:var(--pink)}
@keyframes ping{75%,100%{transform:scale(1.6);opacity:0}}
.intro .txt{flex:1;min-width:280px}
.intro h2{font-size:clamp(24px,3vw,34px);font-weight:700;color:var(--purple);margin-bottom:12px}
.intro p{font-size:17px;color:var(--text);max-width:46em}

/* VoorWie */
.vw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.vwcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:32px;transition:transform .3s,box-shadow .3s,border-color .3s}
.vwcard:hover{transform:translateY(-4px);box-shadow:0 16px 38px rgba(20,10,30,.08);border-color:rgba(214,11,82,.4)}
.vwcard .ic{width:48px;height:48px;border-radius:12px;background:var(--grad-135);display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:18px}
.vwcard h3{font-size:20px;color:var(--purple);margin-bottom:10px}
.vwcard p{color:var(--muted);font-size:15.5px}

/* Waarom */
.waarom{background:var(--soft)}
.wm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:46px}
.wmcard{display:flex;gap:18px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px}
.wmcard .n{font-family:var(--display);font-weight:800;font-size:22px;color:var(--pink);flex:none;width:30px}
.wmcard h3{font-size:18px;color:var(--purple);margin-bottom:6px}
.wmcard p{color:var(--muted);font-size:15px}

/* OVER DENNIS */
.od{background:var(--soft)}
.od-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:center}
.od-photo{position:relative;justify-self:center;width:100%;max-width:360px}
.od-photo::before{content:"";position:absolute;inset:-14px;border-radius:50%;background:var(--grad-135);opacity:.12;z-index:0}
.od-photo img{position:relative;z-index:1;width:100%;height:auto;border-radius:50%;display:block;object-fit:cover;object-position:center top}
.od-copy h2{font-size:clamp(26px,3.2vw,36px);color:var(--purple);margin:12px 0 18px}
.od-copy p{color:var(--muted);font-size:15.5px;margin-bottom:16px;max-width:38em}
.od-copy .od-cta{margin-top:8px}

/* Partnernetwerk */
.pn{position:relative;overflow:hidden;background:#fff}
.pn-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.pn-copy h2{font-size:clamp(26px,3.2vw,36px);color:var(--purple);margin-bottom:16px}
.pn-copy p{color:var(--muted);font-size:16.5px;max-width:34em}
.rings{position:relative;width:100%;max-width:480px;aspect-ratio:1;height:0;padding-bottom:88%;margin-left:auto}
.rings .stage{position:absolute;inset:0}
.ring-arc{position:absolute;right:0;bottom:0;border-top:16px solid;border-left:16px solid;border-top-left-radius:999px;border-color:rgba(214,11,82,.18)}
.dot{position:absolute;transform:translate(-50%,-50%);z-index:3}
.dot .pulse{position:absolute;inset:0;border-radius:50%;background:rgba(214,11,82,.4);animation:dotping 2.4s ease-out infinite}
.dot .core{position:relative;width:22px;height:22px;border-radius:50%;background:#fff;border:4px solid var(--pink);box-shadow:0 0 16px rgba(214,11,82,.5);transition:transform .3s}
.dot:hover .core{transform:scale(1.25);background:var(--pink)}
.dot .tip{position:absolute;bottom:140%;left:50%;transform:translateX(-50%) translateY(6px);width:230px;background:#fff;border:1px solid var(--line);box-shadow:0 16px 40px rgba(20,10,30,.16);border-radius:12px;padding:14px 16px;opacity:0;visibility:hidden;transition:.25s;z-index:5}
.dot:hover .tip{opacity:1;visibility:visible;transform:translateX(-50%)}
.dot .tip h4{font-size:15px;color:var(--purple);margin-bottom:4px}
.dot .tip p{font-size:13px;color:var(--muted);line-height:1.4}
@keyframes dotping{0%{transform:scale(1);opacity:.7}80%,100%{transform:scale(2.4);opacity:0}}

/* Reviews */
.reviews{background:var(--soft);overflow:hidden}
.rv-track{display:flex;transition:transform .5s ease}
.rv-vp{overflow:hidden;max-width:880px;margin:46px auto 0}
.rvcard{flex:0 0 100%;padding:8px}
.rvinner{background:#fff;border:1px solid var(--line);border-radius:16px;padding:44px;box-shadow:0 10px 30px rgba(149,27,129,.05);position:relative}
.rvinner .q{position:absolute;top:24px;right:28px;font-family:var(--display);font-size:90px;line-height:1;color:rgba(214,11,82,.08);font-weight:800}
.rvinner p.quote{font-size:21px;font-style:italic;color:var(--text);line-height:1.5;position:relative;z-index:1}
.rvinner .auth{margin-top:24px}
.rvinner .auth h4{font-size:17px;color:var(--purple)}
.rvinner .auth span{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.rv-dots{display:flex;justify-content:center;gap:10px;margin-top:34px}
.rv-dots button{height:6px;width:8px;border:none;border-radius:999px;background:rgba(214,11,82,.22);cursor:pointer;transition:.4s}
.rv-dots button.active{width:30px;background:var(--pink)}

/* Partner van */
.partnervan{background:#3B0256;color:#fff;text-align:center}
.partnervan h2{color:#fff;font-size:clamp(24px,3vw,34px);letter-spacing:.04em;margin-bottom:40px}
.pv-logos{display:flex;justify-content:center;flex-wrap:wrap;gap:20px}
.pv-logos .card{width:190px;height:120px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:14px;backdrop-filter:blur(4px);transition:transform .3s}
.pv-logos .card:hover{transform:translateY(-4px)}
.pv-logos img{max-height:54px;max-width:130px;object-fit:contain;filter:brightness(0) invert(1);opacity:.9}
.partnervan .cta{margin-top:44px}
.partnervan .cta .btn{background:var(--pink);color:#fff;box-shadow:0 10px 26px rgba(214,11,82,.4)}
.partnervan .cta .btn:hover{transform:translateY(-2px)}

/* CTA band */
.ctaband{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.ctaband .blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:.2}
.ctaband .c1{width:420px;height:420px;background:var(--purple);top:-160px;left:-120px}
.ctaband .c2{width:420px;height:420px;background:var(--pink);bottom:-180px;right:-120px}
.ctaband .inner{position:relative;z-index:2;text-align:center;padding:84px 24px;max-width:760px;margin:0 auto}
.ctaband h2{font-size:clamp(28px,4vw,52px);font-weight:800;text-transform:uppercase;line-height:1.08;margin-bottom:28px}
.ctaband .sub{margin-top:18px;color:rgba(255,255,255,.6);font-size:14px;text-transform:uppercase;letter-spacing:.14em}

/* ===== FOOTER STYLES ===== */
.foot{background:#fff;color:var(--text);padding:64px 0 30px;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:36px}
.foot img{height:58px;width:auto;margin-bottom:18px}
.foot .mission{color:var(--muted);font-size:15.5px;max-width:24em}
.foot h3{font-family:var(--display);font-size:17px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px;color:var(--purple)}
.foot ul{list-style:none}
.foot li{margin-bottom:12px}
.foot li a,.foot .ci{display:flex;align-items:center;gap:10px;color:var(--text);font-size:15px}
.foot li a:hover{color:var(--pink)}
.foot li a .b{width:6px;height:6px;border-radius:50%;background:var(--pink);opacity:.5;transition:.3s}
.foot li a:hover .b{width:16px;opacity:1}
.foot .ci .ico{width:18px;height:18px;margin-top:2px;color:var(--purple);flex:none}
.foot hr{border:none;border-top:1px solid var(--line);margin:42px 0 22px}
.foot .copy{font-size:13.5px;color:var(--muted);text-align:center}

@media(max-width:960px){
  .hero-grid,.pn-grid,.foot-grid{grid-template-columns:1fr}
  .grid3{grid-template-columns:1fr 1fr}
  .vw-grid{grid-template-columns:1fr}
  .wm-grid{grid-template-columns:1fr}
  .od-grid{grid-template-columns:1fr;gap:32px}
  .od-photo{max-width:280px;margin:0 auto}
  .nav,.hdr-right .socials,.hdr-right .btn{display:none}
  .burger{display:inline-flex}
  .rings{margin:0 auto;max-width:380px}
  .foot-grid{grid-template-columns:1fr;gap:30px}
}
@media(max-width:600px){
  .grid3{grid-template-columns:1fr}
  .hdr-in{min-height:88px}
  .hdr-logo img{height:54px}
  .dcard{height:300px}
  .hero-top{padding:60px 20px 40px}
}
