/* ============================================================
   IT-offerte.be · gedeeld design systeem
   Deep navy corporate trust · clean grotesk autoriteit · subtiele motion
   ============================================================ */

:root {
  --navy: #0B2A5B;
  --navy-deep: #081D40;
  --navy-2: #0A2350;
  --blue: #2563EB;
  --blue-soft: #EAF0FE;
  --cyan: #22D3EE;
  --cyan-soft: rgba(34, 211, 238, .12);
  --ink: #0C1730;
  --slate: #5A6B86;
  --slate-light: #8B99B3;
  --line: #E3E9F2;
  --paper: #F6F8FC;
  --white: #FFFFFF;
  --emerald: #0E9F6E;
  --font-display: 'Schibsted Grotesk', 'Instrument Sans', sans-serif;
  --font-body: 'Instrument Sans', sans-serif;
  --shadow-card: 0 1px 2px rgba(11,42,91,.05), 0 12px 32px -16px rgba(11,42,91,.14);
  --shadow-pop: 0 30px 70px -30px rgba(8,29,64,.45);
  --r-lg: 20px;
  --r-md: 14px;
  --r-sm: 10px;
  --maxw: 1200px;
}

html.t-sans { --font-display: 'Schibsted Grotesk', sans-serif; }
html.t-sans .serif-em { font-style: normal; }

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  background: var(--paper);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection { background: rgba(37,99,235,.18); }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; }

/* ---------- type ---------- */
h1, h2, h3 { text-wrap: balance; }
.display { font-family: var(--font-display); font-weight: 600; letter-spacing: -.025em; }
.serif-em { font-style: normal; color: var(--blue); }
.hero h1 .serif-em, .page-head h1 .serif-em { white-space: nowrap; }
html.t-sans .display { font-weight: 600; letter-spacing: -.025em; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 13px; font-weight: 600; letter-spacing: .07em; text-transform: uppercase;
  color: var(--blue); margin-bottom: 18px;
}
.eyebrow .pulse {
  width: 8px; height: 8px; border-radius: 50%; background: var(--cyan);
  box-shadow: 0 0 0 4px rgba(34,211,238,.18);
}
.on-dark .eyebrow { color: #8FD6E8; }

.section-head { max-width: 760px; }
.section-head h2 { font-size: clamp(34px, 4vw, 46px); line-height: 1.06; margin: 0 0 16px; }
.section-head .sub { font-size: 18px; color: var(--slate); margin: 0; }
.on-dark .section-head .sub { color: rgba(255,255,255,.72); }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--font-body); font-weight: 600; font-size: 16px;
  border-radius: 12px; border: none; cursor: pointer; text-decoration: none;
  padding: 15px 28px; transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  white-space: nowrap;
}
.btn .arr { transition: transform .18s ease; display: inline-block; }
.btn:hover .arr { transform: translateX(4px); }
.btn-primary { background: var(--navy); color: #fff; box-shadow: 0 10px 24px -10px rgba(11,42,91,.5); }
.btn-primary:hover { background: var(--navy-2); transform: translateY(-1px); box-shadow: 0 16px 32px -12px rgba(11,42,91,.55); }
.btn-blue { background: var(--blue); color: #fff; box-shadow: 0 10px 24px -10px rgba(37,99,235,.55); }
.btn-blue:hover { transform: translateY(-1px); }
.btn-ghost { background: transparent; color: var(--navy); padding: 15px 18px; }
.btn-ghost:hover { background: rgba(11,42,91,.06); }
.btn-light { background: #fff; color: var(--navy); }
.btn-light:hover { transform: translateY(-1px); box-shadow: 0 16px 32px -14px rgba(0,0,0,.4); }
.btn-sm { padding: 10px 18px; font-size: 14px; border-radius: 10px; }

/* ---------- nav ---------- */
.site-nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.86); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
  transition: box-shadow .25s ease;
}
.site-nav.scrolled { box-shadow: 0 8px 24px -16px rgba(11,42,91,.25); }
.site-nav .inner {
  max-width: var(--maxw); margin: 0 auto; padding: 0 32px;
  display: flex; align-items: center; justify-content: space-between; height: 72px;
}
.brand { display: flex; align-items: center; gap: 11px; font-weight: 700; font-size: 19px; letter-spacing: -.01em; color: var(--ink); text-decoration: none; white-space: nowrap; }
.brand span { white-space: nowrap; }
.brand .tld { color: var(--blue); }
.brand svg { display: block; }
.nav-links { display: flex; gap: 30px; }
.nav-links a { font-size: 15px; font-weight: 500; color: var(--slate); text-decoration: none; transition: color .15s; }
.nav-links a:hover { color: var(--navy); }
.nav-cta { display: flex; align-items: center; gap: 10px; }

/* ---------- trust strip ---------- */
.trust-strip {
  background: var(--navy); color: #CFE0FF;
  font-size: 12.5px; font-weight: 500; letter-spacing: .05em; text-transform: uppercase;
}
.trust-strip .inner {
  max-width: var(--maxw); margin: 0 auto; padding: 11px 32px;
  display: flex; align-items: center; justify-content: center; gap: 12px; flex-wrap: wrap;
}
.trust-strip span { white-space: nowrap; }
.trust-strip b { color: #fff; font-weight: 600; }
.trust-strip .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--cyan); margin: 0 10px; }

