/* ============================================================
   PJ KAPTEIN WOONSUPPORT - Diensten page
   Builds on css/site.css (tokens, nav, footer, .rv, .ba, .proc-wrap, counters)
   ============================================================ */

/* ---------- CINEMATIC HERO ---------- */
.dhero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.dhero-inner{position:relative;z-index:3;width:100%;padding:150px 0 clamp(56px,9vh,104px)}
.dhero .eyebrow{margin-bottom:28px;animation:riseUp .8s var(--ease) .1s both}
.dhero h1{
  font-size:clamp(44px,8.4vw,124px);font-weight:900;text-transform:uppercase;
  letter-spacing:0;line-height:.9;max-width:16ch;
  animation:riseUp .95s var(--ease) .18s both;
}
.dhero h1 em{font-style:normal;color:var(--volt);text-shadow:0 0 60px rgba(57,255,20,.4)}
.dhero .accent-line{width:0;height:3px;background:var(--volt);box-shadow:0 0 16px rgba(57,255,20,.7);
  margin:32px 0;animation:lineGrow 1.1s var(--ease) .5s forwards}
.dhero-sub{max-width:60ch;color:#CCD0CA;font-size:clamp(16px,1.5vw,21px);line-height:1.6;
  animation:riseUp .9s var(--ease) .4s both}
.dhero-actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:40px;animation:riseUp .9s var(--ease) .54s both}
@keyframes riseUp{from{transform:translateY(28px)}to{transform:translateY(0)}}
@keyframes lineGrow{from{width:0}to{width:120px}}

/* directional reveals (image slides in) */
.js .rv.rv-left{opacity:0;transform:translateX(-54px)}
.js .rv.rv-left.in{opacity:1;transform:none}
.js .rv.rv-right{opacity:0;transform:translateX(54px)}
.js .rv.rv-right.in{opacity:1;transform:none}

/* ---------- SERVICE EXPERIENCE BLOCKS ---------- */
.svc-block{padding:clamp(64px,9vh,110px) 0;border-bottom:1px solid var(--line)}
.svc-grid{display:grid;grid-template-columns:1.04fr .96fr;align-items:center;gap:clamp(34px,5vw,84px);min-height:640px}
.svc-block.flip .svc-visual{order:2}
.svc-block.flip .svc-copy{order:1}
.svc-visual{position:relative}
.svc-frame{position:relative;overflow:hidden;border:1px solid var(--line);aspect-ratio:5/4;
  transition:border-color .6s var(--ease),box-shadow .6s var(--ease)}
.svc-frame img{width:100%;height:100%;object-fit:cover;filter:grayscale(.28) brightness(.74) contrast(1.05);
  transform:scale(1.04);transition:transform 1.2s var(--ease),filter .8s}
.svc-visual:hover .svc-frame{border-color:rgba(57,255,20,.45);box-shadow:0 30px 80px -30px rgba(57,255,20,.45)}
.svc-visual:hover .svc-frame img{transform:scale(1.1);filter:grayscale(0) brightness(.86)}
.svc-bignum{position:absolute;top:-26px;left:-10px;font-family:var(--f-mono);font-size:clamp(64px,8vw,120px);
  font-weight:700;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.12);z-index:2;letter-spacing:0}
.svc-block.flip .svc-bignum{left:auto;right:-10px}
.svc-tag{position:absolute;bottom:18px;left:18px;z-index:3;font-family:var(--f-mono);font-size:11px;
  letter-spacing:.05em;text-transform:uppercase;color:var(--volt);background:rgba(8,8,8,.6);
  backdrop-filter:blur(6px);border:1px solid var(--line-2);padding:8px 13px}

