@font-face{font-family:'Inter';font-style:normal;font-weight:400 900;font-display:swap;src:url('/fonts/inter-v20-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:400 900;font-display:swap;src:url('/fonts/inter-v20-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
    --blue:oklch(0.4 0.1076 251.1466);--blue-dark:oklch(0.22 0.09 238);
    --blue-bg:oklch(0.88 0.05 251.1466);--yolk:oklch(0.78 0.18 85);
    --text:#2d3748;--muted:#6b7a8d;--white:#fff;
    --warm:oklch(0.97 0.008 80);
}
@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}
html{scroll-padding-top:80px;height:100%}
body{font-family:'Inter',-apple-system,sans-serif;color:var(--text);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100%;display:flex;flex-direction:column}
a{text-decoration:none;color:inherit}
.c{max-width:1100px;margin:0 auto;padding:0 28px}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 0;transition:all .35s}
.nav.scrolled{background:color-mix(in oklch, var(--blue-dark) 97%, transparent);backdrop-filter:blur(12px);padding:13px 0}
.nav-in{display:flex;justify-content:space-between;align-items:center}
.nav-logo{font-size:22px;font-weight:900;color:#fff;font-style:italic;letter-spacing:-.5px}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{color:rgba(255,255,255,.6);font-size:14px;font-weight:500;transition:color .2s,text-decoration-color .2s,transform .2s,filter .2s}
.nav-links a:hover,.nav-links a.nav-active{color:#fff}
.nav-links a:not(.nav-cta):hover,.nav-links a:not(.nav-cta).nav-active{text-decoration:underline;text-underline-offset:5px;text-decoration-thickness:2px}
.nav-cta,.nav-links a.nav-cta{background:var(--yolk);color:var(--blue-dark);padding:10px 22px;border-radius:5px;font-size:14px;font-weight:700}
.nav-links a.nav-cta:hover{filter:brightness(.9);transform:translateY(-2px)}
.nav-cta-group{display:flex}
.nav-cta-group .nav-cta:first-child{border-radius:5px 0 0 5px}
.nav-cta-group .nav-cta:last-child{border-radius:0 5px 5px 0;border-left:1px solid rgba(0,0,0,.15)}

/* HERO */
.hero{min-height:100vh;position:relative;display:flex;align-items:center;overflow:hidden;background:var(--blue-dark)}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px}
.hero-slide.active{opacity:1}
.hero-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,26,53,.58) 0%,rgba(10,26,53,.72) 50%,rgba(10,26,53,.90) 100%)}
.hero-slide.s1{background:url('images/operations-2-desktop.jpeg') center/cover no-repeat #3d5570}
.hero-slide.s2{background:url('images/hero-operaties.jpeg') center/cover no-repeat #3d5570}
.hero-slide.s3{background:url('images/operations-4-desktop.jpeg') center/cover no-repeat #4a5c75}
.hero-slide.s4{background:url('images/operations-1-desktop.jpeg') center/cover no-repeat #4a5c75}
.hero-slide.s5{background:url('images/operations-3-desktop.jpeg') center/cover no-repeat #5a6d85}
.hero-slide .ph-t{color:rgba(255,255,255,.2);font-size:11px;max-width:240px;text-align:center;line-height:1.4;z-index:0}
.hero-content{position:relative;z-index:4;text-align:center;max-width:680px;padding:0 28px;margin:0 auto}
.hero-label{
    font-size:12px;font-weight:600;letter-spacing:3px;text-transform:uppercase;
    color:var(--yolk);margin-bottom:32px;display:inline-flex;align-items:center;gap:10px;
}
.hero-label::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--yolk)}
.hero h1{font-size:84px;font-weight:300;color:rgba(255,255,255,.7);line-height:1.02;margin-bottom:28px;letter-spacing:-3.5px}
.hero h1 strong{font-weight:900;color:#fff;display:block}
.hero-sub{font-size:19px;color:rgba(255,255,255,.82);line-height:1.75;margin-bottom:48px;max-width:500px;margin-left:auto;margin-right:auto}
.btn-y{background:var(--yolk);color:var(--blue-dark);padding:16px 36px;border-radius:5px;font-size:16px;font-weight:700;transition:all .2s;display:inline-block}
.btn-y:hover{background:oklch(0.84 0.18 85)}
.hero-dots{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:5;display:flex;gap:8px}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2);border:none;cursor:pointer;transition:all .3s;padding:0}
.hero-dot.active{background:var(--yolk);width:28px;border-radius:4px}

/* STATS */
.stats{background:var(--blue);position:relative;z-index:3}
.stats-row{display:flex}
.stat{flex:1;padding:28px 0;text-align:center;border-right:1px solid rgba(255,255,255,.06)}
.stat:last-child{border:none}
.stat-num{font-size:22px;font-weight:800;color:#fff}
.stat-label{font-size:11px;color:rgba(255,255,255,.28);margin-top:3px;font-weight:500}

/* CLIENTS */
.clients{padding:24px 0 24px 48px;border-bottom:1px solid #eee;display:flex;align-items:center;gap:32px;overflow:hidden}
.clients-label{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:#b0b8c4;white-space:nowrap;flex-shrink:0}
.clients-track-wrap{flex:1;overflow:hidden;mask-image:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent);display:flex}
.clients-track{display:flex;align-items:center;gap:72px;padding-right:72px;animation:ticker 55s linear infinite;flex-shrink:0}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}
.clients-track-wrap:hover .clients-track{animation-play-state:paused}
.clients-logo{height:62px;width:auto;max-width:240px;object-fit:contain;flex-shrink:0;filter:grayscale(1) opacity(0.45)}
.clients-logo--lg{height:62px;max-width:240px}
.clients-logo--sm{height:28px;max-width:100px}

/* ---- BRIDGE TEXT (flow connectors) ---- */
.bridge,.people-bridge,.career-bridge{font-size:28px;font-weight:700;color:var(--blue);line-height:1.45;letter-spacing:-.3px}
.bridge span,.career-bridge span{color:var(--muted);font-weight:400}
.bridge{padding:100px 28px 60px;max-width:680px;margin:0 auto}

/* ---- PROJECTS ---- */
.proj-section{padding:0 0 60px}
.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.proj-card{border-radius:14px;overflow:hidden;cursor:pointer;transition:transform .3s;background:#fff;border:1px solid rgba(0,0,0,.05);text-decoration:none;color:inherit;display:block}
.proj-card:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(21,50,90,.08)}
.proj-card.feat,.proj-card.half{display:flex;align-items:flex-end;position:relative}
.proj-card.feat{grid-column:span 2;height:420px}
.proj-card.half{height:300px}
.proj-card.feat .proj-bg,.proj-card.half .proj-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat}
.proj-card.feat .proj-bg{background-image:url('images/defensie.jpeg');background-color:#3d5570}
.proj-card.feat .proj-bg::after,.proj-card.half .proj-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,26,53,.97) 0%,rgba(10,26,53,.75) 40%,rgba(10,26,53,.2) 100%)}
.proj-card.feat .proj-body{position:relative;z-index:2;padding:44px;width:100%;max-width:560px}
.proj-card.half .proj-body{position:relative;z-index:2;padding:28px;width:100%}
.proj-card.feat .proj-tag,.proj-card.half .proj-tag{color:var(--yolk)}
.proj-card.feat .proj-title{color:#fff;font-size:26px;letter-spacing:-.3px}
.proj-card.half .proj-title{color:#fff;font-size:18px}
.proj-card.feat .proj-desc,.proj-card.half .proj-desc{color:rgba(255,255,255,.7);font-size:14px}
.proj-card.feat .proj-arrow,.proj-card.half .proj-arrow{color:var(--yolk)}
.proj-body{padding:26px}
.proj-tag{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--yolk);margin-bottom:8px}
.proj-title{font-size:18px;font-weight:700;color:var(--blue);line-height:1.35;margin-bottom:8px}
.proj-desc{font-size:14px;color:var(--muted);line-height:1.6}
.proj-arrow{margin-top:14px;font-size:14px;font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:4px}
.ph-t{font-size:11px;color:rgba(255,255,255,.25);text-align:center;max-width:200px;line-height:1.4}
.ph-t--dark{color:#5a6a7d;max-width:180px}
.proj-more{text-align:center;padding-top:40px}
.sec-link{font-size:14px;font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:6px;border-bottom:1.5px solid var(--blue);padding-bottom:2px;transition:gap .2s}
.sec-link:hover{gap:10px}
.sec-link--yolk{color:var(--yolk);border-color:var(--yolk)}
.sec-link--cta{display:inline-flex;margin-top:20px}
a[aria-disabled="true"]{pointer-events:none;opacity:.5;cursor:default}

/* ---- PEOPLE BRIDGE → SECTION ---- */
.people-bridge{padding:60px 28px 0;max-width:680px;margin:0 auto;text-align:center}
.people-sec{
    background:var(--blue);position:relative;overflow:hidden;
    padding:80px 0 100px;margin-top:60px;
}
.people-sec::before{
    content:'';position:absolute;top:-60px;left:0;right:0;height:61px;
    background:var(--blue);clip-path:polygon(0 100%,100% 0,100% 100%);
}
.deco-lines{position:absolute;top:0;right:0;bottom:0;width:40%;pointer-events:none;overflow:hidden;opacity:.04}
.deco-lines::before,.deco-lines::after{content:'';position:absolute;width:1px;height:200%;background:#fff;transform:rotate(18deg);transform-origin:top left}
.deco-lines::before{right:30%;top:-20%}
.deco-lines::after{right:55%;top:-40%}
.people-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:start;position:relative;z-index:2}
.video-block{border-radius:14px;overflow:hidden;position:relative;background:#2a3f5c;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;cursor:pointer}
.video-block video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.vid-name{margin-top:14px;font-size:16px;font-weight:700;color:#fff}
.vid-role{font-size:13px;color:rgba(255,255,255,.3)}
.people-cards{display:flex;flex-direction:column;gap:14px}
.p-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:22px;display:grid;grid-template-columns:52px 1fr;gap:16px;align-items:start;transition:background .2s;cursor:pointer}
.p-card:hover{background:rgba(255,255,255,.09)}
.p-av{width:52px;height:52px;border-radius:10px;background:#3d5570;display:flex;align-items:center;justify-content:center;font-size:9px;color:rgba(255,255,255,.25);background-size:cover;background-position:center}
.p-card.large{padding:28px;grid-template-columns:72px 1fr;gap:20px}
.p-card.large .p-av{width:72px;height:72px;border-radius:12px}
.p-card.large .p-q{font-size:15px;line-height:1.65}
.p-q{font-size:14px;color:rgba(255,255,255,.55);line-height:1.55;margin-bottom:8px;font-style:italic}
.p-n{font-size:13px;font-weight:700;color:#fff}
.p-r{font-size:11.5px;color:rgba(255,255,255,.28)}
.people-more{text-align:center;margin-top:32px;position:relative;z-index:2}

/* ---- WHY ---- */
.career-sec{padding:120px 0 100px;position:relative}
.career-bridge{max-width:580px;margin-bottom:48px}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.why-list{display:flex;flex-direction:column;gap:28px}
.why-item{display:flex;gap:18px}
.wi{width:42px;height:42px;min-width:42px;border-radius:10px;background:var(--blue-bg);display:flex;align-items:center;justify-content:center}
.wi svg{width:18px;height:18px}
.why-item h3{font-size:16px;font-weight:700;color:var(--blue);margin-bottom:3px}
.why-item p{font-size:14px;color:var(--muted);line-height:1.65}
.photo-mosaic{display:grid;grid-template-columns:1.15fr 1fr;grid-template-rows:228px 175px;gap:8px}
.pm-cell{border-radius:10px;overflow:hidden;background:#9eaab8;position:relative;display:flex;align-items:center;justify-content:center}
.pm-cell img{width:100%;height:100%;object-fit:cover;display:block}
.pm-placeholder{background:#8899ae}

/* ---- CTA ---- */
.cta{background:var(--blue-bg);padding:100px 0;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;top:-60px;left:0;right:0;height:61px;background:var(--blue-bg);clip-path:polygon(0 0,100% 100%,0 100%)}
.cta-in{max-width:640px;margin:0 auto;text-align:center}
.cta h2{font-size:36px;font-weight:800;color:var(--blue);margin-bottom:20px;letter-spacing:-.5px}
.cta-sub{font-size:16px;color:var(--muted);line-height:1.7;margin-bottom:64px}
.cta-ppl{display:flex;gap:100px;justify-content:center;margin-bottom:56px}
.cta-p{display:flex;flex-direction:column;align-items:center;gap:12px}
.cta-av{width:108px;height:108px;border-radius:50%;background:#a8b8cc center/cover no-repeat;display:flex;align-items:center;justify-content:center;font-size:10px;color:#5a6a7d;border:3px solid #fff;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.cta-nm{font-size:16px;font-weight:700;color:var(--blue)}
.cta-links{display:flex;gap:14px;align-items:center;margin-top:4px}
.cta-links a{font-size:12.5px;color:var(--blue);font-weight:600;border-bottom:1px solid var(--blue);padding-bottom:1px}

/* ---- PROJ BG IMAGES ---- */
.proj-bg-cyber{background-image:url('images/cyber-intelligence.jpeg');background-color:#5c7290}
.proj-bg-forensics{background-image:url('images/forensics.jpeg');background-color:#6b7d95}
.proj-bg-nato{background-image:url('images/nato.jpeg');background-color:#4a5c75}
.proj-bg-public{background-image:url('images/overheid.jpeg');background-color:#7a8fa8}

/* ---- PROJECT DETAIL SECTIONS ---- */
.proj-sec{padding:100px 0;border-bottom:1px solid #eee}
.proj-sec:last-of-type{border-bottom:none}
.proj-sec--dark{background:var(--blue);border-color:rgba(255,255,255,.07)}
.proj-sec--alt{background:oklch(0.97 0.015 251)}
.proj-sec-in{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.proj-sec-in--flip .proj-sec-img{order:2}
.proj-sec-in--flip .proj-sec-body{order:1}
.proj-sec-img{border-radius:16px;overflow:hidden;height:440px;background:#3d5570 center/cover no-repeat;flex-shrink:0}
.proj-sec-img--defensie{background-image:url('images/defensie.jpeg')}
.proj-sec-img--nato{background-image:url('images/nato.jpeg')}
.proj-sec-img--forensics{background-image:url('images/forensics.jpeg')}
.proj-sec-img--cyber{background-image:url('images/cyber-intelligence.jpeg')}
.proj-sec-img--public{background-image:url('images/overheid.jpeg')}
.proj-sec--tint{background:oklch(0.95 0.025 251)}
.proj-jobs-cta{padding:40px 0}
.proj-sec-body .proj-tag{margin-bottom:14px}
.proj-sec-body h2{font-size:28px;font-weight:800;color:var(--blue);line-height:1.3;letter-spacing:-.3px;margin-bottom:24px}
.proj-sec--dark .proj-sec-body h2{color:#fff}
.proj-sec-body p{font-size:16px;color:var(--text);line-height:1.85;margin-bottom:18px}
.proj-sec-body p:last-child{margin-bottom:0}
.proj-sec--dark .proj-sec-body p{color:rgba(255,255,255,.72)}

/* ---- PEOPLE AVATARS ---- */
.p-av-troy{background-image:url('images/people/troy.jpg')}
.p-av-jessy{background-image:url('images/people/jessy.jpg')}
.p-av-steven{background-image:url('images/people/steven.jpg');background-size:475%;background-position:64% 30%}

/* FOOTER */
.footer{background:var(--blue-dark);padding:56px 0 28px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;margin-bottom:40px;align-items:start}
.footer-logo{font-size:20px;font-weight:900;color:#fff;font-style:italic}
.footer-about{font-size:13px;color:rgba(255,255,255,.5);line-height:1.7;max-width:340px;margin-top:14px}
.fct{font-size:11.5px;font-weight:700;color:rgba(255,255,255,.7);margin-bottom:14px;letter-spacing:.5px}
.footer-col a{display:block;font-size:13px;color:rgba(255,255,255,.45);margin-bottom:10px;transition:color .2s}
.footer-col a:hover{color:var(--yolk)}
.footer-btm{border-top:1px solid rgba(255,255,255,.08);padding-top:20px;display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,.3)}
.footer-privacy{color:rgba(255,255,255,.3);transition:color .2s}.footer-privacy:hover{color:rgba(255,255,255,.65)}

/* ---- NAV TOGGLE (hamburger) ---- */
.nav-toggle{
    display:none;flex-direction:column;justify-content:center;gap:5px;
    background:none;border:none;cursor:pointer;padding:4px;z-index:110;
}
.nav-toggle span{
    display:block;width:22px;height:2px;background:#fff;border-radius:2px;
    transition:transform .25s,opacity .25s;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---- INTRO (werken bij / vacatures / projecten) ---- */
.intro{padding:100px 0 70px}
.intro-text{font-size:32px;font-weight:700;color:var(--blue);line-height:1.4;max-width:640px;letter-spacing:-.3px}
.intro-text span{color:var(--muted);font-weight:400}

/* ---- VACATURES ---- */
.profiles{padding:0 0 100px}
.profiles-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}
.profile-card{display:block;background:var(--warm);border-radius:14px;padding:36px;border:1px solid rgba(0,0,0,.04);transition:transform .2s,box-shadow .2s;text-decoration:none}
.profile-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(21,50,90,.06)}
.profile-tag{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--yolk);margin-bottom:12px}
.profile-title{font-size:22px;font-weight:800;color:var(--blue);margin-bottom:12px;line-height:1.25}
.profile-desc{font-size:15px;color:var(--muted);line-height:1.7;margin-bottom:20px}
.profile-tags{display:flex;gap:8px;flex-wrap:wrap}
.ptag{padding:6px 14px;border-radius:50px;font-size:12px;font-weight:600;background:var(--white);color:var(--blue);border:1px solid rgba(21,50,90,.08)}
.profile-detail-title{font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.profile-reqs,.profile-detail ul{padding-left:18px;display:flex;flex-direction:column;gap:8px}
.profile-reqs li,.profile-detail ul li{font-size:14px;color:var(--text);line-height:1.55}

.vacature-col{max-width:680px}
.req-list,.vacature-reqs ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:12px}
.req-list li,.vacature-reqs ul li{padding-left:26px;position:relative;font-size:15px;color:var(--text);line-height:1.55}
.req-list li::before,.vacature-reqs ul li::before{content:'';position:absolute;left:0;top:6px;width:13px;height:8px;border-left:2px solid var(--blue);border-bottom:2px solid var(--blue);transform:rotate(-45deg)}
.vacature-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--blue);border-bottom:2px solid var(--blue);padding-bottom:10px;margin-bottom:20px;display:inline-block}
.vacature-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px}
.proj-sec--sm{padding:64px 0}
.vacature-perks{background:var(--warm);padding:64px 0}

.zzp-note{margin-top:20px;background:var(--blue-bg);border-radius:10px;padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.zzp-note-label{font-size:13px;font-weight:600;color:var(--blue);text-transform:uppercase;letter-spacing:.04em}
.zzp-note-link{font-size:15px;font-weight:500;color:var(--blue);text-decoration:none}
.zzp-note-link:hover{text-decoration:underline;text-underline-offset:3px}
.other-roles{margin-top:32px}
.other-roles-title{font-size:15px;font-weight:600;color:var(--muted);margin-bottom:14px}
.other-roles-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.other-role{display:block;background:var(--white);border-radius:10px;padding:22px 26px;border:1px solid rgba(0,0,0,.06);text-decoration:none;transition:transform .2s,box-shadow .2s}
.other-role:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(21,50,90,.06)}
.other-role-title{font-size:16px;font-weight:700;color:var(--blue);margin-bottom:4px}
.other-role-desc{font-size:13.5px;color:var(--muted);line-height:1.5;margin-bottom:12px}
.other-role-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}
.other-role-meta{font-size:12px;color:var(--muted);opacity:.6}
.other-role-link{font-size:13px;font-weight:700;color:var(--yolk);white-space:nowrap;transition:opacity .2s}
.other-role-link:hover{opacity:.75}

.domains{padding:60px 0 100px;background:oklch(0.95 0.025 251)}
.domains-title{font-size:20px;font-weight:700;color:var(--blue);margin-bottom:24px}
.domains-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.domain{background:var(--blue);border-radius:12px;overflow:hidden;color:#fff;text-align:left;transition:transform .2s,background .2s;cursor:pointer;display:block}
.domain:hover{background:oklch(0.46 0.11 251);transform:translateY(-2px)}
.domain-img{height:120px;background-size:cover;background-position:center;margin-bottom:0}
.domain-body{padding:16px 18px 18px}
.domain-img--defensie{background-image:url('images/defensie-domain.jpeg')}
.domain-img--intelligence{background-image:url('images/cyber-intelligence-domain.jpeg')}
.domain-img--forensics{background-image:url('images/forensics.jpeg')}
.domain-img--nato{background-image:url('images/nato-domain.jpeg')}
.domain-img--public{background-image:url('images/overheid-domain.jpeg')}
.domain-name{font-size:14px;font-weight:700;margin-bottom:4px}
.domain-examples{font-size:12px;color:rgba(255,255,255,.4);line-height:1.4}

.procedure{padding:100px 0;background:#fff}
.procedure-intro{font-size:28px;font-weight:700;color:var(--blue);line-height:1.4;max-width:580px;margin-bottom:48px;letter-spacing:-.3px}
.procedure-intro span{color:var(--muted);font-weight:400}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative}
.steps::before{content:'';position:absolute;top:17px;left:18px;right:18px;height:2px;background:var(--blue-bg);z-index:0}
.step{position:relative;z-index:1}
.step-num{width:36px;height:36px;border-radius:50%;background:var(--blue-bg);color:var(--blue);font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:16px;position:relative;z-index:2}
.step-title{font-size:16px;font-weight:700;color:var(--blue);margin-bottom:6px}
.step-desc{font-size:14px;color:var(--muted);line-height:1.6}
.procedure-note{margin-top:32px;font-size:15px;color:var(--muted);line-height:1.7;max-width:520px}

.perks{background:var(--warm);padding:100px 0;position:relative;overflow:hidden}
.perks::before{content:'';position:absolute;top:-60px;left:0;right:0;height:61px;background:var(--warm);clip-path:polygon(0 100%,100% 0,100% 100%)}
.perks-title{font-size:28px;font-weight:700;color:var(--blue);line-height:1.4;max-width:500px;margin-bottom:48px;letter-spacing:-.3px}
.perks-title span{color:var(--muted);font-weight:400}
.perks-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.perk{background:var(--white);border-radius:12px;padding:28px;border:1px solid rgba(0,0,0,.04);display:flex;gap:18px;align-items:start}
.perk-icon{width:42px;height:42px;min-width:42px;border-radius:10px;background:var(--blue-bg);display:flex;align-items:center;justify-content:center}
.perk-icon svg{width:18px;height:18px}
.perk-title{font-size:15px;font-weight:700;color:var(--blue);margin-bottom:3px}
.perk-desc{font-size:14px;color:var(--muted);line-height:1.6}

.person-block{padding:80px 0 100px}
.person-label{font-size:11.5px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--yolk);margin-bottom:20px}

.shane-video{width:100%;aspect-ratio:16/9;background:#1a2a40;border-radius:14px;position:relative;overflow:hidden;margin-bottom:16px}
.shane-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

.person-meta{margin-bottom:48px}
.person-name{font-size:22px;font-weight:800;color:var(--blue)}
.person-role{font-size:15px;color:var(--muted);margin-top:2px}

.person-story{max-width:720px;font-size:17px;line-height:1.8;color:var(--text)}
.person-story p{margin-bottom:24px}
.person-story strong{color:var(--blue);font-weight:700}

.steven-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start;margin-bottom:48px}
.steven-photo{border-radius:14px;overflow:hidden;background:#9eaab8;aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;position:relative}
.steven-photo img{width:100%;height:100%;object-fit:cover}
.steven-photo .ph-t{color:#6b7a8d;font-size:11px;text-align:center;max-width:140px}

.steven-extra{border-radius:14px;overflow:hidden;background:#9eaab8;height:300px;margin:40px 0}
.steven-extra img{width:100%;height:100%;object-fit:cover;object-position:center 10%}

.divider{border:none;border-top:1px solid #e8ecf0;margin:100px 0}

/* Nav solid (non-hero pages) */
.nav--solid{background:color-mix(in oklch,var(--blue-dark) 97%,transparent);backdrop-filter:blur(12px);padding:13px 0}

/* Person block dark variant */
.person-block--dark{background:var(--blue);padding:80px 0 100px}
.person-block--dark .person-name{color:#fff}
.person-block--dark .person-role{color:rgba(255,255,255,.45)}
.person-block--dark .person-story{color:rgba(255,255,255,.72)}
.person-block--dark .person-story strong{color:#fff}
.person-block--dark .person-story em{color:rgba(255,255,255,.5)}

/* ---- RESPONSIVE: tablet ---- */
@media(max-width:900px){
    .vacature-grid{grid-template-columns:1fr;gap:48px}
    .proj-card.feat{height:360px}
    .proj-card.half{height:260px}
    .people-grid{grid-template-columns:1fr}
    .why-grid{grid-template-columns:1fr;gap:40px}
    .photo-mosaic{grid-template-rows:200px 155px}
    .career-sec{padding:80px 0 60px}
    .cta-ppl{gap:48px}
    /* Clients */
    .clients{padding:20px 0 20px 28px;gap:20px}
    /* Project detail */
    .proj-sec{padding:72px 0}
    .proj-sec-in{grid-template-columns:1fr;gap:40px}
    .proj-sec-in--flip .proj-sec-img{order:0}
    .proj-sec-in--flip .proj-sec-body{order:0}
    .proj-sec-img{height:320px}
    /* Vacatures */
    .domains-grid{grid-template-columns:repeat(3,1fr)}
    .steps{grid-template-columns:1fr 1fr;gap:32px}
    .steps::before{display:none}
    .perks-grid{grid-template-columns:1fr}
}

/* ---- RESPONSIVE: mobiel ---- */
@media(max-width:640px){
    /* Nav */
    .nav-toggle{display:flex}
    .nav-links{
        display:none;position:absolute;top:100%;left:0;right:0;
        background:var(--blue-dark);padding:8px 28px 24px;
        flex-direction:column;gap:0;align-items:stretch;
    }
    .nav-links.open{display:flex}
    .nav-links a{
        padding:13px 0;border-bottom:1px solid rgba(255,255,255,.07);
        color:rgba(255,255,255,.75);font-size:15px;
    }
    .nav-links a:last-child{border-bottom:none}
    .nav-links a.nav-cta{
        margin-top:12px;border-bottom:none;text-align:center;
        padding:13px 22px;border-radius:5px;
    }
    .nav-cta-group{margin-top:12px;flex-direction:row}
    .nav-cta-group .nav-cta:first-child,.nav-cta-group .nav-cta:last-child{flex:1;margin-top:0}

    /* Hero */
    .hero h1{font-size:46px;letter-spacing:-2px}
    .hero-sub{font-size:16px;margin-bottom:36px}
    .hero-content{padding:0 20px}
    .hero-slide.s1{background-image:url('images/operations-2-mobile.jpeg');background-position:70% 30%}
    .hero-slide.s2{background-image:url('images/hero-operaties-mobile.jpeg');background-position:center 25%}
    .hero-slide.s3{background-image:url('images/operations-4-mobile.jpeg');background-position:center 40%}
    .hero-slide.s4{background-image:url('images/operations-1-mobile.jpeg');background-position:75% 10%}
    .hero-slide.s5{background-image:url('images/operations-3-mobile.jpeg');background-position:35% 60%}

    /* Stats */
    .stats-row{flex-wrap:wrap}
    .stat{flex:1 1 50%;border-right:none;border-bottom:1px solid rgba(255,255,255,.06)}
    .stat:nth-child(odd){border-right:1px solid rgba(255,255,255,.06)}
    .stat:nth-last-child(-n+2){border-bottom:none}

    /* Clients */
    .clients{padding:16px 0 16px 20px;gap:16px}
    .clients-label{display:none}
    .clients-logo{filter:grayscale(1) opacity(0.65)}

    /* Bridge */
    .bridge,.people-bridge,.career-bridge{font-size:22px}
    .bridge{padding:48px 20px 32px}
    .people-bridge{padding:40px 20px 0}

    /* Projects */
    .proj-grid{grid-template-columns:1fr}
    .proj-card.feat{grid-column:span 1;height:320px}
    .proj-card.feat .proj-body{padding:24px}
    .proj-card.feat .proj-title{font-size:20px}
    .proj-card.half{height:200px}
    .proj-card.half .proj-body{padding:20px}
    .proj-card.half .proj-desc{display:none}
    .photo-mosaic{grid-template-rows:150px 120px;gap:6px}
    .pm-cell{border-radius:7px}

    /* People */
    .people-sec{padding:48px 0 64px;margin-top:40px}

    /* CTA */
    .cta{padding:64px 0}
    .cta h2{font-size:26px}
    .cta-sub{font-size:15px;margin-bottom:40px}
    .cta-ppl{gap:32px}
    .cta-links{gap:10px}

    /* Footer */
    .footer-grid{grid-template-columns:1fr;gap:28px}
    .footer-about{max-width:none}
    .footer-btm{flex-direction:column;gap:8px;text-align:center}

    /* Project detail */
    .proj-sec{padding:56px 0}
    .proj-sec-img{height:240px}
    .proj-sec-body h2{font-size:22px}
    .proj-sec-body p{font-size:15px}
    /* Vacatures */
    .profiles-grid{grid-template-columns:1fr}
    .other-roles-list{grid-template-columns:1fr}
    .domains-grid{grid-template-columns:1fr 1fr}
    .steps{grid-template-columns:1fr}
    .procedure-intro{font-size:22px}
    .perks{padding:64px 0}
    .perks-title{font-size:22px}

    /* Over ons */
    .intro{padding:90px 0 48px}
    .intro-text{font-size:22px}
    .person-block{padding:0 0 64px}
    .steven-grid{grid-template-columns:1fr;gap:28px}
    .steven-photo{aspect-ratio:4/3}
    .person-story{font-size:15px}
    .divider{margin:64px 0}
}

/* ---- RESPONSIVE: klein telefoon ---- */
@media(max-width:400px){
    .hero h1{font-size:36px;letter-spacing:-1.5px}
    .cta-ppl{flex-direction:column;align-items:center}
    .stat-num{font-size:18px}
}

/* ---- 404 ---- */
.not-found{flex:1;display:flex;align-items:center;justify-content:center;text-align:center}
.not-found-page{flex:1;display:flex;flex-direction:column}
.not-found-code{font-size:140px;font-weight:900;line-height:1;color:var(--blue);opacity:.10;margin:0;letter-spacing:-6px}
.not-found-inner{margin-top:-60px;position:relative}
.not-found-inner h1{font-size:36px;font-weight:800;color:var(--blue);margin:0 0 16px}
.not-found-inner p{font-size:17px;color:var(--muted);max-width:480px;margin:0 auto 40px;line-height:1.6}
.not-found-links{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
@media(max-width:640px){
    .not-found{flex:1}
    .not-found-code{font-size:96px}
    .not-found-inner{margin-top:-40px}
    .not-found-inner h1{font-size:26px}
    .not-found-inner p{font-size:15px}
}