/* ---------- hero ---------- */
.hero { position: relative; overflow: hidden; }
.hero .bg-glow {
  position: absolute; top: -240px; right: -180px; width: 720px; height: 720px;
  background: radial-gradient(closest-side, rgba(37,99,235,.10), transparent);
  border-radius: 50%; pointer-events: none;
}
.hero .bg-arcs { position: absolute; top: -130px; right: -130px; pointer-events: none; opacity: .6; }
.hero .inner {
  max-width: var(--maxw); margin: 0 auto; padding: 72px 32px 56px;
  display: grid; grid-template-columns: 1.02fr .98fr; gap: 56px; align-items: center;
  position: relative;
}
.hero h1 { font-size: clamp(44px, 4.6vw, 62px); line-height: 1.04; margin: 0 0 20px; }
.hero .lead { font-size: 19px; line-height: 1.55; color: var(--slate); max-width: 480px; margin: 0 0 30px; }
.hero .lead b { color: var(--ink); font-weight: 600; }
.cta-row { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-bottom: 26px; }
.micro-trust { display: flex; gap: 22px; flex-wrap: wrap; font-size: 14px; color: var(--slate); font-weight: 500; }
.micro-trust span { display: inline-flex; align-items: center; gap: 7px; }
.check-ic { color: var(--emerald); font-weight: 700; font-style: normal; }

