/* ============================================================
   PJ KAPTEIN WOONSUPPORT - Service landing pages (shared)
   Used by /diensten/*.html - builds on ../css/site.css
   (tokens, nav, footer, .rv, .ba slider, .proc-wrap, buttons)
   ============================================================ */

/* ---------- HERO ---------- */
.shero{position:relative;min-height:96svh;display:flex;align-items:flex-end;overflow:hidden}
.shero-inner{position:relative;z-index:3;width:100%;padding:150px 0 clamp(50px,8vh,92px)}
.shero .crumbs{font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--tx-mut);margin-bottom:26px;display:flex;gap:10px;align-items:center;animation:sRise .7s var(--ease) .05s both}
.shero .crumbs a{color:var(--tx-mut)}.shero .crumbs a:hover{color:var(--volt)}
.shero .crumbs .sep{color:var(--volt)}
.shero h1{font-size:clamp(40px,7.4vw,108px);font-weight:900;text-transform:uppercase;letter-spacing:0;line-height:.9;max-width:18ch;animation:sRise .95s var(--ease) .16s both}
.shero h1 em{font-style:normal;color:var(--volt);text-shadow:0 0 60px rgba(57,255,20,.4)}
.shero .accent-line{width:0;height:3px;background:var(--volt);box-shadow:0 0 16px rgba(57,255,20,.7);margin:30px 0;animation:sGrow 1.1s var(--ease) .5s forwards}
.shero-sub{max-width:58ch;color:#CCD0CA;font-size:clamp(16px,1.5vw,20px);line-height:1.6;animation:sRise .9s var(--ease) .4s both}
.shero-actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:38px;animation:sRise .9s var(--ease) .54s both}
@keyframes sRise{from{transform:translateY(28px)}to{transform:translateY(0)}}
@keyframes sGrow{from{width:0}to{width:120px}}
.shero-stats{display:flex;gap:clamp(26px,5vw,68px);margin-top:clamp(40px,6vh,64px);padding-top:28px;border-top:1px solid var(--line);flex-wrap:wrap;animation:sRise .9s var(--ease) .66s both}
.shero-stats div b{display:block;font-size:clamp(26px,3vw,40px);font-weight:800;letter-spacing:0;line-height:1}
.shero-stats div span{display:block;font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--tx-mut);margin-top:8px}

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

/* ---------- INTRO / WHY ---------- */
.sintro{padding:clamp(80px,12vh,150px) 0;border-bottom:1px solid var(--line)}
.sintro-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center}
.sintro.media .sintro-grid{grid-template-columns:1fr 1.05fr}
.sintro-copy .eyebrow{margin-bottom:24px}
.sintro-copy h2{font-size:clamp(30px,4vw,58px);font-weight:800;text-transform:uppercase;letter-spacing:0;line-height:1.0}
.sintro-copy h2 em{font-style:normal;color:var(--volt)}
.sintro-copy p{color:#C3C6C0;font-size:clamp(15px,1.35vw,18.5px);line-height:1.68;margin-top:22px;max-width:50ch;text-wrap:pretty}
.sintro-copy p+p{margin-top:16px}
.sintro-figure{position:relative;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/5;min-width:0}
.sintro-figure img{width:100%;height:100%;object-fit:cover;filter:grayscale(.25) contrast(1.05) brightness(.82);transform:scale(1.03);transition:transform 1.2s var(--ease)}
.sintro-figure:hover img{transform:scale(1.09)}
.sintro-figure .badge{position:absolute;left:-1px;bottom:-1px;background:var(--volt);color:#06210A;padding:18px 22px;max-width:240px}
.sintro-figure .badge b{display:block;font-size:28px;font-weight:800;letter-spacing:0;line-height:1}
.sintro-figure .badge span{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;margin-top:6px;display:block}

/* ---------- SERVICE DETAIL LIST ---------- */
.sdetail{padding:clamp(80px,12vh,150px) 0;border-bottom:1px solid var(--line);background:var(--ink-2)}
.srow{display:grid;grid-template-columns:96px 1fr auto;gap:clamp(20px,3vw,48px);align-items:start;
  padding:clamp(28px,4vh,44px) 0;border-bottom:1px solid var(--line)}
.srow:first-of-type{border-top:1px solid var(--line)}
.srow .snum{font-family:var(--f-mono);font-size:14px;color:var(--volt);letter-spacing:.06em;padding-top:6px}
.srow h3{font-size:clamp(22px,2.4vw,34px);font-weight:800;text-transform:uppercase;letter-spacing:-.02em;line-height:1.04}
.srow p{color:var(--tx-mut);font-size:15.5px;line-height:1.6;margin-top:12px;max-width:54ch;text-wrap:pretty}
.srow .sarrow{width:46px;height:46px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;color:var(--volt);transition:.45s var(--ease);align-self:center}
.srow:hover .sarrow{background:rgba(57,255,20,.1);border-color:var(--volt);transform:translateX(6px)}
.srow .sarrow svg{width:20px;height:20px}

/* ---------- BEFORE / AFTER ---------- */
.sba{padding:clamp(80px,12vh,150px) 0;border-bottom:1px solid var(--line)}
.sba-head{margin-bottom:clamp(38px,5vh,56px)}
.sba-head h2{font-size:clamp(30px,4.2vw,58px);font-weight:800;text-transform:uppercase;letter-spacing:.01em;line-height:1;margin-top:20px}
.sba-head h2 em{font-style:normal;color:var(--volt)}
.sba .ba{aspect-ratio:21/9;border:1px solid var(--line-2)}
.sba .ba-cap{display:flex;justify-content:space-between;align-items:baseline;margin-top:18px;gap:18px;flex-wrap:wrap}
.sba .ba-cap b{font-size:17px;font-weight:700}
.sba .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) ---------- */
.sproc{padding:clamp(80px,12vh,150px) 0;border-bottom:1px solid var(--line);background:var(--ink-2)}

/* ---------- PROJECTS MASONRY ---------- */
.sproj{padding:clamp(80px,12vh,150px) 0;border-bottom:1px solid var(--line)}
.smasonry{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:clamp(150px,19vw,220px);gap:16px}
.scard{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)}
.scard 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}
.scard::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))}
.scard:hover{border-color:rgba(57,255,20,.5);transform:translateY(-6px)}
.scard:hover img{transform:scale(1.11);filter:grayscale(0) brightness(.72)}
.scard .scat{font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--volt);margin-bottom:10px}
.scard h3{font-size:clamp(18px,1.7vw,24px);font-weight:700;letter-spacing:-.015em;line-height:1.15;text-wrap:pretty}
.scard .sloc{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)}
.scard .sloc svg{width:13px;height:13px;color:var(--volt)}
.sa{grid-column:span 7;grid-row:span 2}.sb{grid-column:span 5;grid-row:span 2}
.sc{grid-column:span 5;grid-row:span 2}.sd{grid-column:span 7;grid-row:span 2}
.sproj-foot{display:flex;justify-content:center;margin-top:clamp(40px,6vh,60px)}

