/* ==========================================================================
   GEEN KLANT KWIJT — design system v2 "Vertrouwen-blauw + groen accent"
   Premium SaaS: self-hosted Plus Jakarta Sans, zachte gelaagde schaduwen,
   subtiele gradients, diepte in kaarten, verfijnde scroll-motion.
   Eén accent-blauw (CTA/primair) + één groen (positief/opgenomen). Eén radius.
   ========================================================================== */

/* ---- self-hosted font (geen externe requests → snel + verify-poort blijft groen) ---- */
@font-face{font-family:'Jakarta';src:url('../fonts/pjs-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Jakarta';src:url('../fonts/pjs-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Jakarta';src:url('../fonts/pjs-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Jakarta';src:url('../fonts/pjs-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Jakarta';src:url('../fonts/pjs-800.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap}

:root{
  --blue:#1d5fd8;          /* primair / CTA (vertrouwen) */
  --blue-700:#1748a8;
  --blue-400:#5b8af0;
  --blue-50:#eef4ff;
  --blue-100:#dde9ff;
  --navy:#0b1a30;          /* donkere secties / ink */
  --navy-2:#11233b;
  --ink:#0c1828;           /* koppen */
  --slate:#475569;         /* body */
  --muted:#7b8aa0;
  --line:#e7ecf5;
  --green:#10b981;         /* accent: opgenomen/check/positief */
  --green-700:#059669;
  --green-50:#e7f8f1;
  --danger:#ef4444;
  --bg:#ffffff;
  --bg-soft:#f5f8fd;       /* lichte sectie */
  --white:#ffffff;
  --radius:18px;
  --radius-sm:12px;
  --radius-lg:26px;
  /* gelaagde, brand-getinte schaduwen → premium diepte */
  --shadow-sm:0 1px 2px rgba(12,26,46,.05), 0 4px 14px -6px rgba(12,26,46,.12);
  --shadow:0 8px 24px -10px rgba(13,38,76,.18), 0 28px 60px -34px rgba(13,38,76,.32);
  --shadow-lg:0 18px 40px -16px rgba(13,38,76,.26), 0 50px 90px -40px rgba(13,38,76,.42);
  --shadow-blue:0 14px 30px -12px rgba(29,95,216,.55);
  --ring:0 0 0 1px var(--line);
  --grad-blue:linear-gradient(135deg,#2a6ff0 0%,#1748a8 100%);
  --grad-hero:radial-gradient(1200px 520px at 78% -8%, #dbe8ff 0%, rgba(238,244,255,0) 60%), linear-gradient(180deg,#f3f7ff 0%,#ffffff 72%);
  --container:1160px;
  --ff:'Jakarta','Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  --ff-head:var(--ff);
  --ff-body:var(--ff);
  --ease:cubic-bezier(.22,.61,.36,1);
  /* back-compat aliases voor starter-componenten */
  --brass:var(--green); --brass-600:var(--green-700); --cream:var(--bg); --cream-2:var(--bg-soft);
  --navy-700:var(--blue); --navy-800:var(--blue-700);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--ff-body);color:var(--slate);background:var(--bg);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-family:var(--ff-head);color:var(--ink);line-height:1.08;margin:0 0 .5em;
  font-weight:800;letter-spacing:-.025em}
h1{font-size:clamp(2.2rem,5.4vw,3.75rem)}
h2{font-size:clamp(1.75rem,3.6vw,2.7rem)}
h3{font-size:1.22rem;font-weight:700;letter-spacing:-.015em}
p{margin:0 0 1rem}
a{color:var(--blue);text-decoration:none;transition:color .15s}
a:hover{color:var(--blue-700)}
img,svg{max-width:100%;display:block}
strong,b{color:var(--ink)}
::selection{background:var(--blue-100);color:var(--ink)}
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:4px}
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:clamp(58px,8vw,108px) 0}
.section--soft{background:var(--bg-soft)}
.section--dark{background:var(--navy);color:#c6d4e6;position:relative;overflow:hidden}
.section--dark::before{content:"";position:absolute;inset:0;
  background:radial-gradient(800px 360px at 15% 0%, rgba(29,95,216,.22), transparent 60%),
             radial-gradient(700px 340px at 100% 100%, rgba(16,185,129,.12), transparent 55%);pointer-events:none}
.section--dark>.container{position:relative}
.section--dark h2,.section--dark h3{color:#fff}
.section--blue{background:var(--grad-blue);color:#e8f0ff}
.section--blue h2{color:#fff}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;
  font-size:.74rem;color:var(--blue);margin-bottom:.85rem;padding:.42rem .8rem;border-radius:999px;
  background:var(--blue-50);box-shadow:inset 0 0 0 1px var(--blue-100)}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--blue)}
.section--dark .eyebrow,.section--blue .eyebrow{color:#bfe9d8;background:rgba(16,185,129,.12);box-shadow:inset 0 0 0 1px rgba(16,185,129,.25)}
.section--dark .eyebrow::before,.section--blue .eyebrow::before{background:var(--green)}
.lead{font-size:1.2rem;color:var(--slate);line-height:1.6}
.section--dark .lead{color:#aabfd8}
.center{text-align:center}
.measure{max-width:720px}.measure-center{max-width:730px;margin:0 auto}
.sec-head{max-width:700px;margin:0 auto 2.8rem;text-align:center}
.sec-head .eyebrow{margin-inline:auto}
.sec-head p{color:var(--muted)}

/* ---- buttons (één primair label overal) ---- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.55em;font-family:var(--ff-body);
  font-weight:700;font-size:1rem;padding:.92em 1.55em;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .18s var(--ease),box-shadow .18s var(--ease),background .18s,border-color .18s;
  white-space:nowrap;line-height:1}
.btn svg{width:18px;height:18px}
.btn--primary{background:var(--grad-blue);color:#fff;box-shadow:var(--shadow-blue)}
.btn--primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 18px 36px -12px rgba(29,95,216,.65)}
.btn--gold,.btn--accent{background:var(--green);color:#04241a;box-shadow:0 12px 26px -12px rgba(16,185,129,.6)}
.btn--gold:hover,.btn--accent:hover{background:var(--green-700);color:#04241a;transform:translateY(-2px)}
.btn--ghost{background:#fff;color:var(--ink);border-color:var(--line);box-shadow:var(--shadow-sm)}
.btn--ghost:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}
.btn--light{background:#fff;color:var(--blue);border-color:transparent}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn--outline-light:hover{border-color:#fff;background:rgba(255,255,255,.1);color:#fff}
.btn--wa{background:#25D366;color:#06311c;border:none}
.btn--lg{padding:1.06em 1.95em;font-size:1.06rem}
.btn--block{display:flex;width:100%}

/* ---- header ---- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:1.2rem}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--ff-head);font-weight:800;color:var(--ink);font-size:1.08rem;letter-spacing:-.02em}
.brand:hover{color:var(--ink)}
.brand .mark{width:40px;height:40px;border-radius:12px;background:var(--grad-blue);color:#fff;display:flex;
  align-items:center;justify-content:center;line-height:1;letter-spacing:-.01em;font-weight:800;font-size:.95rem;
  flex:0 0 auto;box-shadow:var(--shadow-blue)}
.brand .mark b{color:#8ff0d0}
.brand small{display:block;font-family:var(--ff-body);font-weight:500;font-size:.66rem;color:var(--muted);letter-spacing:0;margin-top:1px}
.nav-links{display:flex;align-items:center;gap:.1rem;list-style:none;margin:0;padding:0}
.nav-links a{font-weight:600;font-size:.95rem;color:var(--ink);padding:.5rem .8rem;border-radius:9px;transition:background .15s,color .15s}
.nav-links a:hover{background:var(--bg-soft);color:var(--blue)}
.nav-links a.active{color:var(--blue)}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.dropdown{position:relative}
.dropdown-menu{position:absolute;top:calc(100% + 10px);left:0;min-width:320px;background:#fff;
  border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:8px;
  opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s var(--ease);
  display:grid;grid-template-columns:1fr 1fr;gap:2px}
.dropdown:hover .dropdown-menu,.dropdown:focus-within .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu a{display:block;padding:.6rem .8rem;border-radius:10px;font-size:.92rem;color:var(--ink);font-weight:600}
.dropdown-menu a:hover{background:var(--bg-soft)}
.dropdown-menu a small{display:block;color:var(--muted);font-weight:400;font-size:.76rem;margin-top:1px}
.hamburger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.2s}

/* ---- hero (licht, split, met telefoon-demo) ---- */
.hero{background:var(--grad-hero);overflow:hidden;position:relative}
.hero .container{padding-top:clamp(44px,6vw,82px);padding-bottom:clamp(44px,6vw,78px);position:relative}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,60px);align-items:center}
.hero h1{max-width:16ch}
.hero h1 span{color:var(--blue);position:relative;white-space:nowrap}
.hero h1 span::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.34em;border-radius:6px;
  background:linear-gradient(90deg,rgba(16,185,129,.35),rgba(16,185,129,.18));z-index:-1}
.hero .lead{max-width:47ch;margin-bottom:1.8rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:.7rem 1.1rem;margin-top:1.8rem;color:var(--slate);font-size:.92rem}
.hero-trust .ht{display:inline-flex;align-items:center;gap:.45rem;font-weight:600}
.hero-trust svg{color:var(--green-700);width:18px;height:18px;flex:0 0 auto}
.page-hero{background:var(--grad-hero);padding:clamp(44px,6vw,78px) 0 clamp(30px,4vw,48px)}
.page-hero .container{max-width:820px;text-align:center}
.page-hero .lead{max-width:60ch;margin-inline:auto}
.crumbs{font-size:.85rem;color:var(--muted);margin-bottom:1rem}
.crumbs a{color:var(--muted)}.crumbs a:hover{color:var(--blue)}

/* hero entrée-animatie (alleen met motion) */
.hero-anim>*{opacity:0;transform:translateY(18px);animation:heroUp .7s var(--ease) forwards}
.hero-anim>*:nth-child(1){animation-delay:.05s}
.hero-anim>*:nth-child(2){animation-delay:.13s}
.hero-anim>*:nth-child(3){animation-delay:.21s}
.hero-anim>*:nth-child(4){animation-delay:.29s}
.hero-anim>*:nth-child(5){animation-delay:.37s}
@keyframes heroUp{to{opacity:1;transform:none}}

/* ---- telefoon-/chat-demo (het echte product) ---- */
.phone-wrap{position:relative;display:flex;justify-content:center}
.phone-wrap::before{content:"";position:absolute;width:78%;height:78%;top:8%;left:11%;border-radius:50%;
  background:radial-gradient(closest-side,rgba(29,95,216,.20),transparent);filter:blur(10px);z-index:0}
.phone{position:relative;z-index:1;width:100%;max-width:300px;margin-inline:auto;background:#0b1626;border-radius:40px;padding:13px;
  box-shadow:var(--shadow-lg);border:1px solid #20304a}
.phone-screen{background:#0e1828;border-radius:28px;overflow:hidden;height:520px;display:flex;flex-direction:column}
.phone-top{background:#122036;color:#cdd8ea;padding:13px 15px;display:flex;align-items:center;gap:.55rem;border-bottom:1px solid #1e2c45}
.phone-top .av{width:34px;height:34px;border-radius:50%;background:var(--green);display:grid;place-items:center}
.phone-top .av svg{width:18px;height:18px;stroke:#04241a}
.phone-top b{color:#fff;font-size:.92rem}
.phone-top small{color:#7e8ba6;font-size:.72rem}
.chat{flex:1;padding:15px;display:flex;flex-direction:column;gap:9px;overflow:hidden}
.bub{max-width:80%;padding:9px 12px;border-radius:16px;font-size:.88rem;line-height:1.4;overflow-wrap:anywhere;word-break:break-word;opacity:0;transform:translateY(8px) scale(.98);animation:pop .42s var(--ease) forwards}
.bub .link{overflow-wrap:anywhere;word-break:break-all}
.bub.them{background:#1b2840;color:#dfe7f4;align-self:flex-start;border-bottom-left-radius:5px}
.bub.us{background:var(--green);color:#04241a;align-self:flex-end;border-bottom-right-radius:5px;font-weight:600}
.bub.alert{background:#2a1620;color:#ffd7d7;align-self:center;font-size:.76rem;border:1px solid #50212e;display:inline-flex;align-items:center;gap:.4rem;max-width:92%}
.bub.alert svg{width:14px;height:14px;stroke:#ff8a8a}
.bub .link{color:#04241a;text-decoration:underline;font-weight:700}
@keyframes pop{to{opacity:1;transform:none}}

/* ---- grids / cards ---- */
.grid{display:grid;gap:22px}
.hero-grid>*,.split-2>*,.hiw-split>*,.calc>*,.contact-grid>*,.vs>*,.grid>*,.steps>*,.showcase>*,.stats>*{min-width:0}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--blue-100)}
.card .ic-box{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;margin-bottom:1rem;
  background:var(--blue-50);box-shadow:inset 0 0 0 1px var(--blue-100)}
.card .ic-box svg{width:24px;height:24px;stroke:var(--blue)}
/* losse .ic-iconen op andere pagina's krijgen automatisch dezelfde 'geboxte' look */
.card svg.ic{width:24px;height:24px;stroke:var(--blue);margin-bottom:1rem;padding:11px;box-sizing:content-box;
  background:var(--blue-50);border-radius:13px;box-shadow:inset 0 0 0 1px var(--blue-100)}
.card h3{margin-bottom:.4rem}
.card p{margin:0;color:var(--slate);font-size:.99rem}
.section--dark .card{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.10);box-shadow:none;backdrop-filter:blur(4px)}
.section--dark .card:hover{border-color:rgba(16,185,129,.4);transform:translateY(-4px)}
.section--dark .card p{color:#aabfd8}
.section--dark .card svg.ic{stroke:var(--green);background:rgba(16,185,129,.12);box-shadow:inset 0 0 0 1px rgba(16,185,129,.25)}
.section--dark .card .ic-box{background:rgba(16,185,129,.12);box-shadow:inset 0 0 0 1px rgba(16,185,129,.25)}
.section--dark .card .ic-box svg{stroke:var(--green)}

/* ---- usp / probleem ---- */
.usp{display:flex;gap:.8rem;align-items:flex-start}
.usp .ic-box{flex:0 0 auto;width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:var(--green-50);box-shadow:inset 0 0 0 1px #c7eeda}
.usp .ic-box svg{width:22px;height:22px;stroke:var(--green-700)}
.usp>svg,.usp svg.bare{flex:0 0 auto;width:24px;height:24px;stroke:var(--green-700);margin-top:2px}
.usp h3{margin:0 0 .25rem;font-size:1.08rem}
.usp p{margin:0;font-size:.97rem;color:var(--slate)}
.bignum{font-size:clamp(2.6rem,7vw,4.1rem);font-weight:800;color:#fff;letter-spacing:-.035em;line-height:1.05}
.bignum span{color:var(--green)}

/* ---- stat-balk (echte marktcijfers, count-up) ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:center}
.stat{padding:8px 6px}
.stat .num{font-family:var(--ff-head);font-weight:800;font-size:clamp(2rem,4.6vw,3rem);letter-spacing:-.03em;color:var(--ink);line-height:1}
.section--dark .stat .num,.section--blue .stat .num{color:#fff}
.stat .num .u{color:var(--blue)}
.section--dark .stat .num .u,.section--blue .stat .num .u{color:var(--green)}
.stat .lbl{margin-top:.5rem;font-size:.95rem;color:var(--muted)}
.section--dark .stat .lbl,.section--blue .stat .lbl{color:#9fb6d2}

/* ---- "vertrouwd door / wij gebruiken het zelf" logo-strip ---- */
.trust-strip{border:1px solid var(--line);background:#fff;border-radius:var(--radius);padding:22px 26px;
  display:flex;align-items:center;gap:26px;flex-wrap:wrap;justify-content:center;box-shadow:var(--shadow-sm)}
.trust-strip .tl{font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);flex:0 0 auto}
.logos{display:flex;align-items:center;gap:14px 30px;flex-wrap:wrap;justify-content:center}
.logo-chip{display:inline-flex;align-items:center;gap:.55rem;font-weight:800;color:var(--ink);font-size:1.02rem;letter-spacing:-.01em;opacity:.85;transition:opacity .15s}
.logo-chip:hover{opacity:1;color:var(--ink)}
.logo-chip .dot{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;color:#fff;font-size:.82rem;font-weight:800;flex:0 0 auto;background:var(--grad-blue)}
.logo-chip .dot.g{background:linear-gradient(135deg,#16c98c,#059669)}
.logo-chip .dot.k{background:linear-gradient(135deg,#5b8af0,#1d5fd8)}
.logo-chip small{display:block;font-weight:500;font-size:.7rem;color:var(--muted);letter-spacing:0}

/* "wij gebruiken het zelf" highlight-blok */
.dogfood{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center;
  background:linear-gradient(135deg,#fff, #f3f8ff);border:1px solid var(--blue-100);border-radius:var(--radius);
  padding:22px 26px;box-shadow:var(--shadow-sm)}
.dogfood .badge-logo{width:56px;height:56px;border-radius:15px;background:var(--grad-blue);color:#fff;display:grid;place-items:center;font-weight:800;font-size:1.1rem;flex:0 0 auto;box-shadow:var(--shadow-blue)}
.dogfood p{margin:0;color:var(--slate)}
.dogfood b{color:var(--ink)}

/* ---- stappen ---- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:s}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;position:relative;
  box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.step::before{counter-increment:s;content:counter(s);position:absolute;top:-16px;left:22px;width:36px;height:36px;
  background:var(--grad-blue);color:#fff;border-radius:11px;display:grid;place-items:center;font-weight:800;box-shadow:var(--shadow-blue)}
.step h3{margin:.5rem 0 .3rem}.step p{margin:0;color:var(--slate);font-size:.96rem}

/* ---- sticky feature-showcase (telefoon blijft staan, tekst scrolt) ---- */
.showcase{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(28px,4vw,64px);align-items:start}
.showcase .sticky{position:sticky;top:96px}
.showcase-steps{display:flex;flex-direction:column;gap:18px}
.fblock{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 26px;box-shadow:var(--shadow-sm)}
.fblock .k{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;
  background:var(--blue-50);color:var(--blue);font-weight:800;margin-bottom:.7rem;box-shadow:inset 0 0 0 1px var(--blue-100)}
.fblock h3{margin:0 0 .35rem}.fblock p{margin:0;color:var(--slate);font-size:.99rem}

/* ---- ROI calculator ---- */
.calc{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);background:#fff}
.calc-in{padding:34px}
.calc-out{padding:34px;background:var(--navy);color:#dbe6f5;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.calc-out::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 240px at 90% 0%,rgba(16,185,129,.18),transparent 60%);pointer-events:none}
.calc-out>*{position:relative}
.field{margin-bottom:1.6rem}
.field label{display:block;font-weight:600;color:var(--ink);margin-bottom:.55rem}
.field input[type=range]{width:100%;accent-color:var(--blue)}
.field .val{font-weight:800;color:var(--blue)}
.calc-out .sub{color:#9fb2cc;margin-bottom:.4rem;font-size:.96rem}
.calc-out .res{font-size:clamp(2.3rem,5vw,3.1rem);font-weight:800;color:var(--green);letter-spacing:-.025em;margin-bottom:.2rem}
.calc-out .res-note{color:#9fb2cc;font-size:.9rem;margin-bottom:1.1rem}
.calc-out .verdict{background:rgba(16,185,129,.10);border:1px solid rgba(16,185,129,.3);border-radius:var(--radius-sm);padding:14px 16px;font-size:.96rem;color:#c7f5e3}
.calc-foot{color:var(--muted);font-size:.85rem;margin:0}

/* ---- Zonder / Met ---- */
.vs{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.vs-card{border-radius:var(--radius);padding:28px;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.vs-card.zonder{background:linear-gradient(180deg,#fff7f7,#fff);border-color:#fecaca}
.vs-card.met{background:linear-gradient(180deg,#ecfaf4,#fff);border-color:#a7e8d0}
.vs-card h3{display:flex;align-items:center;gap:.5rem}
.vs-card h3 svg{width:24px;height:24px;flex:0 0 auto}
.vs-card.zonder h3{color:#b91c1c}.vs-card.met h3{color:var(--green-700)}
.vs-card ul{list-style:none;margin:.6rem 0 0;padding:0}
.vs-card li{display:flex;gap:.55rem;align-items:flex-start;padding:.4rem 0;font-size:.98rem;color:var(--slate)}
.vs-card li svg{flex:0 0 auto;width:19px;height:19px;margin-top:3px}
.vs-card.zonder li svg{stroke:#ef4444}.vs-card.met li svg{stroke:var(--green-700)}

/* ---- sector grid ---- */
.sector-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.sector-tile{display:flex;align-items:center;gap:.85rem;border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 22px;background:#fff;color:var(--ink);font-weight:700;box-shadow:var(--shadow-sm);
  transition:transform .18s var(--ease),box-shadow .18s var(--ease),border-color .18s}
.sector-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--blue);color:var(--ink)}
.sector-tile .ic-box{width:42px;height:42px;border-radius:11px;background:var(--blue-50);display:grid;place-items:center;flex:0 0 auto;box-shadow:inset 0 0 0 1px var(--blue-100)}
.sector-tile .ic-box svg{width:23px;height:23px;stroke:var(--blue)}
.sector-tile>svg{width:26px;height:26px;stroke:var(--blue);flex:0 0 auto}
.sector-tile .arr{margin-left:auto;color:var(--muted);transition:transform .18s var(--ease),color .18s}
.sector-tile:hover .arr{transform:translateX(4px);color:var(--blue)}

/* ---- pricing ---- */
.price-card{max-width:540px;margin:0 auto;border:1px solid var(--blue-100);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:#fff}
.price-head{background:var(--grad-blue);color:#fff;padding:30px 32px;position:relative;overflow:hidden}
.price-head::before{content:"";position:absolute;inset:0;background:radial-gradient(420px 180px at 90% -20%,rgba(16,185,129,.35),transparent 60%);pointer-events:none}
.price-head>*{position:relative}
.price-head .amt{font-size:3.1rem;font-weight:800;letter-spacing:-.035em;line-height:1}
.price-head .amt small{font-size:1rem;font-weight:600;opacity:.85}
.price-head .sub{opacity:.92;margin:.35rem 0 0}
.price-body{padding:28px 32px}
.price-body ul{list-style:none;margin:0 0 1.4rem;padding:0}
.price-body li{display:flex;gap:.6rem;align-items:flex-start;padding:.5rem 0;border-bottom:1px solid var(--line)}
.price-body li svg{width:20px;height:20px;stroke:var(--green-700);flex:0 0 auto;margin-top:2px}
.guarantee{display:flex;gap:.5rem;align-items:center;justify-content:center;margin-top:1.1rem;color:var(--muted);font-size:.92rem}
.guarantee svg{width:20px;height:20px;stroke:var(--green-700)}

/* ---- reviews ---- */
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);
  transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.review-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.review-card .stars{color:#f5a524;letter-spacing:2px;margin-bottom:.6rem;font-size:1.05rem}
.review-card p{font-size:1.04rem;color:var(--ink);line-height:1.55}
.review-card .who{display:flex;align-items:center;gap:.7rem;margin-top:1.1rem;color:var(--muted);font-size:.9rem}
.review-card .who .av{width:42px;height:42px;border-radius:50%;background:var(--blue-50);color:var(--blue);display:grid;place-items:center;font-weight:800;flex:0 0 auto}
.review-card .who b{display:block;color:var(--ink)}
.review-card.soon{background:var(--bg-soft);border-style:dashed;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:var(--muted)}
.review-card.soon svg{width:30px;height:30px;stroke:var(--blue);margin-bottom:.6rem}

/* ---- faq ---- */
.faq{max-width:800px;margin:0 auto}
.faq details{border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:12px;background:#fff;box-shadow:var(--shadow-sm);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:18px 20px;font-weight:700;color:var(--ink);font-size:1.05rem;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pl{flex:0 0 auto;width:22px;height:22px;stroke:var(--blue);transition:transform .2s var(--ease)}
.faq details[open]{border-color:var(--blue-100)}
.faq details[open] summary .pl{transform:rotate(45deg)}
.faq .ans{padding:0 20px 18px;color:var(--slate);max-width:70ch}

/* ---- cta band ---- */
.cta-band{background:var(--navy);color:#fff;border-radius:var(--radius-lg);padding:clamp(34px,5vw,60px);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 280px at 20% 0%,rgba(29,95,216,.32),transparent 55%),radial-gradient(520px 260px at 100% 120%,rgba(16,185,129,.2),transparent 55%);pointer-events:none}
.cta-band>*{position:relative}
.cta-band h2{color:#fff}
.cta-band p{color:#aabfd8;max-width:54ch;margin:0 auto 1.5rem}

/* ---- contact form ---- */
.form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form .full{grid-column:1/-1}
.form label{display:block;font-weight:600;color:var(--ink);font-size:.92rem;margin-bottom:.3rem}
.form input,.form textarea,.form select{width:100%;padding:.85rem 1rem;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;background:#fff;color:var(--ink);transition:border-color .15s,box-shadow .15s}
.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 3px var(--blue-50)}
.form-note{color:var(--muted);font-size:.85rem;margin-top:.4rem}
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:38px;align-items:start}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.contact-aside{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.contact-aside .row{display:flex;gap:.6rem;align-items:flex-start;padding:.5rem 0}
.contact-aside .row svg{width:20px;height:20px;stroke:var(--blue);flex:0 0 auto;margin-top:3px}

/* ---- footer ---- */
.site-footer{background:#081320;color:#9fb2cc;padding:56px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:32px}
.footer-brand .brand{color:#fff}
.footer-brand .brand .mark{box-shadow:none}
.footer-brand p{margin-top:12px;font-size:.92rem;color:#8fa1bb}
.foot-h{font-weight:700;color:#fff;margin:0 0 .6rem}
.site-footer a{display:block;color:#c2d0e4;padding:.26rem 0;font-size:.93rem;transition:color .15s}
.site-footer a:hover{color:#fff}
/* knop in de footer mag niet door de footer-link-regel block/full-width worden */
.site-footer .btn{display:inline-flex;width:auto;color:#04241a;padding:.92em 1.5em;margin-top:14px}
.site-footer .btn:hover{color:#04241a}
.site-footer .footer-brand .brand{display:inline-flex}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid #16263b;margin-top:36px;padding-top:22px;font-size:.85rem;color:#7e90ab}
.footer-bottom a{display:inline}

/* ---- WhatsApp float + mobile CTA ---- */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:60;background:#25D366;color:#fff;display:flex;align-items:center;gap:.5rem;
  padding:.75rem .95rem;border-radius:999px;box-shadow:var(--shadow);font-weight:600;font-size:.9rem;transition:transform .18s var(--ease)}
.wa-float span{display:none}
.wa-float:hover{color:#fff;transform:translateY(-3px) scale(1.03)}
.mobile-cta{display:none}

/* ---- 2-koloms split (scenario / hoe-het-werkt) ---- */
.hiw-split,.split-2{display:grid;gap:38px;align-items:center}
.split-2{grid-template-columns:1fr 1fr}
@media(max-width:820px){.hiw-split,.split-2,.showcase{grid-template-columns:1fr!important}.showcase .sticky{position:static}}

/* ---- reveal (verfijnde scroll-motion met richting + scale) ---- */
.reveal{opacity:0;transform:translateY(22px) scale(.985);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important}
  .hero-anim>*{opacity:1!important;transform:none!important;animation:none!important}
}

/* ---- responsive ---- */
@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero h1,.hero .lead{margin-inline:auto}.hero-cta,.hero-trust{justify-content:center}
  .grid-3,.grid-4,.steps,.sector-grid,.stats{grid-template-columns:repeat(2,1fr)}
  .calc,.vs,.contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .dropdown-menu{grid-template-columns:1fr}
}
@media(max-width:680px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-mobile-open .nav-links{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;
    background:#fff;border-bottom:1px solid var(--line);padding:10px 16px;gap:2px;box-shadow:var(--shadow)}
  .nav-mobile-open .nav-links a{padding:.7rem .6rem}
  .hamburger{display:block}
  .grid-3,.grid-4,.steps,.sector-grid,.form,.footer-grid,.stats{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;gap:18px}
  .dogfood{grid-template-columns:1fr;text-align:center;justify-items:center}
  .trust-strip{flex-direction:column;gap:16px}
  .mobile-cta{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;gap:8px;padding:10px 14px;
    background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-top:1px solid var(--line);
    transform:translateY(110%);transition:transform .25s var(--ease)}
  .mobile-cta.is-visible{transform:none}
  .mobile-cta .btn{flex:1}.mobile-cta .btn--wa{flex:0 0 auto}
  .wa-float{display:none}
  body{font-size:16px}
}
