/* ============================================================
   PJ KAPTEIN WOONSUPPORT - Projecten page
   Builds on css/site.css (same tokens / nav / footer / .rv / .ba)
   ============================================================ */

/* ---------- PAGE HERO ---------- */
.phero{
  position:relative;overflow:hidden;
  padding:clamp(150px,22vh,230px) 0 clamp(64px,9vh,110px);
  border-bottom:1px solid var(--line);
  background:radial-gradient(120% 130% at 80% -10%, #181818 0%, var(--ink) 55%);
}
.phero-grid{
  position:absolute;inset:0;z-index:0;opacity:.55;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:84px 84px;
  mask-image:radial-gradient(110% 90% at 78% 0%, #000 25%, transparent 72%);
}
.phero-inner{position:relative;z-index:2;max-width:62ch}
.phero h1{
  font-size:clamp(40px,6.4vw,88px);font-weight:800;text-transform:uppercase;
  letter-spacing:0;line-height:.96;margin-top:26px;
}
.phero h1 em{font-style:normal;color:var(--volt);text-shadow:0 0 50px rgba(57,255,20,.35)}
.accent-line{width:108px;height:3px;background:var(--volt);box-shadow:0 0 16px rgba(57,255,20,.7);margin:30px 0;
  animation:lineGrow 1s var(--ease) .42s forwards}
@keyframes lineGrow{from{width:0}to{width:108px}}
.phero p{color:#C7CAC4;font-size:clamp(16px,1.5vw,20px);line-height:1.62;max-width:56ch}
.phero-stats{display:flex;gap:clamp(26px,5vw,64px);margin-top:clamp(38px,6vh,60px);flex-wrap:wrap}
.phero-stats div b{display:block;font-size:clamp(24px,2.8vw,38px);font-weight:800;letter-spacing:0;line-height:1}
.phero-stats div span{font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--tx-mut);margin-top:8px;display:block}

/* phero entrance - translate-only rise (opacity stays 1 so content is never hidden if paused/export) */
.phero .eyebrow{animation:riseUp .85s var(--ease) .05s both}
.phero h1{animation:riseUp .95s var(--ease) .14s both}
.phero p{animation:riseUp .9s var(--ease) .32s both}
.phero-stats{animation:riseUp .9s var(--ease) .42s both}
@keyframes riseUp{from{transform:translateY(26px)}to{transform:translateY(0)}}

/* ---------- FEATURED CASE STUDY ---------- */
.case-sect{padding:clamp(80px,11vh,140px) 0;border-bottom:1px solid var(--line)}
.case{
  display:grid;grid-template-columns:1.25fr .85fr;gap:0;
  border:1px solid var(--line);background:var(--panel);overflow:hidden;
}
.case-media{position:relative;min-height:clamp(360px,46vw,620px);min-width:0}
.case-media .ba{position:absolute;inset:0;border:0;aspect-ratio:auto;height:100%}
.case-flag{
  position:absolute;top:20px;left:20px;z-index:6;display:flex;align-items:center;gap:10px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;
  background:rgba(8,8,8,.62);backdrop-filter:blur(6px);border:1px solid var(--line-2);padding:8px 13px;color:var(--volt)
}
.case-flag .d{width:7px;height:7px;border-radius:50%;background:var(--volt);box-shadow:0 0 10px var(--volt)}
.case-body{padding:clamp(32px,3.4vw,56px);display:flex;flex-direction:column;justify-content:center;min-width:0}
.case-body .eyebrow{margin-bottom:24px}
.case-body h2{font-size:clamp(28px,3vw,44px);font-weight:800;text-transform:uppercase;letter-spacing:.01em;line-height:1.02}
.case-loc{display:flex;align-items:center;gap:9px;margin-top:16px;color:var(--tx-mut);font-size:14.5px}
.case-loc svg{width:16px;height:16px;color:var(--volt)}
.case-specs{margin:30px 0;border-top:1px solid var(--line)}
.case-specs div{display:grid;grid-template-columns:140px 1fr;gap:18px;padding:15px 0;border-bottom:1px solid var(--line)}
.case-specs dt{font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--tx-faint);padding-top:2px}
.case-specs dd{font-size:15.5px;color:var(--tx);line-height:1.5}
.case-result{color:#C7CAC4;font-size:16px;line-height:1.62;margin-bottom:30px;text-wrap:pretty}
.case-result b{color:#fff;font-weight:600}

/* ---------- FILTER + GRID ---------- */
.work-sect{padding:clamp(80px,11vh,140px) 0}
.filterbar{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:clamp(34px,5vh,52px) 0 clamp(28px,4vh,42px);
  padding-bottom:22px;border-bottom:1px solid var(--line)
}
.fbtn{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  padding:11px 20px;border:1px solid var(--line-2);background:transparent;color:var(--tx-mut);
  cursor:pointer;border-radius:12px;transition:color .3s,border-color .3s,background .3s,transform .3s var(--ease)
}
.fbtn:hover{color:#fff;border-color:var(--line-2);transform:translateY(-1px)}
.fbtn.active{background:var(--volt);color:#06210A;border-color:var(--volt);box-shadow:0 10px 30px -12px rgba(57,255,20,.6)}
.fcount{margin-left:auto;font-family:var(--f-mono);font-size:12px;letter-spacing:.06em;color:var(--tx-faint)}
.fcount b{color:var(--volt)}

.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pcard{
  position:relative;display:flex;flex-direction:column;overflow:hidden;
  border:1px solid var(--line);background:var(--panel);
  transition:opacity .4s var(--ease),transform .45s var(--ease),border-color .45s var(--ease);
}
.pcard.out{opacity:0;transform:scale(.95) translateY(14px);pointer-events:none}
.pcard:hover{border-color:rgba(57,255,20,.45);transform:translateY(-6px)}
.pcard-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.pcard-media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3) brightness(.78) contrast(1.04);transition:transform 1s var(--ease),filter .6s}
.pcard:hover .pcard-media img{transform:scale(1.08);filter:grayscale(0) brightness(.9)}
.pcard-media::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 60% at 50% 130%,rgba(57,255,20,.26),transparent 70%);opacity:0;transition:opacity .5s}
.pcard:hover .pcard-media::after{opacity:1}
.pcat{
  position:absolute;top:14px;left:14px;z-index:3;font-family:var(--f-mono);font-size:10.5px;
  letter-spacing:.05em;text-transform:uppercase;padding:6px 11px;background:rgba(8,8,8,.66);
  backdrop-filter:blur(6px);border:1px solid var(--line-2);color:var(--volt)
}
.pcard-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.pcard-body h3{font-size:19px;font-weight:700;letter-spacing:-.015em;line-height:1.2;text-wrap:pretty}
.pcard-body p{color:var(--tx-mut);font-size:14px;line-height:1.55;margin-top:11px;flex:1;text-wrap:pretty}
.pcard-meta{display:flex;align-items:center;gap:12px;margin-top:20px;font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--tx-faint)}
.pcard-meta .mloc{display:flex;align-items:center;gap:6px}
.pcard-meta .mloc svg{width:13px;height:13px;color:var(--volt)}
.pcard-meta .dotsep{width:3px;height:3px;border-radius:50%;background:var(--tx-faint)}
.pcard-link{
  display:inline-flex;align-items:center;gap:10px;margin-top:22px;padding-top:18px;border-top:1px solid var(--line);
  font-family:var(--f-mono);font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--volt)
}
.pcard-link .ar{transition:transform .4s var(--ease)}
.pcard:hover .pcard-link .ar{transform:translateX(6px)}

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

