  :root{
    --navy-900:#0B1438;
    --navy-800:#0E1F6B;
    --navy-700:#1A2D8F;
    --navy-500:#3A4FB5;
    --sky-500:#2EA3DD;
    --sky-400:#52B6E6;
    --sky-200:#BFE3F5;
    --bg:#F6F8FC;
    --bg-2:#EEF2F8;
    --surface:#FFFFFF;
    --ink:#0B1438;
    --ink-2:#1C254E;
    --muted:#5B6584;
    --muted-2:#8892AE;
    --line:#E4EAF3;
    --line-2:#D6DEEB;
    --green:#19A974;
    --radius:16px;
    --radius-sm:10px;
    --shadow-sm:0 1px 2px rgba(11,20,56,.04), 0 2px 6px rgba(11,20,56,.04);
    --shadow-md:0 6px 24px -8px rgba(11,20,56,.12), 0 2px 6px rgba(11,20,56,.04);
    --shadow-lg:0 24px 60px -20px rgba(11,20,56,.22), 0 6px 16px rgba(11,20,56,.06);
    --max:1200px;
  }
  *,*::before,*::after{ box-sizing:border-box; }
  html{
    scroll-behavior:smooth;
    -webkit-text-size-adjust:100%;
  }
  html, body{ overflow-x:clip; }
  body{
    margin:0;
    font-family:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
    color:var(--ink);
    background:var(--bg);
    font-size:16px;
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
  }
  body.menu-open{ overflow:hidden; }
  ::selection{ background:var(--navy-800); color:#fff; }
  a{ color:inherit; text-decoration:none; }
  button{ font-family:inherit; cursor:pointer; }
  img{ display:block; max-width:100%; }
  .mono{ font-family:"JetBrains Mono", ui-monospace, monospace; }

  .container{ width:100%; max-width:var(--max); margin:0 auto; padding:0 28px; }

  /* ============ NAV ============ */
  .nav-wrap{
    position:sticky; top:0; z-index:50;
    background:rgba(246,248,252,.72);
    backdrop-filter:saturate(140%) blur(14px);
    -webkit-backdrop-filter:saturate(140%) blur(14px);
    border-bottom:1px solid transparent;
    transition:border-color .25s ease, background .25s ease, box-shadow .25s ease;
  }
  .nav-wrap.scrolled{
    background:rgba(255,255,255,.85);
    border-bottom-color:var(--line);
    box-shadow:0 4px 20px -12px rgba(11,20,56,.12);
  }
  .nav{
    display:flex; align-items:center; justify-content:space-between;
    padding:18px 0; gap:24px;
  }
  .brand{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
  .brand img{ height:34px; width:auto; }
  .nav-links{ display:flex; align-items:center; gap:6px; }
  .nav-links a{
    font-size:14px; font-weight:500; color:var(--ink-2);
    padding:8px 12px; border-radius:8px;
    transition:color .2s ease, background .2s ease;
  }
  .nav-links a:hover{ color:var(--navy-800); background:rgba(14,31,107,.05); }
  .nav-links .track{
    display:inline-flex; align-items:center; gap:6px;
  }
  .nav-links .track::before{
    content:""; width:6px; height:6px; border-radius:50%;
  }
  .nav-links .track-ict::before{ background:var(--sky-500); }
  .nav-links .track-sec::before{ background:var(--navy-800); }
  .nav-cta{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
  .phone-pill{
    display:inline-flex; align-items:center; gap:8px;
    font-size:13.5px; font-weight:500; color:var(--ink-2);
    padding:8px 14px; border-radius:999px;
    border:1px solid var(--line);
    background:#fff;
    transition:border-color .2s ease;
  }
  .phone-pill:hover{ border-color:var(--sky-400); }
  .phone-pill svg{ width:13px; height:13px; color:var(--sky-500); }

  .btn{
    display:inline-flex; align-items:center; gap:10px;
    font-family:inherit; font-weight:600; font-size:14.5px;
    padding:11px 20px; border-radius:999px;
    border:1px solid transparent;
    cursor:pointer; transition:all .2s ease;
    line-height:1;
  }
  .btn-primary{
    background:var(--navy-800); color:#fff;
    box-shadow:0 6px 16px -6px rgba(14,31,107,.5);
  }
  .btn-primary:hover{ background:var(--navy-900); transform:translateY(-1px); box-shadow:0 10px 24px -8px rgba(14,31,107,.55); }
  .btn-ghost{
    background:transparent; color:var(--ink-2); border-color:var(--line-2);
  }
  .btn-ghost:hover{ border-color:var(--navy-800); color:var(--navy-800); }
  .btn-on-dark{
    background:#fff; color:var(--navy-900);
  }
  .btn-on-dark:hover{ background:var(--sky-200); }
  .btn-ghost-dark{
    background:transparent; color:#fff; border-color:rgba(255,255,255,.22);
  }
  .btn-ghost-dark:hover{ border-color:var(--sky-400); color:var(--sky-400); }
  .btn-lg{ padding:14px 26px; font-size:15px; }
  .btn .arrow{ width:14px; height:14px; transition:transform .2s ease; }
  .btn:hover .arrow{ transform:translateX(3px); }

  .menu-btn{
    display:none;
    background:transparent; border:0;
    width:44px; height:44px;
    align-items:center; justify-content:center;
    border-radius:10px;
    color:var(--ink-2);
    transition:background .2s ease;
  }
  .menu-btn:hover{ background:rgba(14,31,107,.05); }
  .menu-btn svg{ width:22px; height:22px; }

  /* ============ MOBILE MENU DRAWER ============ */
  .mobile-menu{
    position:fixed; inset:0;
    z-index:60;
    background:rgba(11,20,56,.5);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    opacity:0; pointer-events:none;
    transition:opacity .25s ease;
  }
  .mobile-menu.open{ opacity:1; pointer-events:auto; }
  .mobile-menu-panel{
    position:absolute; top:0; right:0; bottom:0;
    width:min(360px, 88vw);
    background:#fff;
    display:flex; flex-direction:column;
    transform:translateX(100%);
    transition:transform .3s cubic-bezier(.2,.7,.2,1);
    box-shadow:-10px 0 40px rgba(11,20,56,.15);
  }
  .mobile-menu.open .mobile-menu-panel{ transform:translateX(0); }
  .mobile-menu-head{
    display:flex; align-items:center; justify-content:space-between;
    padding:18px 20px;
    border-bottom:1px solid var(--line);
  }
  .mobile-menu-head img{ height:30px; width:auto; }
  .mobile-menu-close{
    width:44px; height:44px;
    background:transparent; border:0; border-radius:10px;
    display:flex; align-items:center; justify-content:center;
    color:var(--ink-2);
  }
  .mobile-menu-close:hover{ background:var(--bg-2); }
  .mobile-menu-close svg{ width:22px; height:22px; }
  .mobile-menu-links{
    flex:1; padding:14px 12px 24px;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .mobile-menu-links a{
    display:flex; align-items:center; gap:12px;
    padding:14px 16px;
    min-height:52px;
    font-size:16px; font-weight:500;
    color:var(--ink-2);
    border-radius:10px;
    transition:background .2s ease;
  }
  .mobile-menu-links a:hover{ background:var(--bg-2); }
  .mobile-menu-links a .dot{
    width:8px; height:8px; border-radius:50%; flex-shrink:0;
  }
  .mobile-menu-links a.track-ict .dot{ background:var(--sky-500); }
  .mobile-menu-links a.track-sec .dot{ background:var(--navy-800); }
  .mobile-menu-foot{
    padding:18px 20px 24px;
    border-top:1px solid var(--line);
    display:flex; flex-direction:column; gap:10px;
  }
  .mobile-menu-foot .btn{ width:100%; justify-content:center; min-height:48px; }
  .mobile-menu-foot .phone-pill{ width:100%; justify-content:center; min-height:48px; }

  /* ============ HERO ============ */
  .hero{
    position:relative;
    padding:80px 0 60px;
    overflow:hidden;
  }
  .hero-inner{ text-align:center; max-width:880px; margin:0 auto; }
  .eyebrow{
    display:inline-flex; align-items:center; gap:10px;
    font-size:12.5px; font-weight:500; letter-spacing:.04em;
    color:var(--navy-800);
    padding:7px 14px;
    background:#fff; border:1px solid var(--line);
    border-radius:999px;
    box-shadow:var(--shadow-sm);
  }
  .eyebrow .dot{
    width:7px; height:7px; border-radius:50%;
    background:var(--green); box-shadow:0 0 0 4px rgba(25,169,116,.18);
    animation:pulse 2.4s ease-in-out infinite;
  }
  @keyframes pulse{
    0%,100%{ box-shadow:0 0 0 0 rgba(25,169,116,.35); }
    50%{ box-shadow:0 0 0 6px rgba(25,169,116,0); }
  }
  h1.hero-title{
    font-size:clamp(40px, 5.8vw, 76px);
    line-height:1.0;
    letter-spacing:-.024em;
    font-weight:700;
    margin:24px 0 22px;
    color:var(--navy-900);
    text-wrap:balance;
  }
  .hero-title em{
    font-style:normal;
    background:linear-gradient(95deg, var(--navy-800) 10%, var(--sky-500) 90%);
    -webkit-background-clip:text; background-clip:text; color:transparent;
  }
  .hero-sub{
    font-size:19px; line-height:1.55; color:var(--muted);
    max-width:620px; margin:0 auto 36px;
    text-wrap:pretty;
  }
  .hero-cta{ display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; }
  .hero-meta{
    display:flex; gap:28px; justify-content:center; margin-top:36px; flex-wrap:wrap;
  }
  .hero-meta .item{ display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--ink-2); }
  .hero-meta .item svg{ width:15px; height:15px; color:var(--sky-500); flex-shrink:0; }

  /* ============ TRACK PICKER ============ */
  .picker{
    padding:50px 0 90px;
  }
  .picker-grid{
    display:grid; grid-template-columns:1fr 1fr; gap:22px;
  }
  .track-card{
    position:relative;
    border-radius:24px;
    padding:40px;
    overflow:hidden;
    display:flex; flex-direction:column;
    min-height:340px;
    transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s ease;
    cursor:pointer;
    border:1px solid var(--line);
    background:#fff;
  }
  .track-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); }
  .track-card.ict::before{
    content:""; position:absolute; right:-20%; top:-30%;
    width:70%; height:80%;
    background:radial-gradient(circle, rgba(46,163,221,.18), transparent 65%);
  }
  .track-card.sec{
    background:linear-gradient(165deg, var(--navy-900) 0%, var(--navy-800) 100%);
    color:#fff; border-color:transparent;
  }
  .track-card.sec::before{
    content:""; position:absolute; right:-20%; top:-30%;
    width:70%; height:80%;
    background:radial-gradient(circle, rgba(46,163,221,.32), transparent 65%);
  }
  .track-num{
    position:absolute; top:24px; right:28px;
    font-family:"JetBrains Mono", monospace;
    font-size:11px; letter-spacing:.12em;
    color:var(--muted-2);
  }
  .track-card.sec .track-num{ color:rgba(255,255,255,.45); }
  .track-tag{
    display:inline-flex; align-items:center; gap:8px;
    font-family:"JetBrains Mono", monospace;
    font-size:11.5px; letter-spacing:.1em; text-transform:uppercase;
    padding:6px 10px; border-radius:999px;
    border:1px solid var(--line);
    background:#fff;
    align-self:flex-start;
    color:var(--navy-800);
    position:relative;
  }
  .track-card.sec .track-tag{
    border-color:rgba(255,255,255,.18);
    background:rgba(255,255,255,.04);
    color:var(--sky-400);
  }
  .track-tag .dot{
    width:6px; height:6px; border-radius:50%;
    background:var(--sky-500);
  }
  .track-card.sec .track-tag .dot{ background:var(--sky-400); }
  .track-card h3{
    font-size:34px; font-weight:700; letter-spacing:-.018em;
    margin:18px 0 12px;
    line-height:1.05;
    position:relative; max-width:11ch;
    color:var(--navy-900);
  }
  .track-card.sec h3{ color:#fff; }
  .track-card .desc{
    font-size:15.5px; color:var(--muted); margin:0 0 24px;
    max-width:32ch; position:relative;
  }
  .track-card.sec .desc{ color:rgba(255,255,255,.7); }
  .track-list{
    display:flex; gap:8px; flex-wrap:wrap; margin-bottom:24px; position:relative;
  }
  .track-list .chip{
    font-size:12.5px; font-weight:500;
    padding:5px 10px; border-radius:999px;
    background:var(--bg-2); color:var(--ink-2);
  }
  .track-card.sec .track-list .chip{
    background:rgba(255,255,255,.08); color:rgba(255,255,255,.85);
  }
  .track-foot{
    display:flex; align-items:center; justify-content:space-between;
    margin-top:auto;
    padding-top:20px;
    border-top:1px solid var(--line);
    position:relative;
  }
  .track-card.sec .track-foot{ border-top-color:rgba(255,255,255,.1); }
  .audience{
    font-size:12px; color:var(--muted-2); letter-spacing:.04em;
  }
  .track-card.sec .audience{ color:rgba(255,255,255,.5); }
  .audience strong{
    display:block; color:var(--ink-2); font-size:13px;
    font-weight:600; letter-spacing:0; margin-bottom:2px;
  }
  .track-card.sec .audience strong{ color:#fff; }
  .track-cta{
    display:inline-flex; align-items:center; gap:8px;
    font-size:14.5px; font-weight:600;
    color:var(--navy-800);
  }
  .track-card.sec .track-cta{ color:var(--sky-400); }
  .track-cta svg{ width:14px; height:14px; transition:transform .2s ease; }
  .track-card:hover .track-cta svg{ transform:translateX(4px); }

  /* ============ SECTION SHELL ============ */
  section{ padding:110px 0; }
  .section-head{
    max-width:680px; margin:0 auto 56px;
    text-align:center;
  }
  .section-head.left{ text-align:left; margin-left:0; }
  .section-head .kicker{
    display:inline-flex; align-items:center; gap:8px;
    font-family:"JetBrains Mono", monospace;
    font-size:12px; letter-spacing:.12em; text-transform:uppercase;
    margin-bottom:14px;
  }
  .section-head .kicker .bar{
    display:inline-block; width:24px; height:1px;
  }
  .kicker-ict{ color:var(--sky-500); }
  .kicker-ict .bar{ background:var(--sky-500); }
  .kicker-sec{ color:var(--sky-400); }
  .kicker-sec .bar{ background:var(--sky-400); }
  .kicker-neutral{ color:var(--navy-800); }
  .kicker-neutral .bar{ background:var(--navy-800); }
  .section-head h2{
    font-size:clamp(30px, 3.8vw, 50px);
    font-weight:700; letter-spacing:-.022em;
    margin:0 0 16px; line-height:1.06;
    color:var(--navy-900);
    text-wrap:balance;
  }
  .section-head h2.on-dark{ color:#fff; }
  .section-head p{
    color:var(--muted); font-size:17px; margin:0 auto;
    max-width:560px;
    text-wrap:pretty;
  }
  .section-head.left p{ margin:0; max-width:520px; }
  .section-head p.on-dark{ color:rgba(255,255,255,.7); }

  .audience-strip{
    display:inline-flex; align-items:center; gap:14px;
    margin-top:22px;
    padding:8px 16px;
    border-radius:999px;
    border:1px solid var(--line);
    background:#fff;
    font-size:13px;
    color:var(--ink-2);
  }
  .audience-strip.on-dark{
    border-color:rgba(255,255,255,.16);
    background:rgba(255,255,255,.04);
    color:rgba(255,255,255,.85);
  }
  .audience-strip .lbl{
    font-family:"JetBrains Mono", monospace;
    font-size:11px; color:var(--muted-2); letter-spacing:.1em; text-transform:uppercase;
  }
  .audience-strip.on-dark .lbl{ color:rgba(255,255,255,.5); }

  /* ============ ICT SERVICES ============ */
  .ict-wrap{
    background:var(--bg);
    position:relative;
  }
  .ict-wrap::before{
    content:""; position:absolute; left:0; right:0; top:0; height:1px;
    background:linear-gradient(90deg, transparent, var(--line) 30%, var(--line) 70%, transparent);
  }
  .services-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:18px;
  }
  .svc{
    position:relative;
    background:#fff; border:1px solid var(--line);
    border-radius:var(--radius);
    padding:26px;
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    overflow:hidden;
  }
  .svc::before{
    content:""; position:absolute; left:0; top:0; bottom:0;
    width:3px; background:var(--sky-500);
    transform:scaleY(0); transform-origin:top;
    transition:transform .3s ease;
  }
  .svc:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow-lg);
    border-color:transparent;
  }
  .svc:hover::before{ transform:scaleY(1); }
  .svc-icon{
    width:44px; height:44px; border-radius:11px;
    background:linear-gradient(180deg,#F4F8FC,#E9F2F9);
    border:1px solid var(--line);
    display:grid; place-items:center;
    color:var(--navy-800);
    margin-bottom:20px;
  }
  .svc-icon svg{ width:20px; height:20px; }
  .svc-title{
    font-size:17px; font-weight:600; letter-spacing:-.01em;
    margin:0 0 6px;
  }
  .svc-desc{
    font-size:14px; line-height:1.55; color:var(--muted); margin:0;
  }
  .svc-meta{
    margin-top:14px; padding-top:14px;
    border-top:1px dashed var(--line);
    font-family:"JetBrains Mono", monospace;
    font-size:11px; color:var(--muted-2);
    letter-spacing:.04em;
  }

  /* ============ CYBERSECURITY ============ */
  .sec-wrap{
    background:linear-gradient(180deg, var(--navy-900) 0%, #07102D 100%);
    color:#fff;
    position:relative;
    overflow:hidden;
  }
  .sec-wrap::before{
    content:""; position:absolute; inset:0;
    background:
      radial-gradient(60% 50% at 80% 10%, rgba(46,163,221,.16), transparent 60%),
      radial-gradient(50% 40% at 10% 90%, rgba(46,163,221,.10), transparent 60%);
    pointer-events:none;
  }
  .sec-wrap::after{
    content:""; position:absolute; inset:0;
    background-image:
      linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
    background-size:64px 64px;
    background-position:center;
    mask-image:radial-gradient(ellipse at center, #000 0%, transparent 70%);
    -webkit-mask-image:radial-gradient(ellipse at center, #000 0%, transparent 70%);
    pointer-events:none;
  }
  .sec-wrap > .container{ position:relative; }

  .sec-grid{
    display:grid;
    grid-template-columns:1.05fr 1fr;
    gap:60px;
    margin-top:60px;
    align-items:start;
  }
  .sec-services{
    display:grid; gap:12px;
  }
  .sec-svc{
    display:grid;
    grid-template-columns:48px 1fr;
    align-items:center;
    gap:18px;
    padding:22px;
    background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.08);
    border-radius:14px;
    transition:background .25s ease, border-color .25s ease, transform .2s ease;
  }
  .sec-svc:hover{
    background:rgba(255,255,255,.06);
    border-color:rgba(46,163,221,.4);
    transform:translateX(4px);
  }
  .sec-svc .ic{
    width:44px; height:44px; border-radius:11px;
    background:rgba(46,163,221,.1);
    border:1px solid rgba(46,163,221,.25);
    display:grid; place-items:center;
    color:var(--sky-400);
  }
  .sec-svc .ic svg{ width:20px; height:20px; }
  .sec-svc h4{
    margin:0 0 4px; font-size:16px; font-weight:600; color:#fff;
    letter-spacing:-.005em;
  }
  .sec-svc p{
    margin:0; font-size:13.5px; color:rgba(255,255,255,.6); line-height:1.5;
  }
  .sec-svc .arrow{ display:none; }

  .sec-sidecard{
    position:sticky; top:100px;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.1);
    border-radius:18px;
    padding:32px;
  }
  .sec-sidecard h4{
    font-size:18px; font-weight:600; margin:0 0 8px;
    color:#fff;
  }
  .sec-sidecard p{
    font-size:14.5px; color:rgba(255,255,255,.7);
    margin:0 0 24px; line-height:1.55;
  }
  .frameworks{
    display:grid; grid-template-columns:1fr 1fr; gap:8px;
    margin-bottom:24px;
  }
  .fw{
    padding:14px;
    border:1px solid rgba(255,255,255,.1);
    border-radius:10px;
    background:rgba(255,255,255,.02);
    transition:border-color .2s ease;
  }
  .fw:hover{ border-color:var(--sky-400); }
  .fw .name{
    font-family:"JetBrains Mono", monospace;
    font-size:13px; font-weight:500; color:var(--sky-400);
    margin-bottom:4px;
  }
  .fw .for{
    font-size:11.5px; color:rgba(255,255,255,.55); line-height:1.4;
  }
  .sectors{
    display:flex; flex-wrap:wrap; gap:6px;
  }
  .sector{
    font-size:11.5px; padding:5px 9px;
    border:1px solid rgba(255,255,255,.14);
    border-radius:999px; color:rgba(255,255,255,.8);
    background:rgba(255,255,255,.02);
  }

  /* ============ PRAKTIJK GALLERY ============ */
  .praktijk{
    background:var(--bg);
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
  }
  .praktijk-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:18px;
  }
  .pk{
    position:relative;
    border-radius:var(--radius);
    overflow:hidden;
    aspect-ratio:4/5;
    background:var(--navy-800);
    isolation:isolate;
    box-shadow:var(--shadow-md);
  }
  .pk img{
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover;
    transition:transform .6s cubic-bezier(.2,.7,.2,1);
    z-index:0;
  }
  .pk:hover img{ transform:scale(1.04); }
  .pk::after{
    content:""; position:absolute; inset:0;
    background:linear-gradient(180deg, rgba(11,20,56,0) 30%, rgba(11,20,56,.78) 100%);
    z-index:1;
  }
  .pk-body{
    position:absolute; left:0; right:0; bottom:0;
    padding:24px;
    color:#fff;
    z-index:2;
  }
  .pk-tag{
    display:inline-flex; align-items:center; gap:8px;
    font-family:"JetBrains Mono", monospace;
    font-size:11px; letter-spacing:.1em; text-transform:uppercase;
    padding:5px 10px; border-radius:999px;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.22);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    margin-bottom:10px;
  }
  .pk-tag .dot{ width:6px; height:6px; border-radius:50%; }
  .pk-tag.ict .dot{ background:var(--sky-400); }
  .pk-tag.sec .dot{ background:#22D78A; }
  .pk-tag.both .dot{ background:#fff; }
  .pk-title{
    font-size:20px; font-weight:600; letter-spacing:-.01em;
    margin:0 0 4px; line-height:1.2;
  }
  .pk-sub{
    font-size:13.5px; margin:0;
    color:rgba(255,255,255,.78);
    line-height:1.5;
  }

  /* ============ CASES ============ */
  .cases-wrap{
    background:#fff;
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
  }
  .cases-head{
    display:flex; align-items:flex-end; justify-content:space-between;
    gap:32px; margin-bottom:48px;
  }
  .cases-head .section-head{ margin:0; text-align:left; max-width:560px; }
  .cases-head .section-head p{ margin:0; }
  .cases-head .head-cta{ flex-shrink:0; padding-bottom:6px; }
  .cases-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:20px;
  }
  .case-card{
    position:relative;
    background:#fff;
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:28px;
    display:flex; flex-direction:column;
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    overflow:hidden;
    text-decoration:none;
    color:inherit;
  }
  .case-card::before{
    content:""; position:absolute; left:0; top:0; bottom:0;
    width:3px;
    transform:scaleY(0); transform-origin:top;
    transition:transform .3s ease;
  }
  .case-card.ict::before{ background:var(--sky-500); }
  .case-card.sec::before{ background:var(--navy-800); }
  .case-card:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow-lg);
    border-color:transparent;
  }
  .case-card:hover::before{ transform:scaleY(1); }
  .case-meta-top{
    display:flex; align-items:center; justify-content:space-between;
    gap:12px; margin-bottom:20px;
  }
  .case-tag{
    display:inline-flex; align-items:center; gap:8px;
    font-family:"JetBrains Mono", monospace;
    font-size:11px; letter-spacing:.1em; text-transform:uppercase;
    padding:5px 10px; border-radius:999px;
    border:1px solid var(--line);
    background:var(--bg);
    color:var(--navy-800);
  }
  .case-tag .dot{ width:6px; height:6px; border-radius:50%; }
  .case-card.ict .case-tag .dot{ background:var(--sky-500); }
  .case-card.sec .case-tag .dot{ background:var(--navy-800); }
  .case-num{
    font-family:"JetBrains Mono", monospace;
    font-size:11px; color:var(--muted-2); letter-spacing:.12em;
  }
  .case-card h3{
    font-size:20px; font-weight:600; letter-spacing:-.012em;
    margin:0 0 10px; line-height:1.2;
    color:var(--navy-900);
  }
  .case-card .case-sit{
    font-size:14px; color:var(--muted); margin:0 0 18px;
    line-height:1.55;
  }
  .case-result{
    margin-top:auto;
    padding-top:18px;
    border-top:1px dashed var(--line);
    display:flex; align-items:flex-start; gap:10px;
    font-size:13.5px; color:var(--ink-2);
    line-height:1.45;
  }
  .case-result svg{
    width:16px; height:16px; flex-shrink:0;
    color:var(--green); margin-top:1px;
  }
  .case-result strong{ color:var(--navy-900); font-weight:600; }
  .case-card .case-cta{
    margin-top:16px;
    font-size:13px; font-weight:600;
    color:var(--navy-800);
    display:inline-flex; align-items:center; gap:6px;
  }
  .case-card .case-cta svg{ width:12px; height:12px; transition:transform .2s ease; }
  .case-card:hover .case-cta svg{ transform:translateX(4px); }
  @media (max-width:1024px){
    .cases-grid{ grid-template-columns:1fr 1fr; }
    .cases-grid .case-card:last-child{ grid-column:1 / -1; }
  }
  @media (max-width:760px){
    .cases-head{ flex-direction:column; align-items:flex-start; gap:20px; margin-bottom:36px; }
    .cases-grid{ grid-template-columns:1fr; gap:14px; }
    .cases-grid .case-card:last-child{ grid-column:auto; }
  }

  /* ============ WHY ============ */
  .why-wrap{
    background:#fff;
    border-top:1px solid var(--line);
  }
  .why-grid{
    display:grid;
    grid-template-columns:1.1fr 1fr;
    gap:80px;
    align-items:center;
  }
  .why-list{ display:grid; gap:8px; margin-top:32px; }
  .why-item{
    display:flex; align-items:flex-start; gap:18px;
    padding:20px 22px;
    border:1px solid var(--line);
    border-radius:14px;
    background:#fff;
    transition:border-color .2s ease, transform .2s ease;
  }
  .why-item:hover{ border-color:var(--sky-400); transform:translateX(4px); }
  .why-item .num{
    font-family:"JetBrains Mono", monospace;
    font-size:11.5px; color:var(--muted-2);
    padding-top:3px;
  }
  .why-item .body h4{
    margin:0 0 4px; font-size:16px; font-weight:600;
  }
  .why-item .body p{
    margin:0; font-size:14px; color:var(--muted); line-height:1.5;
  }
  .why-side{
    background:linear-gradient(160deg, var(--navy-900), var(--navy-800));
    border-radius:20px;
    padding:42px;
    color:#fff;
    position:relative;
    overflow:hidden;
    min-height:460px;
    display:flex; flex-direction:column; justify-content:space-between;
  }
  .why-side::before{
    content:""; position:absolute; right:-30%; top:-30%;
    width:80%; height:80%;
    background:radial-gradient(circle, rgba(46,163,221,.25), transparent 65%);
    pointer-events:none;
  }
  .why-side .why-side-kicker{
    font-family:"JetBrains Mono", monospace;
    font-size:11.5px; letter-spacing:.12em; text-transform:uppercase;
    color:var(--sky-400);
    margin-bottom:18px;
  }
  .why-side h3{
    font-size:30px; font-weight:600; line-height:1.15; margin:0 0 14px;
    letter-spacing:-.015em; text-wrap:balance;
  }
  .why-side p{ color:rgba(255,255,255,.7); font-size:15px; margin:0 0 32px; max-width:36ch; }
  .why-stats{
    display:grid; grid-template-columns:1fr 1fr; gap:24px;
    border-top:1px solid rgba(255,255,255,.1); padding-top:28px;
    position:relative;
  }
  .why-stats .stat .n{
    font-size:34px; font-weight:700; color:#fff;
    letter-spacing:-.02em; line-height:1;
  }
  .why-stats .stat .n .acc{ color:var(--sky-400); }
  .why-stats .stat .lbl{
    font-size:12.5px; color:rgba(255,255,255,.6); margin-top:6px;
  }

  /* ============ TESTIMONIALS ============ */
  .testimonials{
    background:var(--bg);
    border-top:1px solid var(--line);
  }
  .quotes-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:18px;
  }
  .quote{
    position:relative;
    background:#fff;
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:28px 26px 24px;
    display:flex; flex-direction:column;
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    overflow:hidden;
  }
  .quote::before{
    content:"“";
    position:absolute; top:-18px; right:20px;
    font-family:Georgia, "Times New Roman", serif;
    font-size:120px; line-height:1;
    color:var(--bg-2);
    pointer-events:none;
    z-index:0;
  }
  .quote::after{
    content:""; position:absolute; left:0; top:0; bottom:0;
    width:3px;
    transform:scaleY(0); transform-origin:top;
    transition:transform .3s ease;
  }
  .quote.ict::after{ background:var(--sky-500); }
  .quote.sec::after{ background:var(--navy-800); }
  .quote:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow-lg);
    border-color:transparent;
  }
  .quote:hover::after{ transform:scaleY(1); }
  .quote-tag{
    display:inline-flex; align-items:center; gap:8px;
    font-family:"JetBrains Mono", monospace;
    font-size:11px; letter-spacing:.1em; text-transform:uppercase;
    color:var(--navy-800);
    margin-bottom:18px;
    position:relative; z-index:1;
  }
  .quote.sec .quote-tag{ color:var(--navy-800); }
  .quote-tag .dot{
    width:7px; height:7px; border-radius:50%;
  }
  .quote.ict .quote-tag .dot{ background:var(--sky-500); }
  .quote.sec .quote-tag .dot{ background:var(--navy-800); }
  .quote-body{
    font-size:15.5px; line-height:1.6;
    color:var(--ink-2);
    margin:0 0 22px;
    position:relative; z-index:1;
    text-wrap:pretty;
  }
  .quote-author{
    margin-top:auto;
    padding-top:18px;
    border-top:1px solid var(--line);
    position:relative; z-index:1;
  }
  .quote-author .name{
    font-weight:600; font-size:14px; color:var(--navy-900);
    margin:0; letter-spacing:-.005em;
  }
  .quote-author .role{
    font-size:12.5px; color:var(--muted); margin:2px 0 0;
  }
  .quote-stars{
    display:inline-flex; gap:3px; margin-left:auto;
    color:#F5A623;
  }
  .quote-meta-row{
    display:flex; align-items:flex-end; justify-content:space-between;
    gap:12px;
  }
  .quote-stars svg{ width:13px; height:13px; }

  /* ============ ABOUT ============ */
  .about{
    background:var(--bg-2);
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
  }
  .about-grid{
    display:grid; grid-template-columns: 1fr 1.4fr; gap:60px; align-items:center;
  }
  .joost-card{
    background:#fff; border-radius:18px; border:1px solid var(--line);
    padding:24px; box-shadow:var(--shadow-md);
    position:relative;
  }
  .joost-photo{
    aspect-ratio:4/5;
    border-radius:12px;
    background:linear-gradient(135deg, var(--navy-800) 0%, var(--sky-500) 100%);
    position:relative;
    overflow:hidden;
    margin-bottom:20px;
  }
  .joost-photo img{
    width:100%; height:100%;
    object-fit:cover;
    object-position:center 22%;
    display:block;
  }
  .joost-photo::after{
    content:""; position:absolute; inset:0;
    background:linear-gradient(180deg, transparent 55%, rgba(11,20,56,.55) 100%);
    pointer-events:none;
  }
  .joost-photo .tag{
    position:absolute; left:14px; bottom:14px;
    z-index:1;
    display:inline-flex; align-items:center; gap:8px;
    font-family:"JetBrains Mono", monospace;
    font-size:11px; letter-spacing:.08em; text-transform:uppercase;
    color:#fff;
    padding:6px 10px;
    background:rgba(11,20,56,.55);
    border:1px solid rgba(255,255,255,.18);
    border-radius:999px;
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
  }
  .joost-photo .tag .dot{
    width:6px; height:6px; border-radius:50%;
    background:#22D78A;
    box-shadow:0 0 0 3px rgba(34,215,138,.25);
  }
  .joost-card .name{ font-size:20px; font-weight:700; margin:0; }
  .joost-card .role{ font-size:13px; color:var(--sky-500); font-weight:500; margin:4px 0 0; font-family:"JetBrains Mono", monospace; }
  .joost-card .links{ display:flex; gap:10px; margin-top:16px; padding-top:16px; border-top:1px solid var(--line); }
  .joost-card .links a{
    display:inline-flex; align-items:center; gap:6px;
    font-size:13px; color:var(--muted); padding:6px 10px;
    border-radius:8px; border:1px solid var(--line);
    transition:all .2s ease;
  }
  .joost-card .links a:hover{ border-color:var(--navy-800); color:var(--navy-800); }
  .joost-card .links svg{ width:13px; height:13px; }

  .about-text h2{
    font-size:clamp(28px, 3.4vw, 42px); font-weight:700;
    letter-spacing:-.02em; margin:0 0 18px; line-height:1.12;
    color:var(--navy-900); text-wrap:balance;
  }
  .about-text p{
    font-size:16px; line-height:1.65; color:var(--ink-2); margin:0 0 16px;
  }
  .about-text p.muted{ color:var(--muted); font-size:15px; }
  .quote-row{
    display:flex; gap:18px;
    background:#fff; border:1px solid var(--line); border-radius:14px;
    padding:18px 20px; margin-top:24px;
    box-shadow:var(--shadow-sm);
  }
  .quote-row .q-icon{
    width:36px; height:36px; flex-shrink:0;
    border-radius:10px; background:var(--bg-2);
    display:grid; place-items:center; color:var(--navy-800);
  }
  .quote-row .q-icon svg{ width:18px; height:18px; }
  .quote-row .q-body{ font-size:14.5px; color:var(--ink-2); }
  .quote-row .q-body strong{ color:var(--navy-800); }

  /* ============ CONTACT ============ */
  .contact{ padding-bottom:120px; }
  .contact-grid{
    display:grid; grid-template-columns: 1fr 1fr; gap:0;
    background:#fff;
    border:1px solid var(--line);
    border-radius:24px;
    overflow:hidden;
    box-shadow:var(--shadow-lg);
  }
  .contact-info{
    background:linear-gradient(160deg, var(--navy-900) 0%, var(--navy-800) 100%);
    color:#fff;
    padding:48px;
    position:relative;
    overflow:hidden;
  }
  .contact-info::before{
    content:""; position:absolute; right:-40%; bottom:-40%;
    width:90%; height:90%;
    background:radial-gradient(circle, rgba(46,163,221,.2), transparent 65%);
  }
  .contact-info h2{
    font-size:30px; font-weight:600; margin:0 0 12px;
    letter-spacing:-.015em; text-wrap:balance;
  }
  .contact-info p{
    color:rgba(255,255,255,.7); font-size:15px; margin:0 0 36px; max-width:34ch;
  }
  .contact-list{ display:grid; gap:22px; position:relative; }
  .contact-list .row{ display:flex; gap:14px; align-items:flex-start; }
  .contact-list .ic{
    width:38px; height:38px; flex-shrink:0;
    border-radius:10px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.12);
    display:grid; place-items:center;
    color:var(--sky-400);
  }
  .contact-list .ic svg{ width:16px; height:16px; }
  .contact-list .lbl{ font-size:12px; color:rgba(255,255,255,.55); margin-bottom:2px; letter-spacing:.04em; }
  .contact-list .val{ font-size:15px; font-weight:500; }
  .contact-list .val a:hover{ color:var(--sky-400); }
  .availability{
    position:relative; margin-top:36px; padding-top:24px;
    border-top:1px solid rgba(255,255,255,.1);
    display:flex; align-items:center; gap:10px;
    font-size:13px; color:rgba(255,255,255,.85);
  }
  .availability .live{
    width:8px; height:8px; border-radius:50%; background:#22D78A;
    box-shadow:0 0 0 4px rgba(34,215,138,.2);
    animation:pulse 2.4s ease-in-out infinite;
  }

  .contact-form{ padding:48px; }
  .form-head{ margin-bottom:24px; }
  .form-head h3{
    font-size:22px; font-weight:600; margin:0 0 6px;
    letter-spacing:-.01em; color:var(--navy-900);
  }
  .form-head p{ color:var(--muted); font-size:14px; margin:0; }
  .track-toggle{
    display:grid; grid-template-columns:1fr 1fr 1fr; gap:6px;
    padding:4px; border:1px solid var(--line);
    border-radius:12px;
    margin-bottom:18px;
    background:var(--bg);
  }
  .track-toggle button{
    background:transparent; border:0;
    padding:10px; border-radius:8px;
    font-size:13px; font-weight:500; color:var(--muted);
    display:flex; align-items:center; justify-content:center; gap:6px;
    transition:all .2s ease;
  }
  .track-toggle button .dot{
    width:6px; height:6px; border-radius:50%;
    background:var(--muted-2);
  }
  .track-toggle button:hover{ color:var(--ink-2); }
  .track-toggle button.on{
    background:#fff; color:var(--navy-900);
    box-shadow:var(--shadow-sm);
  }
  .track-toggle button.on[data-t="ict"] .dot{ background:var(--sky-500); }
  .track-toggle button.on[data-t="sec"] .dot{ background:var(--navy-800); }
  .track-toggle button.on[data-t="other"] .dot{ background:var(--green); }

  .field{ margin-bottom:14px; }
  .field label{
    display:block; font-size:12.5px; font-weight:500;
    color:var(--ink-2); margin-bottom:6px;
  }
  .field input, .field textarea, .field select{
    width:100%; font-family:inherit; font-size:14.5px;
    padding:12px 14px; border-radius:10px;
    border:1px solid var(--line); background:#fff;
    color:var(--ink);
    transition:border-color .2s ease, box-shadow .2s ease;
  }
  .field input:focus, .field textarea:focus, .field select:focus{
    outline:none;
    border-color:var(--navy-800);
    box-shadow:0 0 0 3px rgba(46,163,221,.18);
  }
  .field-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
  .field textarea{ min-height:100px; resize:vertical; }
  .form-submit{
    width:100%; justify-content:center;
    padding:14px;
    margin-top:6px;
  }
  .form-fine{
    margin-top:10px; font-size:12px; color:var(--muted-2);
    display:flex; gap:6px; align-items:center; justify-content:center;
  }
  .form-fine svg{ width:12px; height:12px; }

  /* ============ FOOTER ============ */
  footer{
    background:var(--navy-900); color:rgba(255,255,255,.7);
    padding:60px 0 30px;
  }
  .foot-grid{
    display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:48px;
    margin-bottom:48px;
  }
  .foot-grid h5{
    color:#fff; font-size:13px; letter-spacing:.06em; text-transform:uppercase;
    margin:0 0 16px; font-weight:600;
    display:flex; align-items:center; gap:8px;
  }
  .foot-grid h5 .dot{
    width:6px; height:6px; border-radius:50%;
  }
  .foot-grid h5 .dot-ict{ background:var(--sky-500); }
  .foot-grid h5 .dot-sec{ background:var(--sky-400); }
  .foot-grid a{ display:block; padding:5px 0; font-size:14px; transition:color .2s ease; }
  .foot-grid a:hover{ color:var(--sky-400); }
  .foot-brand img{ height:32px; filter:brightness(0) invert(1); margin-bottom:16px; }
  .foot-brand p{ font-size:14px; line-height:1.6; margin:0; max-width:30ch; }
  .foot-bottom{
    padding-top:28px; border-top:1px solid rgba(255,255,255,.08);
    display:flex; justify-content:space-between; align-items:center;
    flex-wrap:wrap; gap:14px;
    font-size:12.5px; color:rgba(255,255,255,.5);
  }
  .foot-bottom .links{ display:flex; gap:20px; }
  .foot-bottom a:hover{ color:#fff; }

  /* ============ REVEAL ============ */
  .reveal{
    opacity:0; transform:translateY(20px);
    transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
  }
  .reveal.in{ opacity:1; transform:none; }

  /* ============ RESPONSIVE ============ */
  @media (max-width:1024px){
    .nav-links{ display:none; }
    .menu-btn{ display:inline-flex; }
    .sec-grid, .why-grid, .about-grid{ grid-template-columns:1fr; gap:48px; }
    .sec-sidecard{ position:static; }
    .quotes-grid{ grid-template-columns:1fr 1fr; }
    .praktijk-grid{ grid-template-columns:1fr 1fr; }
    .praktijk-grid .pk:last-child{ grid-column:1 / -1; aspect-ratio:16/8; }
  }
  @media (max-width:880px){
    .nav-cta .btn:not(.menu-trigger), .nav-cta .phone-pill{ display:none; }
    .picker-grid, .contact-grid, .foot-grid{ grid-template-columns:1fr; }
  }
  @media (max-width:760px){
    .container{ padding:0 20px; }
    section{ padding:64px 0; }
    .hero{ padding:40px 0 32px; }
    .picker{ padding:24px 0 56px; }
    .services-grid{ grid-template-columns:1fr; gap:14px; }
    .praktijk-grid{ grid-template-columns:1fr; gap:14px; }
    .pk{ aspect-ratio:16/11; }
    .quotes-grid{ grid-template-columns:1fr; gap:14px; }
    .contact-info, .contact-form{ padding:32px 22px; }
    .track-card{ padding:28px 24px; min-height:auto; }
    .track-card h3{ font-size:26px; max-width:none; }
    .track-card .desc{ max-width:none; }
    .track-num{ top:20px; right:22px; }
    .sec-svc{ grid-template-columns:42px 1fr; padding:18px; gap:14px; }
    .sec-svc .arrow{ display:none; }
    .sec-sidecard{ padding:26px 22px; }
    .why-side{ padding:32px 24px; min-height:auto; }
    .why-stats{ gap:16px; }
    .joost-card{ padding:18px; }
    .audience-strip{ flex-wrap:wrap; gap:8px; padding:10px 14px; }
    .audience-strip .lbl{ display:none; }
    .hero-cta{ flex-direction:column; align-items:stretch; gap:10px; width:100%; }
    .hero-cta .btn{ width:100%; justify-content:center; }
    .hero-meta{ gap:14px; flex-direction:column; align-items:center; }
    .section-head{ margin-bottom:40px; }
    .nav{ padding:14px 0; gap:12px; }
    .brand img{ height:30px; }
    .form-fine{ text-align:center; line-height:1.4; }
    /* iOS: forceer ≥16px om auto-zoom op focus te voorkomen */
    .field input, .field textarea, .field select,
    .track-toggle button{ font-size:16px; }
    .field input, .field textarea, .field select{ padding:14px 14px; }
    .track-toggle button{ padding:14px 10px; min-height:48px; }
    /* Tap targets in voet en kaarten */
    .foot-grid a{ padding:10px 0; min-height:44px; display:flex; align-items:center; }
    .joost-card .links a{ min-height:44px; padding:10px 14px; }
    .why-item{ padding:18px 20px; }
    .btn{ min-height:44px; }
    .btn-lg{ min-height:52px; padding:14px 22px; }
  }
  @media (max-width:520px){
    .container{ padding:0 18px; }
    .foot-grid{ grid-template-columns:1fr; gap:32px; }
    .frameworks{ grid-template-columns:1fr 1fr; }
    .why-stats{ grid-template-columns:1fr 1fr; }
    .track-toggle{ grid-template-columns:1fr; }
    .field-row{ grid-template-columns:1fr; gap:0; }
    .foot-bottom{ flex-direction:column; align-items:flex-start; gap:18px; }
    .foot-bottom .links{ flex-wrap:wrap; gap:8px 18px; }
    .contact-info h2{ font-size:26px; }
    .why-side h3{ font-size:26px; }
    .joost-photo{ aspect-ratio:1/1; max-width:280px; margin-left:auto; margin-right:auto; }
    .hero-title{ letter-spacing:-.02em; }
  }
  @media (max-width:400px){
    .container{ padding:0 16px; }
    section{ padding:56px 0; }
    .track-card{ padding:24px 20px; }
    .track-card h3{ font-size:24px; }
    .contact-info, .contact-form{ padding:28px 18px; }
    .why-side{ padding:28px 20px; }
    .sec-svc{ padding:16px; }
  }
}

/* Utility classes replacing inline styles */
.link-inherit{ color:inherit; }
.mt-8{ margin-top:8px; }
.sec-divider-top{ margin-top:24px; padding-top:20px; border-top:1px solid rgba(255,255,255,.1); }
.btn-full{ width:100%; justify-content:center; }
.kicker-inline{ display:inline-flex; align-items:center; gap:8px; font-size:12px; letter-spacing:.12em; text-transform:uppercase; margin-bottom:14px; }
.kicker-inline .bar{ display:inline-block; width:24px; height:1px; background:var(--navy-800); }
.h2-why{ font-size:clamp(28px,3.4vw,42px); font-weight:700; letter-spacing:-.02em; margin:0 0 14px; line-height:1.12; color:var(--navy-900); }
.lead-why{ color:var(--muted); font-size:16.5px; margin:0; max-width:48ch; }
.label-optional{ color:var(--muted-2); font-weight:400; }