/* ---------- vergelijkingsconsole ---------- */
.console {
  background: linear-gradient(160deg, #0E3168 0%, var(--navy-deep) 80%);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-lg); padding: 22px;
  color: #EAF1FF; box-shadow: var(--shadow-pop);
  position: relative; overflow: hidden;
}
.console::before {
  content: ''; position: absolute; inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 40px 40px; pointer-events: none;
  mask-image: radial-gradient(120% 80% at 80% 0%, #000 20%, transparent 70%);
}
.console > * { position: relative; }
.console-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.console-top .ttl { font-weight: 600; font-size: 15.5px; display: flex; align-items: center; gap: 10px; }
.tag-demo {
  display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 600;
  color: #7DEFC0; background: rgba(52,227,160,.08); border: 1px solid rgba(125,239,192,.3);
  padding: 4px 10px; border-radius: 99px; letter-spacing: .02em;
}
.tag-demo i { width: 6px; height: 6px; border-radius: 50%; background: #34E3A0; animation: blink 2.4s infinite; }
@keyframes blink { 0%,100% { opacity: 1; } 50% { opacity: .35; } }
.console-sub { font-size: 13px; color: #9DB2D6; margin: 0 0 14px; }
.console-req {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-md); padding: 14px 16px; margin-bottom: 16px;
}
.console-req .req-label { font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: #7DEFC0; margin-bottom: 5px; }
.console-req .req-title { font-weight: 600; font-size: 15.5px; color: #EAF1FF; line-height: 1.35; }
.console-req .req-specs { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 11px; }
.console-req .req-specs span {
  font-size: 11.5px; font-weight: 500; color: #9DB2D6;
  border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.04);
  padding: 4px 10px; border-radius: 99px;
}
.offer-list { display: flex; flex-direction: column; gap: 10px; }
.offer {
  display: grid; grid-template-columns: auto 1fr auto; gap: 13px; align-items: center;
  padding: 13px 14px; border: 1px solid rgba(255,255,255,.1); border-radius: var(--r-md);
  background: rgba(255,255,255,.03); cursor: pointer; transition: all .2s ease;
}
.offer:hover { border-color: rgba(34,211,238,.45); transform: translateY(-1px); }
.offer.sel { border-color: var(--cyan); background: rgba(34,211,238,.07); box-shadow: 0 0 0 1px rgba(34,211,238,.35) inset; }
.offer .av {
  width: 40px; height: 40px; border-radius: 10px; display: grid; place-items: center;
  font-weight: 700; color: #fff; font-size: 15px; flex-shrink: 0;
}
.offer .meta { display: flex; flex-direction: column; min-width: 0; }
.offer .nm { font-weight: 600; font-size: 14.5px; display: flex; align-items: center; gap: 8px; white-space: nowrap; }
.offer .nm .lock { opacity: .55; display: inline-flex; }
.offer .tags { font-size: 12px; color: #9DB2D6; margin-top: 2px; display: block; }
.offer .sc { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; text-align: right; min-width: 94px; }
.offer .sc .price { font-weight: 700; font-size: 17px; color: #fff; white-space: nowrap; line-height: 1.1; }
.offer .sc .price small { display: block; font-weight: 500; font-size: 10.5px; color: #7C90B8; letter-spacing: .02em; }
.offer .sc .score-row { display: flex; align-items: center; gap: 8px; }
.offer .sc .score-row .val { font-weight: 600; font-size: 12.5px; color: #9DB2D6; }
.offer .sc .bar { display: block; width: 58px; height: 5px; border-radius: 99px; background: rgba(255,255,255,.1); overflow: hidden; }
.offer .sc .bar i {
  display: block; height: 100%; border-radius: 99px;
  background: linear-gradient(90deg, var(--blue), var(--cyan));
  transition: width 1s cubic-bezier(.22,1,.36,1);
}
.offer .reveal-name { display: none; color: #7DEFC0; font-weight: 600; }
.offer.revealed .nm .masked { display: none; }
.offer.revealed .reveal-name { display: inline; }
.console-foot {
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  margin-top: 16px; padding-top: 16px; border-top: 1px dashed rgba(255,255,255,.14);
}
.console-foot .hint { font-size: 13px; color: #9DB2D6; }
.console-foot .hint b { color: #fff; }
.btn-reveal {
  background: var(--cyan); color: #062033; font-weight: 700; font-size: 13.5px;
  border: none; border-radius: var(--r-sm); padding: 11px 18px; cursor: pointer; white-space: nowrap;
  font-family: var(--font-body); transition: transform .15s ease, box-shadow .15s ease;
}
.btn-reveal:hover { transform: translateY(-1px); box-shadow: 0 10px 22px -8px rgba(34,211,238,.5); }
.btn-reveal:disabled { opacity: .45; cursor: not-allowed; transform: none; box-shadow: none; }
.console-note { font-size: 12px; color: #7C90B8; margin: 12px 0 0; text-align: center; }
.console-note a { color: #8FD6E8; }

/* ---------- stat band ---------- */
.stat-band { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: #fff; }
.stat-band .inner {
  max-width: var(--maxw); margin: 0 auto; padding: 30px 32px;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
.stat { text-align: center; }
.stat .big { font-family: var(--font-display); font-size: 38px; font-weight: 500; color: var(--navy); line-height: 1.1; letter-spacing: -.01em; }
.stat .lbl { font-size: 13.5px; color: var(--slate); margin-top: 2px; }

/* ---------- sections ---------- */
.section { padding: 96px 0; }
.section.tight { padding: 72px 0; }

/* steps */
.steps-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-top: 52px; position: relative; }
.step-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 28px 24px; position: relative;
  transition: transform .2s ease, box-shadow .2s ease;
}
.step-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card); }
.step-card .n {
  font-family: var(--font-display); font-size: 38px; font-weight: 500; color: var(--blue);
  line-height: 1; margin-bottom: 16px;
}
.step-card h3 { font-size: 17.5px; font-weight: 600; margin: 0 0 8px; line-height: 1.3; }
.step-card p { font-size: 14.5px; color: var(--slate); margin: 0; line-height: 1.55; }
.step-card p b { color: var(--ink); font-weight: 600; }
.steps-cta { text-align: center; margin-top: 44px; }

/* waarom · split checklist */
.why-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 64px; align-items: start; }
.why-side { position: sticky; top: 110px; }
.why-visual { margin-top: 36px; }
.why-list { display: flex; flex-direction: column; }
.why-item {
  display: grid; grid-template-columns: auto 1fr; gap: 18px; align-items: start;
  padding: 24px 0; border-bottom: 1px solid var(--line);
}
.why-item:first-child { padding-top: 4px; }
.why-item .ic {
  width: 44px; height: 44px; border-radius: 12px; background: var(--blue-soft);
  display: grid; place-items: center; color: var(--blue); flex-shrink: 0;
}
.why-item h3 { font-size: 17px; font-weight: 600; margin: 2px 0 6px; }
.why-item p { font-size: 15px; color: var(--slate); margin: 0; line-height: 1.6; }
.why-item p b { color: var(--ink); font-weight: 600; }

/* voordelen + voor wie */
.adv-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-top: 48px; }
.adv-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 26px 24px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.adv-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card); }
.adv-card .ic { width: 42px; height: 42px; border-radius: 11px; background: var(--blue-soft); color: var(--blue); display: grid; place-items: center; margin-bottom: 16px; }
.adv-card p { font-size: 14.5px; color: var(--slate); margin: 0; line-height: 1.55; }
.adv-card h3 { font-size: 16.5px; font-weight: 600; margin: 0 0 7px; }

.who-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; margin-top: 48px; }
.who-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px;
  display: grid; grid-template-columns: auto 1fr; gap: 18px; align-items: center;
  transition: transform .2s ease, box-shadow .2s ease;
}
.who-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card); }
.who-card .ic { width: 48px; height: 48px; border-radius: 13px; background: var(--navy); color: var(--cyan); display: grid; place-items: center; }
.who-card p { font-size: 15.5px; margin: 0; color: var(--ink); line-height: 1.5; }
.who-card p b { font-weight: 600; }

/* faq */
.faq-wrap { max-width: 860px; margin: 48px auto 0; display: flex; flex-direction: column; gap: 12px; }
.faq-item {
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-md);
  transition: box-shadow .2s ease, border-color .2s ease;
}
.faq-item[open] { border-color: rgba(37,99,235,.35); box-shadow: var(--shadow-card); }
.faq-item summary {
  list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 20px 24px; font-weight: 600; font-size: 16.5px;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary .pm {
  width: 28px; height: 28px; border-radius: 50%; border: 1px solid var(--line); flex-shrink: 0;
  display: grid; place-items: center; color: var(--blue); font-weight: 500; font-size: 17px;
  transition: transform .25s ease, background .2s ease;
}
.faq-item[open] summary .pm { transform: rotate(45deg); background: var(--blue-soft); border-color: transparent; }
.faq-item .faq-body { padding: 0 24px 22px; color: var(--slate); font-size: 15.5px; line-height: 1.65; max-width: 720px; }
.faq-item .faq-body p { margin: 0 0 10px; }
.faq-item .faq-body p:last-child { margin-bottom: 0; }

/* ---------- case study (navy band) ---------- */
.band-navy {
  background: linear-gradient(170deg, var(--navy) 0%, var(--navy-deep) 90%);
  color: #EAF1FF; position: relative; overflow: hidden;
}
.band-navy .bg-arcs { position: absolute; top: -180px; right: -180px; opacity: .35; pointer-events: none; }
.case-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 64px; margin-top: 52px; align-items: start; position: relative; }
.case-block h3 {
  font-size: 14px; font-weight: 600; letter-spacing: .07em; text-transform: uppercase;
  color: #8FD6E8; margin: 0 0 10px;
}
.case-block { margin-bottom: 32px; }
.case-block p { font-size: 15.5px; line-height: 1.65; color: rgba(255,255,255,.82); margin: 0 0 12px; }
.case-block p b { color: #fff; font-weight: 600; }
.case-params { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 14px; }
.case-params span {
  font-size: 13px; font-weight: 500; color: #CFE0FF; border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.05); padding: 7px 14px; border-radius: 99px;
}
.case-aside { position: sticky; top: 110px; display: flex; flex-direction: column; gap: 18px; }
.quote-card {
  background: #fff; color: var(--ink); border-radius: var(--r-lg); padding: 30px;
  box-shadow: var(--shadow-pop);
}
.quote-card .qmark { font-family: var(--font-display); font-size: 54px; line-height: .6; color: var(--blue); display: block; margin-bottom: 14px; }
.quote-card p { font-size: 16px; line-height: 1.6; margin: 0 0 12px; }
.quote-card .who { font-size: 13.5px; color: var(--slate); font-weight: 500; }
.case-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.case-stat {
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-md); padding: 18px 14px; text-align: center;
}
.case-stat .big { font-family: var(--font-display); font-size: 30px; color: var(--cyan); font-weight: 500; line-height: 1.1; }
.case-stat .lbl { font-size: 12px; color: #9DB2D6; margin-top: 3px; }

/* ---------- cta band ---------- */
.cta-final { text-align: center; position: relative; overflow: hidden; }
.cta-final .bg-glow {
  position: absolute; left: 50%; top: -300px; transform: translateX(-50%);
  width: 900px; height: 600px; border-radius: 50%;
  background: radial-gradient(closest-side, rgba(37,99,235,.09), transparent); pointer-events: none;
}
.cta-final h2 { font-size: clamp(38px, 4.4vw, 54px); margin: 0 0 14px; }
.cta-final .sub { font-size: 19px; color: var(--slate); margin: 0 0 32px; }
.cta-final .sub b { color: var(--ink); }

/* kleine lettertjes */
.fine-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px 28px; margin-top: 44px; }
.fine-item {
  display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: start;
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-md); padding: 18px 20px;
}
.fine-item .check-ic { margin-top: 2px; }
.fine-item p { margin: 0; font-size: 15.5px; line-height: 1.55; color: var(--ink); }

/* ---------- footer ---------- */
.site-footer { background: var(--navy-deep); color: #9DB2D6; }
.site-footer .inner {
  max-width: var(--maxw); margin: 0 auto; padding: 56px 32px 36px;
}
.footer-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 40px; flex-wrap: wrap; padding-bottom: 36px; border-bottom: 1px solid rgba(255,255,255,.09); }
.site-footer .brand { color: #fff; }
.site-footer .tagline { font-size: 14.5px; max-width: 380px; margin: 14px 0 0; line-height: 1.6; }
.footer-col h4 { color: #fff; font-size: 14px; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; margin: 0 0 14px; }
.footer-col a { display: block; color: #9DB2D6; text-decoration: none; font-size: 14.5px; margin-bottom: 9px; transition: color .15s; }
.footer-col a:hover { color: #fff; }
.footer-bottom { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; padding-top: 24px; font-size: 13px; color: #7C90B8; }

/* ---------- reveals ---------- */
@media (prefers-reduced-motion: no-preference) {
  /* alleen elementen onder de vouw worden door JS gemarkeerd met [data-pre];
     zonder JS of animatie blijft alles gewoon zichtbaar */
  html.motion [data-reveal][data-pre] {
    opacity: 0; transform: translateY(22px);
    transition: opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
    transition-delay: var(--rd, 0s);
  }
  html.motion [data-reveal][data-pre].in { opacity: 1; transform: none; }
}

/* ============================================================
   AANVRAAG-pagina
   ============================================================ */
.page-head { position: relative; overflow: hidden; }
.page-head .inner { display: block; max-width: var(--maxw); margin: 0 auto; padding: 56px 32px 48px; position: relative; }
.page-head h1 { font-size: clamp(38px, 4.2vw, 54px); line-height: 1.06; margin: 0 0 18px; max-width: 800px; }
.page-head .lead { font-size: 17.5px; color: var(--slate); max-width: 760px; margin: 0; line-height: 1.65; }
.page-head .lead b { color: var(--ink); font-weight: 600; }

.apply-layout {
  max-width: var(--maxw); margin: 0 auto; padding: 0 32px 96px;
  display: grid; grid-template-columns: 1fr 380px; gap: 48px; align-items: start;
}

/* form */
.form-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg);
  box-shadow: var(--shadow-card); overflow: hidden;
}
.form-card-head {
  background: linear-gradient(160deg, #0E3168, var(--navy-deep));
  color: #fff; padding: 26px 32px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
.form-card-head h2 { font-size: 26px; margin: 0; }
.form-card-head .meta { white-space: nowrap; font-size: 13px; font-weight: 600; color: #BDEEFB; background: rgba(34,211,238,.14); border: 1px solid rgba(34,211,238,.3); padding: 6px 13px; border-radius: 99px; }
.form-body { padding: 8px 32px 32px; }

.fieldset { border: none; margin: 0; padding: 26px 0 8px; }
.fieldset + .fieldset { border-top: 1px solid var(--line); }
.fieldset-head { display: flex; align-items: center; gap: 13px; margin-bottom: 20px; }
.fieldset-head .num {
  width: 32px; height: 32px; border-radius: 9px; background: var(--blue-soft); color: var(--blue);
  display: grid; place-items: center; font-weight: 700; font-size: 14.5px; flex-shrink: 0;
}
.fieldset-head h3 { font-size: 19px; font-weight: 600; margin: 0; }
.fieldset-head .opt { font-size: 13px; color: var(--slate-light); font-weight: 500; margin-left: auto; }

.f-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 18px; }
.f-field.full { grid-column: 1 / -1; }
.f-field label { display: block; font-size: 13.5px; font-weight: 600; color: var(--ink); margin-bottom: 7px; }
.f-field label .opt { color: var(--slate-light); font-weight: 500; }
.f-field .note { font-size: 12.5px; color: var(--slate-light); margin-top: 6px; line-height: 1.45; }
.f-input, .f-select, .f-textarea {
  width: 100%; font-family: var(--font-body); font-size: 15px; color: var(--ink);
  background: #F8FAFE; border: 1px solid var(--line); border-radius: var(--r-sm);
  padding: 12px 14px; height: 48px; transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.f-textarea { height: auto; min-height: 110px; resize: vertical; line-height: 1.55; }
.f-input:focus, .f-select:focus, .f-textarea:focus {
  outline: none; border-color: var(--blue); background: #fff; box-shadow: 0 0 0 3px rgba(37,99,235,.12);
}
.f-input::placeholder, .f-textarea::placeholder { color: #A4B1C7; }
.f-select { appearance: none; background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%235A6B86' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 38px; cursor: pointer; }
.f-field.invalid .f-input, .f-field.invalid .f-select, .f-field.invalid .f-textarea { border-color: #E5484D; background: #FFF8F8; }
.f-field.invalid .err { display: block; }
.f-field .err { display: none; font-size: 12.5px; color: #D93840; margin-top: 6px; font-weight: 500; }

/* type project chips */
.type-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.type-opt { position: relative; }
.type-opt input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
.type-opt .face {
  display: flex; align-items: center; justify-content: center; gap: 8px; text-align: center;
  border: 1px solid var(--line); border-radius: var(--r-sm); background: #F8FAFE;
  padding: 13px 10px; font-size: 14px; font-weight: 500; color: var(--slate);
  transition: all .15s ease; cursor: pointer; min-height: 48px;
}
.type-opt input:checked + .face {
  border-color: var(--blue); background: var(--blue-soft); color: var(--blue); font-weight: 600;
  box-shadow: 0 0 0 1px var(--blue) inset;
}
.type-opt input:focus-visible + .face { box-shadow: 0 0 0 3px rgba(37,99,235,.25); }
.type-opt .face::before { content: ''; width: 16px; height: 16px; border-radius: 5px; border: 1.5px solid #C4CEDE; background: #fff; flex-shrink: 0; transition: all .15s ease; }
.type-opt input:checked + .face::before {
  background: var(--blue); border-color: var(--blue);
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8' viewBox='0 0 10 8'%3E%3Cpath d='M1 4l2.8 2.8L9 1.2' stroke='white' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: center;
}

/* consent */
.consent {
  display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: start;
  background: #F8FAFE; border: 1px solid var(--line); border-radius: var(--r-md); padding: 18px 20px;
  cursor: pointer; transition: border-color .15s ease;
}
.consent:hover { border-color: rgba(37,99,235,.4); }
.consent input { width: 20px; height: 20px; margin: 2px 0 0; accent-color: var(--blue); cursor: pointer; }
.consent p { margin: 0; font-size: 14.5px; line-height: 1.55; color: var(--ink); }
.consent.invalid { border-color: #E5484D; background: #FFF8F8; }

.form-foot { padding-top: 26px; }
.btn-submit {
  width: 100%; height: 56px; font-size: 17px; border-radius: var(--r-md);
}
.form-foot .reassure { display: flex; justify-content: center; gap: 22px; flex-wrap: wrap; margin-top: 16px; font-size: 13.5px; color: var(--slate); font-weight: 500; }
.form-foot .reassure span { display: inline-flex; align-items: center; gap: 7px; }

/* thanks */
.thanks { display: none; padding: 56px 40px; text-align: center; }
.thanks.show { display: block; }
.form-card.submitted .form-body, .form-card.submitted .form-card-head .meta { display: none; }
.thanks .big-check {
  width: 76px; height: 76px; border-radius: 50%; background: var(--blue-soft);
  display: grid; place-items: center; margin: 0 auto 24px; color: var(--blue);
}
.thanks h2 { font-size: 34px; margin: 0 0 16px; }
.thanks p { font-size: 16.5px; color: var(--slate); line-height: 1.65; max-width: 520px; margin: 0 auto 10px; }
.thanks .steps-mini { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; max-width: 620px; margin: 28px auto 0; text-align: left; }
.thanks .steps-mini div { background: #F8FAFE; border: 1px solid var(--line); border-radius: var(--r-md); padding: 16px; font-size: 13.5px; color: var(--slate); line-height: 1.5; }
.thanks .steps-mini b { display: block; color: var(--ink); margin-bottom: 4px; font-size: 14px; }

/* side rail */
.side-rail { position: sticky; top: 96px; display: flex; flex-direction: column; gap: 18px; }
.rail-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 26px; }
.rail-card h3 { font-size: 17px; font-weight: 600; margin: 0 0 14px; display: flex; align-items: center; gap: 10px; }
.rail-card h3 .ic { width: 34px; height: 34px; border-radius: 9px; background: var(--blue-soft); color: var(--blue); display: grid; place-items: center; flex-shrink: 0; }
.rail-card p { font-size: 14px; color: var(--slate); line-height: 1.6; margin: 0 0 10px; }
.rail-card p:last-child { margin-bottom: 0; }
.rail-card p b { color: var(--ink); font-weight: 600; }
.rail-list { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 12px; }
.rail-list li { display: grid; grid-template-columns: auto 1fr; gap: 11px; font-size: 14px; color: var(--slate); line-height: 1.55; }
.rail-list li b { color: var(--ink); font-weight: 600; }
.rail-card.navy { background: linear-gradient(160deg, #0E3168, var(--navy-deep)); border-color: rgba(255,255,255,.08); color: #EAF1FF; }
.rail-card.navy h3 { color: #fff; }
.rail-card.navy h3 .ic { background: rgba(34,211,238,.14); color: var(--cyan); }
.rail-card.navy p { color: rgba(255,255,255,.78); }
.rail-card.navy p b, .rail-card.navy a { color: #8FD6E8; }

/* progress dots (form sections) */
.form-progress { display: flex; gap: 8px; align-items: center; }
.form-progress span { width: 26px; height: 5px; border-radius: 99px; background: rgba(255,255,255,.18); transition: background .3s; }
.form-progress span.done { background: var(--cyan); }

/* ---------- vergelijken (verborgen pagina) ---------- */
.vis-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 44px; }
.vis-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px; }
.vis-card.shown { border-color: rgba(14,159,110,.35); }
.vis-card.locked { border-color: rgba(37,99,235,.28); }
.vis-card h3 { font-size: 17px; font-weight: 600; margin: 0 0 18px; display: flex; align-items: center; gap: 10px; }
.vis-card h3 .tag { font-size: 11px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; padding: 4px 10px; border-radius: 99px; }
.vis-card.shown h3 .tag { background: rgba(14,159,110,.12); color: var(--emerald); }
.vis-card.locked h3 .tag { background: var(--blue-soft); color: var(--blue); }
.vis-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.vis-list li { display: grid; grid-template-columns: auto 1fr; gap: 11px; font-size: 14.5px; color: var(--slate); line-height: 1.5; }
.vis-list li b { color: var(--ink); font-weight: 600; }
.vis-list .mk { width: 20px; height: 20px; border-radius: 6px; display: grid; place-items: center; flex-shrink: 0; margin-top: 1px; }
.vis-card.shown .mk { background: rgba(14,159,110,.12); color: var(--emerald); }
.vis-card.locked .mk { background: var(--blue-soft); color: var(--blue); }
@media (max-width: 720px) { .vis-grid { grid-template-columns: 1fr; } }

/* ---------- responsive ---------- */
@media (max-width: 1080px) {
  .hero .inner { grid-template-columns: 1fr; gap: 44px; padding-top: 56px; }
  .hero .lead { max-width: 620px; }
  .steps-grid, .adv-grid { grid-template-columns: repeat(2, 1fr); }
  .why-grid, .case-grid { grid-template-columns: 1fr; gap: 40px; }
  .why-side, .case-aside, .side-rail { position: static; }
  .apply-layout { grid-template-columns: 1fr; }
  .type-grid { grid-template-columns: repeat(2, 1fr); }
  .nav-links { display: none; }
}
@media (max-width: 720px) {
  .container, .site-nav .inner, .hero .inner, .stat-band .inner, .page-head .inner, .apply-layout, .site-footer .inner { padding-left: 20px; padding-right: 20px; }
  .steps-grid, .adv-grid, .who-grid, .fine-grid { grid-template-columns: 1fr; }
  .stat-band .inner { grid-template-columns: repeat(2, 1fr); }
  .f-grid { grid-template-columns: 1fr; }
  .section { padding: 64px 0; }
  .case-stats { grid-template-columns: repeat(3, 1fr); }
  .thanks .steps-mini { grid-template-columns: 1fr; }
}