/* ---------- FAQ ---------- */
.sfaq{padding:clamp(80px,12vh,150px) 0;border-bottom:1px solid var(--line)}
.faq-list{margin-top:clamp(36px,5vh,52px);border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:0;cursor:pointer;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:clamp(22px,3vh,30px) 0;color:var(--tx);font-family:var(--f-disp);font-size:clamp(17px,1.7vw,23px);font-weight:600;letter-spacing:-.01em;transition:color .3s}
.faq-q:hover{color:#fff}
.faq-ic{flex:none;width:34px;height:34px;border:1px solid var(--line-2);border-radius:50%;position:relative;transition:.4s var(--ease)}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;left:50%;top:50%;background:var(--volt);transition:.4s var(--ease)}
.faq-ic::before{width:12px;height:2px;transform:translate(-50%,-50%)}
.faq-ic::after{width:2px;height:12px;transform:translate(-50%,-50%)}
.faq-item.open .faq-ic{background:rgba(57,255,20,.12);border-color:var(--volt);transform:rotate(180deg)}
.faq-item.open .faq-ic::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.faq-a p{color:var(--tx-mut);font-size:15.5px;line-height:1.65;padding-bottom:clamp(22px,3vh,30px);max-width:64ch}

/* ---------- CTA ---------- */
.scta{position:relative;overflow:hidden;text-align:center;background:var(--ink)}
.scta .glowfield{position:absolute;inset:0;z-index:0;background:radial-gradient(46% 56% at 50% 112%,rgba(57,255,20,.2),transparent 70%)}
.scta .particles{position:absolute;inset:0;z-index:0;overflow:hidden}
.scta .pt{position:absolute;width:5px;height:5px;border-radius:50%;background:var(--volt);filter:blur(1px);opacity:.5;box-shadow:0 0 12px rgba(57,255,20,.8)}
.scta .pt:nth-child(1){left:16%;bottom:-10px;animation:srise 14s linear infinite}
.scta .pt:nth-child(2){left:32%;bottom:-10px;width:3px;height:3px;animation:srise 18s linear infinite 2s}
.scta .pt:nth-child(3){left:50%;bottom:-10px;animation:srise 16s linear infinite 1s}
.scta .pt:nth-child(4){left:66%;bottom:-10px;width:3px;height:3px;animation:srise 20s linear infinite 3s}
.scta .pt:nth-child(5){left:82%;bottom:-10px;animation:srise 15s linear infinite 4s}
.scta .pt:nth-child(6){left:90%;bottom:-10px;width:4px;height:4px;animation:srise 17s linear infinite 1.5s}
@keyframes srise{0%{transform:translateY(0);opacity:0}10%{opacity:.6}90%{opacity:.5}100%{transform:translateY(-104vh);opacity:0}}
.scta-inner{position:relative;z-index:2;padding:clamp(90px,16vh,180px) 0}
.scta-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}
.scta-inner h2 em{font-style:normal;color:var(--volt)}
.scta-inner .lead{margin:24px auto 0;text-align:center;color:var(--tx-mut)}
.scta-actions{position:relative;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:42px}
.scta-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 ---------- */
@media(max-width:1000px){
  .js .rv.rv-left,.js .rv.rv-right{transform:translateY(34px)}
  .js .rv.rv-left.in,.js .rv.rv-right.in{transform:none}
  .sintro-grid,.sintro.media .sintro-grid{grid-template-columns:1fr;gap:40px}
  .sintro-figure{max-width:460px;aspect-ratio:4/3}
  .sba .ba{aspect-ratio:16/10}
  .smasonry{grid-auto-rows:clamp(140px,26vw,200px)}
  .sa,.sb,.sc,.sd{grid-column:span 6}
}
@media(max-width:600px){
  .shero-inner{padding-top:128px}
  .srow{grid-template-columns:1fr;gap:6px}
  .srow .snum{padding-top:0}
  .srow .sarrow{display:none}
  .smasonry{grid-template-columns:1fr;grid-auto-rows:200px}
  .sa,.sb,.sc,.sd{grid-column:span 1}
  .sba .ba{aspect-ratio:3/4}
}
