/* ============================================================
   Nassau420 — gedeeld designsysteem
   Systeem 2: zwart canvas, offerte-kaki accent, Montserrat
   ============================================================ */
:root{
  --black:#080706;
  --panel:#0e0d0b;
  --panel2:#0b0a09;
  --kaki:#a89968;        /* offerte-kaki, premium accent */
  --kaki-deep:#696042;   /* divisie defensie band */
  --blue:#5f8aa0;        /* divisie bedrijven accent */
  --orange:#E2431B;      /* algemene huisstijl, alleen waar passend */
  --text:#c9c4ba;
  --text-dim:#7d786e;
  --white:#ffffff;
  --line:rgba(168,153,104,0.18);
  --line-soft:rgba(255,255,255,0.07);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--black);
  color:var(--text);
  font-family:'Montserrat',sans-serif;
  font-weight:300;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1140px;margin:0 auto;padding:0 30px}
.kicker{font-size:12px;letter-spacing:5px;text-transform:uppercase;color:var(--kaki);font-weight:600}
.kicker.blue{color:var(--blue)}

/* ---------- NAV ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 34px;
  background:linear-gradient(to bottom,rgba(8,7,6,0.92),rgba(8,7,6,0));
  transition:background .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
nav.solid{background:rgba(8,7,6,0.97);border-bottom:1px solid var(--line)}
nav .brand{display:flex;align-items:center;gap:11px}
nav .brand img{height:30px;opacity:.95}
nav .brand .wm{font-weight:600;letter-spacing:3px;font-size:15px;color:#fff}
nav .links{display:flex;align-items:center;gap:30px}
nav .links a{font-size:12.5px;letter-spacing:1.5px;text-transform:uppercase;font-weight:500;color:var(--text);transition:.2s}
nav .links a:hover,nav .links a.active{color:#fff}
nav .links a.cta{
  color:#fff;border:1px solid var(--kaki);padding:9px 18px;border-radius:2px;letter-spacing:2px;font-weight:600;
}
nav .links a.cta:hover{background:var(--kaki);color:var(--black)}
.nav-toggle{display:none;background:none;border:none;color:#fff;font-size:22px;cursor:pointer}
@media(max-width:900px){
  nav .links{
    position:fixed;inset:0 0 0 auto;width:74%;max-width:320px;flex-direction:column;align-items:flex-start;
    gap:6px;padding:90px 30px;background:rgba(8,7,6,0.99);border-left:1px solid var(--line);
    transform:translateX(100%);transition:transform .3s;
  }
  nav .links.open{transform:translateX(0)}
  nav .links a{font-size:15px;padding:10px 0;width:100%;border-bottom:1px solid var(--line-soft)}
  nav .links a.cta{margin-top:14px;border-bottom:1px solid var(--kaki);text-align:center}
  .nav-toggle{display:block;z-index:110}
}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;
  padding-bottom:9vh;background:#000;overflow:hidden;
}
.hero.short{min-height:78vh;padding-bottom:7vh}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center 38%;filter:grayscale(0.28) contrast(1.06) brightness(0.8)}
.hero .veil{
  position:absolute;inset:0;
  background:
    linear-gradient(to bottom,rgba(8,7,6,0.35) 0%,rgba(8,7,6,0.12) 28%,rgba(8,7,6,0.32) 58%,rgba(8,7,6,0.88) 84%,var(--black) 100%),
    radial-gradient(140% 110% at 50% 8%,transparent 44%,rgba(8,7,6,0.55) 100%);
}
.hero-content{position:relative;z-index:2}
.hero h1{
  font-weight:900;font-style:italic;text-transform:uppercase;color:#fff;
  font-size:clamp(46px,9vw,118px);line-height:.9;letter-spacing:-1.5px;
}
.hero h1 .ac{color:var(--kaki)}
.hero h1 .ac.blue{color:var(--blue)}
.hero .tag{font-style:italic;font-weight:500;font-size:clamp(16px,2.3vw,24px);color:#fff;margin-top:20px;max-width:680px}
.hero .baseline{
  margin-top:42px;padding-top:18px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  font-size:11px;letter-spacing:3px;text-transform:uppercase;
}
.hero .baseline .l{color:var(--kaki);font-weight:600}
.hero .baseline .r{color:#fff;font-weight:600;display:flex;align-items:center;gap:10px}
.hero .baseline .r img{height:20px;opacity:.9}
.hero .down{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:3;color:var(--kaki);font-size:18px;animation:bob 2.2s infinite;opacity:.7}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,7px)}}

/* ---------- SECTIONS ---------- */
section{padding:108px 0;position:relative}
.lead{font-weight:300;font-size:clamp(26px,4.2vw,46px);line-height:1.2;color:#fff;letter-spacing:-.5px}
.lead b{font-weight:700;color:var(--kaki)}
.lead b.blue{color:var(--blue)}
.body-lg{font-size:clamp(15px,1.9vw,18px);color:var(--text);max-width:700px;margin-top:24px}
.body-lg + .body-lg{margin-top:16px}
.divider{border-top:1px solid var(--line)}
.bg-panel{background:linear-gradient(180deg,#0b0a08,var(--black))}

/* watermark stamp */
.stamp{position:absolute;top:48px;right:-20px;font-weight:900;font-style:italic;font-size:clamp(70px,15vw,190px);color:rgba(168,153,104,0.04);text-transform:uppercase;letter-spacing:-4px;pointer-events:none;user-select:none;z-index:0}
.stamp + .wrap{position:relative;z-index:1}

/* ---------- TWO MISSIONS / SPLIT CARDS ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);margin-top:54px;border:1px solid var(--line)}
.split .card{position:relative;min-height:440px;display:flex;flex-direction:column;justify-content:flex-end;padding:44px 40px;overflow:hidden;background:var(--panel)}
.split .card .cbg{position:absolute;inset:0;background-size:cover;background-position:center;filter:grayscale(0.3) brightness(0.5);transition:.5s}
.split .card:hover .cbg{transform:scale(1.05);filter:grayscale(0.15) brightness(0.62)}
.split .card .cveil{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,7,6,0.95) 8%,rgba(8,7,6,0.35) 60%,rgba(8,7,6,0.5))}
.split .card .cin{position:relative;z-index:2}
.split .card .ck{font-size:11px;letter-spacing:3px;text-transform:uppercase;font-weight:600}
.split .card h3{font-weight:900;font-style:italic;text-transform:uppercase;font-size:34px;color:#fff;margin:10px 0 12px;line-height:1}
.split .card p{font-size:14.5px;color:var(--text);max-width:90%}
.split .card .more{margin-top:20px;font-size:12px;letter-spacing:2px;text-transform:uppercase;font-weight:600;color:#fff;display:inline-flex;align-items:center;gap:8px}
.split .card .more .arr{transition:.2s}
.split .card:hover .more .arr{transform:translateX(5px)}
.split .card.def .ck{color:var(--kaki)} .split .card.def .more{color:var(--kaki)}
.split .card.biz .ck{color:var(--blue)} .split .card.biz .more{color:var(--blue)}

/* ---------- STAT ROW ---------- */
.stats{background:var(--panel2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.stats .s{background:var(--panel2);padding:48px 28px;text-align:center}
.stats .s .num{font-weight:900;font-style:italic;color:#fff;font-size:clamp(34px,5vw,52px);line-height:1}
.stats .s .num .u{color:var(--kaki)}
.stats .s .lab{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin-top:12px}

/* ---------- BAND ---------- */
.band{background:var(--kaki-deep);color:#fff;text-align:center;padding:64px 28px}
.band .bb{font-weight:900;font-style:italic;text-transform:uppercase;font-size:clamp(30px,5vw,56px)}
.band p{font-weight:400;font-size:clamp(14px,2vw,17px);margin-top:14px;color:rgba(255,255,255,.84);max-width:640px;margin-inline:auto;letter-spacing:.4px}

/* ---------- CYCLE (platform 4 steps) ---------- */
.cycle{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);margin-top:54px;border:1px solid var(--line)}
.cycle .step{background:var(--panel);padding:38px 26px;position:relative}
.cycle .step .ph{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--kaki);font-weight:600}
.cycle .step .nm{font-weight:700;font-size:22px;color:#fff;margin:10px 0 6px;letter-spacing:.5px}
.cycle .step p{font-size:13.5px;color:var(--text-dim);line-height:1.65}
.cycle .step .no{position:absolute;top:20px;right:24px;font-weight:900;font-style:italic;font-size:30px;color:rgba(168,153,104,0.18)}

/* ---------- PLATFORM VISUAL ---------- */
.visual{margin:48px auto 0;max-width:940px;border:1px solid var(--line);overflow:hidden;box-shadow:0 36px 90px rgba(0,0,0,.7)}
.cap{text-align:center;color:var(--kaki);font-size:11px;letter-spacing:3px;text-transform:uppercase;margin-top:18px;font-weight:600}

/* ---------- UNITS ---------- */
.units{position:relative;overflow:hidden;border-top:1px solid var(--line)}
.units .ubg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(0.4) grayscale(0.4);z-index:0}
.units .uveil{position:absolute;inset:0;background:linear-gradient(180deg,var(--black),rgba(8,7,6,0.75) 40%,rgba(8,7,6,0.9));z-index:1}
.units .wrap{position:relative;z-index:2}
.unit-cols{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);margin-top:46px;border:1px solid var(--line)}
.unit-col{background:rgba(11,10,9,0.82);padding:40px 36px}
.unit-col .ut{font-size:12px;letter-spacing:3px;text-transform:uppercase;font-weight:700;margin-bottom:6px}
.unit-col.boots .ut{color:var(--kaki)}
.unit-col.brains .ut{color:var(--blue)}
.unit-col .us{font-size:13px;color:var(--text-dim);margin-bottom:22px}
.unit-col .ulist{display:flex;flex-wrap:wrap;gap:10px}
.unit-col .ulist span{
  font-size:13px;letter-spacing:1px;text-transform:uppercase;font-weight:600;color:#fff;
  border:1px solid var(--line);padding:9px 15px;border-radius:2px;background:rgba(168,153,104,0.05);
}
.unit-col.brains .ulist span{background:rgba(95,138,160,0.07)}

/* ---------- CTA SECTION ---------- */
.cta-sec{text-align:center;border-top:1px solid var(--line);background:linear-gradient(180deg,var(--black),#0b0a08)}
.cta-sec .promise{font-weight:300;font-size:clamp(24px,4.2vw,42px);line-height:1.25;color:#fff;max-width:800px;margin:0 auto}
.cta-sec .promise b{font-weight:700;color:var(--kaki)}
.cta-sec .payoff{font-style:italic;color:var(--text-dim);font-size:17px;margin-top:22px;letter-spacing:1px}
.btn{
  display:inline-block;margin-top:42px;background:transparent;color:#fff;
  font-weight:600;letter-spacing:3px;text-transform:uppercase;font-size:13px;
  padding:18px 46px;border:1px solid var(--kaki);border-radius:2px;transition:.2s;cursor:pointer;
}
.btn:hover{background:var(--kaki);color:var(--black)}
.btn.solid{background:var(--kaki);color:var(--black)}
.btn.solid:hover{background:#bcab78}

/* ---------- CONTENT GRID (12-col) ---------- */
.c12{display:grid;grid-template-columns:repeat(12,1fr);gap:40px;margin-top:50px;align-items:start}
.c12 .l5{grid-column:span 5}
.c12 .r7{grid-column:span 7}
@media(max-width:820px){.c12 .l5,.c12 .r7{grid-column:span 12}}

/* feature list */
.flist{list-style:none}
.flist li{padding:18px 0;border-top:1px solid var(--line);display:flex;gap:18px;align-items:baseline}
.flist li .fn{color:var(--kaki);font-weight:700;font-size:13px;letter-spacing:1px;min-width:34px}
.flist li .ft b{color:#fff;font-weight:600;display:block;margin-bottom:3px;font-size:15.5px}
.flist li .ft span{font-size:14px;color:var(--text-dim)}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--line);padding:54px 0 36px;background:var(--black)}
footer .ftop{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid var(--line-soft)}
footer .fbrand img{height:34px;margin-bottom:16px}
footer .fbrand p{font-size:13.5px;color:var(--text-dim);max-width:300px}
footer .fcol h4{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--kaki);font-weight:600;margin-bottom:16px}
footer .fcol a,footer .fcol p{display:block;font-size:14px;color:var(--text-dim);margin-bottom:10px;transition:.2s}
footer .fcol a:hover{color:#fff}
footer .fbot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:26px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim)}
footer .fbot .tl{color:var(--kaki);font-weight:600}
@media(max-width:760px){
  footer .ftop{grid-template-columns:1fr;gap:28px}
  .split,.cycle,.stats .grid,.unit-cols{grid-template-columns:1fr}
  .cycle{grid-template-columns:1fr 1fr}
  .stats .grid{grid-template-columns:1fr 1fr}
  section{padding:72px 0}
}

/* ============================================================
   V2 ADDITIONS — urgentie, oorsprong, scroll-reveal, sticky CTA
   ============================================================ */

/* scroll-reveal: traag en zwaar */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1.1s cubic-bezier(.16,.7,.3,1),transform 1.1s cubic-bezier(.16,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}.reveal.d3{transition-delay:.36s}.reveal.d4{transition-delay:.48s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---- URGENTIE-BLOK: het probleem is nu ---- */
.urgent{background:#050403;border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center;padding:120px 0}
.urgent .uk{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--kaki);font-weight:600;margin-bottom:40px}
.urgent .lines{max-width:840px;margin:0 auto}
.urgent .lines .ln{font-weight:900;font-style:italic;text-transform:uppercase;color:#fff;font-size:clamp(26px,5vw,52px);line-height:1.05;letter-spacing:-1px;margin:6px 0}
.urgent .lines .ln.dim{color:var(--text-dim)}
.urgent .punch{margin-top:42px;font-weight:300;font-size:clamp(18px,2.6vw,26px);color:var(--kaki);font-style:italic}

/* ---- OORSPRONG-MOMENT ---- */
.origin{position:relative;overflow:hidden;border-top:1px solid var(--line)}
.origin .obg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(0.28) grayscale(0.5);z-index:0}
.origin .oveil{position:absolute;inset:0;background:linear-gradient(110deg,rgba(5,4,3,0.95) 30%,rgba(5,4,3,0.5));z-index:1}
.origin .wrap{position:relative;z-index:2}
.origin .oq{font-weight:900;font-style:italic;text-transform:uppercase;color:#fff;font-size:clamp(30px,5.5vw,64px);line-height:1;letter-spacing:-1.5px;max-width:780px}
.origin .oq .ac{color:var(--kaki)}
.origin .ob{font-size:clamp(15px,1.9vw,18px);color:var(--text);max-width:620px;margin-top:28px}

/* ---- NASSAU-X PLATFORM DIAGRAM (koeler register) ---- */
.diagram{margin-top:54px;border:1px solid var(--line);background:linear-gradient(180deg,#0c0b09,#070605);padding:8px}
.diagram .row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.diagram .node{background:rgba(168,153,104,0.04);border:1px solid var(--line);padding:30px 22px;position:relative;transition:.3s;min-height:160px;display:flex;flex-direction:column;justify-content:space-between}
.diagram .node:hover{background:rgba(168,153,104,0.1);border-color:var(--kaki)}
.diagram .node .ph{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--kaki);font-weight:600}
.diagram .node .nm{font-weight:700;font-size:20px;color:#fff;margin-top:6px}
.diagram .node p{font-size:12.5px;color:var(--text-dim);line-height:1.55;margin-top:14px}
.diagram .node .ar{position:absolute;right:-12px;top:50%;transform:translateY(-50%);color:var(--kaki);font-size:16px;z-index:3;opacity:.5}
.diagram .node:last-child .ar{display:none}
@media(max-width:760px){.diagram .row{grid-template-columns:1fr 1fr}.diagram .node .ar{display:none}}

/* ---- STICKY CTA ---- */
.sticky-cta{position:fixed;bottom:24px;right:24px;z-index:90;opacity:0;transform:translateY(20px);pointer-events:none;transition:.4s}
.sticky-cta.show{opacity:1;transform:none;pointer-events:auto}
.sticky-cta a{display:inline-block;background:var(--kaki);color:var(--black);font-weight:600;letter-spacing:2px;text-transform:uppercase;font-size:12px;padding:14px 26px;border-radius:2px;box-shadow:0 12px 34px rgba(0,0,0,.5);transition:.2s}
.sticky-cta a:hover{background:#bcab78}
@media(max-width:600px){.sticky-cta{bottom:16px;right:16px}.sticky-cta a{padding:12px 20px;font-size:11px}}