/* ---------- PROCESS CTA ---------- */
.pcta{position:relative;overflow:hidden;text-align:center}
.pcta .glowfield{position:absolute;inset:0;z-index:0;background:radial-gradient(50% 65% at 50% 115%,rgba(57,255,20,.2),transparent 70%)}
.pcta .gridmove{position:absolute;inset:0;z-index:0;opacity:.4;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(80% 70% at 50% 50%,#000,transparent 75%);animation:gridfloat 18s linear infinite}
.pcta-inner{position:relative;z-index:2;padding:clamp(78px,13vh,150px) 0}
.pcta-inner h2{font-size:clamp(30px,4.6vw,66px);font-weight:800;text-transform:uppercase;letter-spacing:0;line-height:1;max-width:20ch;margin:24px auto 0}
.pcta-inner h2 em{font-style:normal;color:var(--volt)}
.pcta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:40px}
.pcta-phone{margin-top:30px;font-family:var(--f-mono);font-size:13px;color:var(--tx-mut)}
.pcta-phone a{color:#fff;border-bottom:1px solid var(--volt)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1000px){
  .case{grid-template-columns:1fr}
  .case-media{min-height:0;aspect-ratio:auto;height:clamp(300px,72vw,430px)}
  .pgrid{grid-template-columns:repeat(2,1fr)}
  .showcase .ba{aspect-ratio:16/10}
}
@media(max-width:640px){
  .pgrid{grid-template-columns:1fr}
  .filterbar{gap:8px}
  .fcount{width:100%;margin:6px 0 0 0;order:9}
  .case-specs div{grid-template-columns:110px 1fr;gap:12px}
  .showcase .ba{aspect-ratio:4/3}
}