.svc-copy .eyebrow{margin-bottom:24px}
.svc-copy h2{font-size:clamp(30px,3.6vw,52px);font-weight:800;text-transform:uppercase;letter-spacing:.01em;line-height:1.0}
.svc-copy>p{color:#C3C6C0;font-size:clamp(15px,1.3vw,18px);line-height:1.62;margin-top:20px;max-width:50ch;text-wrap:pretty}
.svc-list{margin:30px 0 34px;border-top:1px solid var(--line);max-width:50ch}
.svc-list li{display:flex;align-items:center;gap:15px;padding:13px 0;border-bottom:1px solid var(--line);
  font-size:15.5px;color:var(--tx);list-style:none}
.svc-list li svg{width:18px;height:18px;color:var(--volt);flex:none}
.svc-list li b{font-weight:500}

/* ---------- STATS ---------- */
.stats{padding:clamp(86px,13vh,150px) 0;border-bottom:1px solid var(--line);background:var(--ink-2)}
.stats-head{margin-bottom:clamp(48px,7vh,80px)}
.stats-head h2{font-size:clamp(32px,4.6vw,64px);font-weight:800;text-transform:uppercase;letter-spacing:0;line-height:1;margin-top:22px}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:8px clamp(18px,2.4vw,40px) 8px 0;position:relative}
.stat+.stat{border-left:1px solid var(--line);padding-left:clamp(20px,2.4vw,42px)}
.stat .tick{width:0;height:2px;background:var(--volt);box-shadow:0 0 12px rgba(57,255,20,.7);margin-bottom:24px;transition:width .9s var(--ease)}
.stat.in .tick{width:42px}
.stat b{display:block;font-size:clamp(44px,6vw,92px);font-weight:800;letter-spacing:0;line-height:.95}
.stat span{display:block;font-family:var(--f-mono);font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--tx-mut);margin-top:16px}

/* ---------- BEFORE / AFTER ---------- */
.dba{background:linear-gradient(180deg,var(--ink),var(--ink-2));padding:clamp(86px,13vh,150px) 0;border-bottom:1px solid var(--line)}
.dba-head{margin-bottom:clamp(40px,6vh,64px)}
.dba-head h2{font-size:clamp(30px,4.4vw,60px);font-weight:800;text-transform:uppercase;letter-spacing:.01em;line-height:1;margin-top:22px}
.dba-head h2 em{font-style:normal;color:var(--volt)}
.dba .ba{aspect-ratio:21/9;border:1px solid var(--line-2)}
.dba .ba-cap{display:flex;justify-content:space-between;align-items:baseline;margin-top:18px;gap:18px;flex-wrap:wrap}
.dba .ba-cap b{font-size:17px;font-weight:700}
.dba .ba-cap span{font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--tx-faint)}

/* ---------- PROCESS (reuses .proc-wrap from site.css) ---------- */
.dprocess{padding:clamp(86px,13vh,150px) 0;border-bottom:1px solid var(--line)}

/* ---------- MASONRY PROJECTS ---------- */
.mproj{padding:clamp(86px,13vh,150px) 0;border-bottom:1px solid var(--line)}
.masonry{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:clamp(150px,19vw,220px);gap:16px}
.mcard{position:relative;overflow:hidden;border:1px solid var(--line);display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(22px,2.2vw,34px);isolation:isolate;transition:border-color .5s var(--ease),transform .55s var(--ease)}
.mcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;
  filter:grayscale(.32) brightness(.6) contrast(1.05);transform:scale(1.04);transition:transform 1.1s var(--ease),filter .7s}
.mcard::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(5,5,5,.05),rgba(5,5,5,.55) 55%,rgba(5,5,5,.92))}
.mcard:hover{border-color:rgba(57,255,20,.5);transform:translateY(-6px)}
.mcard:hover img{transform:scale(1.11);filter:grayscale(0) brightness(.72)}
.mcard .mcat{font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--volt);margin-bottom:10px}
.mcard h3{font-size:clamp(19px,1.8vw,26px);font-weight:700;letter-spacing:-.015em;line-height:1.15;text-wrap:pretty}
.mcard .mloc{display:flex;align-items:center;gap:7px;margin-top:12px;font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--tx-mut)}
.mcard .mloc svg{width:13px;height:13px;color:var(--volt)}
.m-a{grid-column:span 7;grid-row:span 2}
.m-b{grid-column:span 5;grid-row:span 2}
.m-c{grid-column:span 5;grid-row:span 2}
.m-d{grid-column:span 7;grid-row:span 2}
.mproj-foot{display:flex;justify-content:center;margin-top:clamp(40px,6vh,60px)}

