/* ============================================================
   DESIGN TOKENS
============================================================ */
:root {
  --clr-primary:  #1e1b4b;
  --clr-accent:   #6366f1;
  --clr-accent-h: #4f46e5;
  --clr-accent2:  #818cf8;
  --clr-soft:     #eef2ff;
  --clr-text:     #334155;
  --clr-muted:    #64748b;
  --clr-light:    #f8fafc;
  --clr-white:    #ffffff;
  --clr-border:   #e2e8f0;

  --gradient: linear-gradient(135deg, #1e1b4b 0%, #312e81 55%, #4338ca 100%);

  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 22px;

  --shadow-sm: 0 2px 12px rgba(0,0,0,.06);
  --shadow-md: 0 8px 30px rgba(0,0,0,.09);
  --shadow-lg: 0 20px 60px rgba(0,0,0,.12);

  --tr: all .35s cubic-bezier(.165,.84,.44,1);
  --max-w: 1200px;
  --header-h: 80px;
}

/* ============================================================
   RESET & BASE
============================================================ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html  { scroll-behavior:smooth; font-size:16px; }
body  { font-family:'Poppins',sans-serif; background:var(--clr-light); color:var(--clr-text); line-height:1.6; overflow-x:hidden; }
img   { display:block; max-width:100%; height:auto; }
a     { color:inherit; }
ul[role="list"] { list-style:none; }

/* ============================================================
   TYPOGRAPHY
============================================================ */
h1 { font-size:clamp(2rem,5vw,3.6rem); font-weight:800; line-height:1.1; color:var(--clr-primary); }
h2 { font-size:clamp(1.6rem,3.5vw,2.6rem); font-weight:800; line-height:1.2; color:var(--clr-primary); }
h3 { font-size:1.15rem; font-weight:700; color:var(--clr-primary); }
p  { color:var(--clr-muted); line-height:1.75; }

/* ============================================================
   LAYOUT
============================================================ */
.container { max-width:var(--max-w); margin-inline:auto; padding-inline:24px; }
.section   { padding-block:100px; }
.section--alt { background:var(--clr-white); }

.section-header { text-align:center; max-width:600px; margin-inline:auto; margin-bottom:64px; }
.section-header p { margin-top:12px; font-size:1.05rem; }

.tag {
  display:inline-block; background:var(--clr-soft); color:var(--clr-accent);
  padding:5px 16px; border-radius:24px; font-size:.75rem; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase; margin-bottom:14px;
}

/* ============================================================
   BUTTONS
============================================================ */
.btn {
  display:inline-block; padding:13px 26px; border-radius:var(--radius-sm);
  font-family:'Poppins',sans-serif; font-weight:700; font-size:.93rem;
  text-decoration:none; cursor:pointer; border:2px solid transparent;
  transition:var(--tr); white-space:nowrap;
}
.btn--primary { background:var(--clr-accent); color:#fff; border-color:var(--clr-accent); }
.btn--primary:hover { background:var(--clr-accent-h); border-color:var(--clr-accent-h); transform:translateY(-2px); box-shadow:0 10px 28px rgba(99,102,241,.35); }
.btn--outline { background:transparent; color:var(--clr-primary); border-color:var(--clr-primary); }
.btn--outline:hover { background:var(--clr-primary); color:#fff; transform:translateY(-2px); }
.btn--white   { background:#fff; color:var(--clr-primary); border-color:#fff; }
.btn--white:hover { background:transparent; color:#fff; transform:translateY(-2px); }

/* ============================================================
   HEADER
============================================================ */
header {
  position:sticky; top:0; z-index:900;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  height:var(--header-h);
  display:flex; align-items:center;
  border-bottom:1px solid var(--clr-border);
  transition:box-shadow .3s ease;
}
header.scrolled { box-shadow:var(--shadow-md); }

/*
  Nav: drie gelijke zones via 1fr auto 1fr
  - Zone 1 (1fr): logo → justify-self:start, plakt links
  - Zone 2 (auto): links → exact zo breed als nodig, altijd gecentreerd
  - Zone 3 (1fr): cta + burger → justify-self:end, plakt rechts
  Doordat zone 1 en 3 altijd even breed zijn staan de links
  wiskundig perfect in het midden, ongeacht logo- of CTA-breedte.
*/
.nav {
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  width:100%;
}

.nav__logo { justify-self:start; }
.nav__logo img { max-height:46px; width:auto; display:block; }

.nav__links {
  display:flex; align-items:center; gap:2px;
  list-style:none; justify-self:center;
}
.nav__links a {
  text-decoration:none; color:var(--clr-primary);
  font-weight:600; font-size:.9rem;
  padding:8px 16px; border-radius:var(--radius-sm);
  transition:var(--tr); position:relative; white-space:nowrap;
}
.nav__links a:hover { background:var(--clr-soft); color:var(--clr-accent); }
.nav__links a.active { color:var(--clr-accent); background:var(--clr-soft); }
.nav__links a.active::after {
  content:''; position:absolute; bottom:3px; left:16px; right:16px;
  height:2px; border-radius:2px; background:var(--clr-accent);
}

/* CTA + burger in zone 3, beide rechts */
.nav__right {
  justify-self:end;
  display:flex; align-items:center; gap:12px;
}
.nav__cta {
  display:inline-block; background:var(--clr-accent); color:#fff;
  padding:9px 20px; border-radius:var(--radius-sm);
  font-weight:700; font-size:.88rem;
  text-decoration:none; white-space:nowrap; transition:var(--tr);
}
.nav__cta:hover { background:var(--clr-accent-h); transform:translateY(-2px); box-shadow:0 6px 20px rgba(99,102,241,.3); }

.nav__burger {
  display:none; flex-direction:column; justify-content:center;
  gap:5px; background:none; border:none; cursor:pointer;
  padding:6px; border-radius:var(--radius-sm); transition:var(--tr);
}
.nav__burger:hover { background:var(--clr-soft); }
.nav__burger span { display:block; width:24px; height:2px; background:var(--clr-primary); border-radius:2px; transition:var(--tr); }

/* Mobile overlay */
.mobile-overlay {
  position:fixed; inset:0; background:var(--gradient); z-index:950;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
  transform:translateX(100%); transition:transform .42s cubic-bezier(.165,.84,.44,1);
}
.mobile-overlay.active { transform:translateX(0); }
.mobile-overlay__close {
  position:absolute; top:24px; right:24px;
  background:rgba(255,255,255,.15); border:none; color:#fff;
  font-size:1.3rem; width:44px; height:44px; border-radius:50%;
  cursor:pointer; display:flex; align-items:center; justify-content:center; transition:var(--tr);
}
.mobile-overlay__close:hover { background:rgba(255,255,255,.25); }
.mobile-overlay nav ul { text-align:center; }
.mobile-overlay nav ul li { margin-bottom:4px; }
.mobile-overlay nav a {
  display:block; color:#fff; font-size:1.7rem; font-weight:700;
  text-decoration:none; padding:10px 28px; border-radius:var(--radius-md);
  opacity:.9; transition:var(--tr);
}
.mobile-overlay nav a:hover { background:rgba(255,255,255,.1); opacity:1; }

/* ============================================================
   HERO
============================================================ */
.hero {
  min-height:calc(100vh - var(--header-h));
  background:var(--gradient);
  display:flex; align-items:center;
  padding-block:80px; position:relative; overflow:hidden;
}
.hero__grid { display:grid; grid-template-columns:1.1fr .9fr; gap:60px; align-items:center; }
.hero__badge {
  display:inline-block; background:rgba(255,255,255,.15); color:#fff;
  border:1px solid rgba(255,255,255,.2); backdrop-filter:blur(8px);
  padding:8px 22px; border-radius:24px; font-size:.95rem; font-weight:600; margin-bottom:22px;
}
.hero h1 { color:#fff; margin-bottom:20px; }
.hero h1 .typewriter {
  color:var(--clr-accent2); border-right:3px solid var(--clr-accent2);
  padding-right:3px; animation:blink .7s step-end infinite;
}
.hero__sub { color:rgba(255,255,255,.82); font-size:1.05rem; max-width:500px; }
.hero__btns { display:flex; gap:14px; margin-top:32px; flex-wrap:wrap; }
.hero__visual { position:relative; }
.code-card {
  background:rgba(255,255,255,.08); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.14); border-radius:var(--radius-lg);
  padding:28px 30px; animation:float 6s ease-in-out infinite; position:relative; z-index:2;
}
.code-card__dots { display:flex; gap:7px; margin-bottom:16px; }
.code-card__dots span { width:11px; height:11px; border-radius:50%; }
.code-card__dots span:nth-child(1) { background:#ff5f56; }
.code-card__dots span:nth-child(2) { background:#ffbd2e; }
.code-card__dots span:nth-child(3) { background:#27c93f; }
.code-card pre { font-family:'Courier New',monospace; font-size:.86rem; line-height:1.75; color:rgba(255,255,255,.9); white-space:pre-wrap; }
.code-card pre .kw  { color:var(--clr-accent2); }
.code-card pre .str { color:#86efac; }
.code-card pre .fn  { color:#fde68a; }
.hero__blob { position:absolute; top:-60px; right:-60px; width:380px; height:380px; background:rgba(99,102,241,.35); filter:blur(100px); border-radius:50%; z-index:1; pointer-events:none; }

/* ============================================================
   STATS
============================================================ */
.stats { background:var(--clr-white); padding-block:60px; border-bottom:1px solid var(--clr-border); }
.stats__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; text-align:center; }
.stat__num { font-size:2.8rem; font-weight:800; color:var(--clr-primary); line-height:1; }
.stat__num span { color:var(--clr-accent); }
.stat__label { font-size:.88rem; color:var(--clr-muted); margin-top:8px; }

/* ============================================================
   CARDS
============================================================ */
.grid--3 { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.grid--2 { display:grid; grid-template-columns:repeat(2,1fr); gap:32px; }

.card {
  background:var(--clr-white); border:1px solid var(--clr-border);
  border-radius:var(--radius-lg); padding:36px 30px;
  transition:var(--tr); position:relative; overflow:hidden;
}
.card::after { content:''; position:absolute; inset:0; background:var(--gradient); opacity:0; transition:var(--tr); z-index:0; }
.card:hover  { transform:translateY(-8px); border-color:transparent; box-shadow:var(--shadow-lg); }
.card:hover::after { opacity:1; }
.card > * { position:relative; z-index:1; }
.card:hover h3, .card:hover p { color:rgba(255,255,255,.9); }
.card:hover h3 { color:#fff; }
.card__icon { font-size:2.2rem; margin-bottom:16px; display:block; }
.card h3 { margin-bottom:10px; }
.card p  { font-size:.9rem; }

/* ============================================================
   TESTIMONIALS
============================================================ */
.testimonials { background:var(--clr-soft); }
.test-card { background:var(--clr-white); border-radius:var(--radius-lg); padding:32px 28px; box-shadow:var(--shadow-sm); border:1px solid var(--clr-border); }
.test-card__stars { color:#f59e0b; font-size:1rem; letter-spacing:2px; margin-bottom:14px; }
.test-card p { font-style:italic; font-size:.93rem; margin-bottom:22px; }
.test-card__author { display:flex; align-items:center; gap:12px; }
.avatar { width:44px; height:44px; border-radius:50%; background:var(--gradient); display:flex; align-items:center; justify-content:center; color:#fff; font-weight:700; font-size:.95rem; flex-shrink:0; }
.test-card__author strong { display:block; font-size:.88rem; color:var(--clr-primary); }
.test-card__author span  { font-size:.78rem; color:var(--clr-muted); }

/* ============================================================
   CTA BANNER
============================================================ */
.cta-banner { background:var(--gradient); padding-block:90px; text-align:center; }
.cta-banner h2 { color:#fff; margin-bottom:14px; }
.cta-banner p  { color:rgba(255,255,255,.8); font-size:1.05rem; max-width:500px; margin-inline:auto; margin-bottom:34px; }

/* ============================================================
   PAGE HERO (inner pages)
============================================================ */
.page-hero { background:var(--gradient); padding-block:110px 80px; text-align:center; }
.page-hero h1 { color:#fff; margin-bottom:14px; }
.page-hero p  { color:rgba(255,255,255,.8); max-width:520px; margin-inline:auto; font-size:1.05rem; }

/* ============================================================
   ABOUT PAGE
============================================================ */
.about-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:80px; align-items:center; }
.about-visual { background:var(--gradient); border-radius:var(--radius-lg); padding:56px 40px; text-align:center; color:#fff; position:relative; }
.about-visual__emoji { font-size:4.5rem; margin-bottom:16px; }
.about-visual h3 { font-size:1.5rem; color:#fff; }
.about-visual p  { color:rgba(255,255,255,.75); margin-top:6px; }
.about-badge { position:absolute; bottom:-20px; right:-20px; background:#fff; border-radius:var(--radius-md); padding:14px 20px; box-shadow:var(--shadow-md); text-align:center; min-width:110px; }
.about-badge strong { display:block; font-size:1.7rem; font-weight:800; color:var(--clr-accent); }
.about-badge span   { font-size:.75rem; color:var(--clr-muted); }
.about-text .tag { display:block; width:fit-content; }
.about-text h2 { margin-bottom:18px; }
.about-text p  { margin-bottom:16px; }
.values { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:28px; }
.value-item { background:var(--clr-soft); border-radius:var(--radius-md); padding:18px 16px; display:flex; gap:12px; align-items:flex-start; }
.value-item__icon { font-size:1.3rem; line-height:1; }
.value-item h4 { font-size:.88rem; font-weight:700; color:var(--clr-primary); margin-bottom:3px; }
.value-item p  { font-size:.8rem; margin:0; }

/* ============================================================
   DIENSTEN PAGE
============================================================ */
.diensten-intro { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; margin-bottom:80px; }
.diensten-intro p    { font-size:1.05rem; }
.diensten-intro .btn { margin-top:20px; }
.process { background:var(--clr-soft); }
.process-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.process-step { background:var(--clr-white); border-radius:var(--radius-lg); padding:32px 26px; text-align:center; border:1px solid var(--clr-border); }
.process-step__num { width:48px; height:48px; background:var(--gradient); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:1.1rem; margin:0 auto 18px; }
.process-step h3 { font-size:1rem; margin-bottom:8px; }
.process-step p  { font-size:.88rem; }

/* ============================================================
   CONTACT & START PAGES
============================================================ */
.contact-split { display:grid; grid-template-columns:1fr 1.2fr; gap:56px; align-items:start; }
.map-wrap { border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:1/1; border:1px solid var(--clr-border); box-shadow:var(--shadow-sm); }
.map-wrap iframe { width:100%; height:100%; border:0; display:block; }
.contact-info { margin-bottom:36px; }
.contact-info h3 { margin-bottom:22px; }
.info-item { display:flex; gap:14px; align-items:flex-start; margin-bottom:20px; }
.info-icon { width:44px; height:44px; background:var(--clr-soft); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.info-item h4  { font-size:.88rem; font-weight:700; color:var(--clr-primary); margin-bottom:2px; }
.info-item p, .info-item a { font-size:.85rem; color:var(--clr-muted); text-decoration:none; }
.info-item a:hover { color:var(--clr-accent); }

.start-intro { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.start-checklist { list-style:none; margin-top:20px; display:flex; flex-direction:column; gap:12px; }
.start-checklist li { display:flex; gap:12px; align-items:flex-start; font-size:.95rem; color:var(--clr-text); }
.start-checklist li::before { content:'✓'; color:var(--clr-accent); font-weight:800; font-size:1rem; flex-shrink:0; margin-top:1px; }

/* ============================================================
   FORMULIER
============================================================ */
.contact-form-wrap { background:var(--clr-white); border:1px solid var(--clr-border); border-radius:var(--radius-lg); padding:42px 38px; box-shadow:var(--shadow-md); }
.contact-form-wrap h3 { margin-bottom:28px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-size:.83rem; font-weight:600; color:var(--clr-primary); margin-bottom:7px; }
.form-group input,
.form-group textarea,
.form-group select {
  width:100%; padding:13px 16px; border:1.5px solid var(--clr-border);
  border-radius:var(--radius-sm); font-family:'Poppins',sans-serif;
  font-size:.9rem; color:var(--clr-text); background:var(--clr-light);
  transition:var(--tr); appearance:none;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  outline:none; border-color:var(--clr-accent);
  background:var(--clr-white); box-shadow:0 0 0 4px rgba(99,102,241,.1);
}
.form-group textarea { resize:vertical; min-height:130px; }
.form-submit {
  width:100%; padding:15px; font-size:1rem; border-radius:var(--radius-sm);
  background:var(--clr-accent); color:#fff; font-family:'Poppins',sans-serif;
  font-weight:700; border:none; cursor:pointer; transition:var(--tr);
}
.form-submit:hover { background:var(--clr-accent-h); transform:translateY(-2px); box-shadow:0 8px 24px rgba(99,102,241,.35); }
.form-submit:disabled { opacity:.6; cursor:not-allowed; transform:none; }

/* ============================================================
   FOOTER
============================================================ */
.footer { background:var(--clr-primary); color:rgba(255,255,255,.85); padding-top:72px; }
.footer__grid {
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1.4fr;
  gap:40px; padding-bottom:56px; border-bottom:1px solid rgba(255,255,255,.08);
}
.footer__logo { max-height:54px; width:auto; margin-bottom:16px; }
.footer__brand p { font-size:.88rem; color:#94a3b8; line-height:1.75; max-width:230px; }
.footer__col h4 { color:var(--clr-accent2); font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; margin-bottom:18px; }
.footer__col ul li { margin-bottom:10px; }
.footer__col ul a { color:#94a3b8; text-decoration:none; font-size:.87rem; transition:color .25s; }
.footer__col ul a:hover { color:#fff; }
.footer__col ul li span { color:#94a3b8; font-size:.87rem; }
.footer__hours li { display:flex; justify-content:space-between; gap:16px; font-size:.83rem; color:#94a3b8; padding-block:4px; border-bottom:1px solid rgba(255,255,255,.05); }
.footer__hours li:last-child { border-bottom:none; }
.footer__hours .closed { color:#f87171; }
.footer__bottom { padding-block:22px; text-align:center; }
.footer__bottom p { font-size:.8rem; color:#475569; }

/* ============================================================
   ANIMATIES
============================================================ */
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-16px)} }
@keyframes blink  { 0%,100%{border-color:var(--clr-accent2)} 50%{border-color:transparent} }

.reveal { opacity:0; transform:translateY(26px); transition:opacity .7s ease,transform .7s ease; }
.reveal.active { opacity:1; transform:translateY(0); }
.reveal--delay-1 { transition-delay:.1s; }
.reveal--delay-2 { transition-delay:.2s; }
.reveal--delay-3 { transition-delay:.3s; }

/* ============================================================
   RESPONSIVE — tablet
============================================================ */
@media (max-width:1024px) {
  .grid--3       { grid-template-columns:repeat(2,1fr); }
  .process-steps { grid-template-columns:repeat(2,1fr); }
  .footer__grid  { grid-template-columns:1fr 1fr; }
  .about-grid    { gap:50px; }
}

/* ============================================================
   RESPONSIVE — mobiel
============================================================ */
@media (max-width:768px) {
  /* Header: verberg links en CTA, toon burger */
  .nav__links       { display:none; }
  .nav__cta         { display:none; }
  .nav__burger      { display:flex; }
  /* Op mobiel: logo links, burger rechts — twee zones */
  .nav              { grid-template-columns:auto auto; }
  .nav__right       { justify-self:end; }

  .hero__grid,
  .about-grid,
  .diensten-intro,
  .contact-split,
  .start-intro      { grid-template-columns:1fr; gap:36px; }

  .hero__visual     { order:-1; }
  .grid--3, .grid--2 { grid-template-columns:1fr; }
  .stats__grid      { grid-template-columns:repeat(2,1fr); }
  .values           { grid-template-columns:1fr; }
  .form-row         { grid-template-columns:1fr; }
  .process-steps    { grid-template-columns:1fr; }

  /* About badge: onder de kaart, niet over tekst */
  .about-visual     { padding-bottom:36px; }
  .about-badge      { position:static; display:inline-flex; gap:10px; align-items:center; margin-top:16px; border-radius:var(--radius-md); }
  .about-badge strong { font-size:1.3rem; }

  .contact-form-wrap { padding:28px 22px; }
  .map-wrap          { aspect-ratio:4/3; }
}

@media (max-width:480px) {
  .stats__grid  { grid-template-columns:1fr 1fr; }
  .footer__grid { grid-template-columns:1fr; }
  .hero__btns   { flex-direction:column; }
  .cta-banner .btn { width:100%; text-align:center; }
}