/* ---------- POWERFUL CTA ---------- */
.dcta{position:relative;overflow:hidden;text-align:center;background:var(--ink)}
.dcta .glowfield{position:absolute;inset:0;z-index:0;background:radial-gradient(45% 55% at 50% 112%,rgba(57,255,20,.22),transparent 70%)}
.dcta .particles{position:absolute;inset:0;z-index:0;overflow:hidden}
.dcta .pt{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--volt);filter:blur(1px);opacity:.5;box-shadow:0 0 12px rgba(57,255,20,.8)}
.dcta .pt:nth-child(1){left:12%;bottom:-10px;animation:drift 13s linear infinite}
.dcta .pt:nth-child(2){left:28%;bottom:-10px;width:4px;height:4px;animation:drift 17s linear infinite 2s}
.dcta .pt:nth-child(3){left:46%;bottom:-10px;animation:drift 15s linear infinite 1s}
.dcta .pt:nth-child(4){left:63%;bottom:-10px;width:3px;height:3px;animation:drift 19s linear infinite 3s}
.dcta .pt:nth-child(5){left:78%;bottom:-10px;animation:drift 14s linear infinite 4s}
.dcta .pt:nth-child(6){left:90%;bottom:-10px;width:4px;height:4px;animation:drift 16s linear infinite 1.5s}
.dcta .pt:nth-child(7){left:38%;bottom:-10px;width:3px;height:3px;animation:drift 21s linear infinite 6s}
.dcta .pt:nth-child(8){left:55%;bottom:-10px;animation:drift 18s linear infinite 5s}
@keyframes drift{0%{transform:translateY(0);opacity:0}10%{opacity:.6}90%{opacity:.5}100%{transform:translateY(-104vh);opacity:0}}
.dcta-inner{position:relative;z-index:2;padding:clamp(90px,16vh,180px) 0}
.dcta-inner h2{font-size:clamp(32px,5.2vw,80px);font-weight:800;text-transform:uppercase;letter-spacing:0;line-height:.98;max-width:20ch;margin:24px auto 0}
.dcta-inner h2 em{font-style:normal;color:var(--volt)}
.dcta-inner .lead{margin:26px auto 0;text-align:center}
.dcta-actions{position:relative;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:42px}
.dcta-actions::before{content:"";position:absolute;inset:-40px -30px;background:radial-gradient(50% 80% at 50% 50%,rgba(57,255,20,.16),transparent 70%);z-index:-1;filter:blur(8px)}

/* ---------- RESPONSIVE - mobile first integrity ---------- */
@media(max-width:1000px){
  /* directional reveals would overflow the narrow gutter - use vertical reveal */
  .js .rv.rv-left,.js .rv.rv-right{transform:translateY(34px)}
  .js .rv.rv-left.in,.js .rv.rv-right.in{transform:none}
  .svc-grid{grid-template-columns:1fr;min-height:0;gap:30px}
  .svc-block .svc-visual,.svc-block.flip .svc-visual{order:1}
  .svc-block .svc-copy,.svc-block.flip .svc-copy{order:2}
  .svc-block.flip .svc-bignum{left:-10px;right:auto}
  .stats-row{grid-template-columns:1fr 1fr;gap:0}
  .stat{padding:clamp(22px,4vw,32px) clamp(16px,3vw,28px)}
  .stat:nth-child(3),.stat:nth-child(4){border-top:1px solid var(--line)}
  .stat:nth-child(odd){border-left:0;padding-left:0}
  .dba .ba{aspect-ratio:16/10}
  .masonry{grid-auto-rows:clamp(140px,26vw,200px)}
  .m-a,.m-b,.m-c,.m-d{grid-column:span 6}
}
@media(max-width:600px){
  .dhero-inner{padding-top:128px}
  .svc-frame{aspect-ratio:4/3}
  .svc-bignum{font-size:60px;top:-20px}
  .stats-row{grid-template-columns:1fr}
  .stat{border-left:0!important;padding-left:0!important;border-top:1px solid var(--line)}
  .stat:first-child{border-top:0}
  .stat b{font-size:clamp(48px,16vw,72px)}
  .masonry{grid-template-columns:1fr;grid-auto-rows:200px}
  .m-a,.m-b,.m-c,.m-d{grid-column:span 1}
  .dba .ba{aspect-ratio:3/4}
}
