/* ============================================================
   PJ KAPTEIN WOONSUPPORT - Contact page
   Builds on css/site.css (tokens, nav, footer, .rv, buttons)
   ============================================================ */

/* ---------- Honeypot (spam trap, hidden from real users) ---------- */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}

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

/* ---------- CONTACT EXPERIENCE (split) ---------- */
.contact-x{padding:clamp(72px,10vh,130px) 0;border-bottom:1px solid var(--line)}
.cx-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(26px,4vw,64px);align-items:start}

/* form panel - glassmorphism */
.form-panel{position:relative;background:rgba(255,255,255,.025);backdrop-filter:blur(20px);
  border:1px solid var(--line-2);border-radius:24px;padding:clamp(34px,4vw,60px);min-width:0;overflow:hidden}
.form-panel::before{content:"";position:absolute;inset:0;border-radius:24px;padding:1px;
  background:linear-gradient(140deg,rgba(57,255,20,.35),transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.7}
.form-panel .eyebrow{margin-bottom:36px}
.form-panel h2{font-size:clamp(26px,2.6vw,38px);font-weight:800;letter-spacing:-.02em;line-height:1.05}
.form-trust{display:flex;flex-wrap:wrap;gap:12px 26px;list-style:none;padding:0;margin-top:22px}
.form-trust li{display:flex;align-items:center;gap:9px;font-family:var(--f-body);font-size:13.5px;color:var(--tx-mut)}
.form-trust li::before{content:"\2713";color:var(--volt);font-size:12px;font-weight:700}
.form-panel>p{color:var(--tx-mut);font-size:16px;line-height:1.6;margin-top:28px;margin-bottom:56px;max-width:38ch}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:26px 18px}
.field{display:flex;flex-direction:column;gap:12px;min-width:0}
.field.full{grid-column:1 / -1}
.field label{font-family:var(--f-body);font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--tx-faint)}
.field label .req{color:var(--volt)}
.field input,.field select,.field textarea{
  width:100%;min-width:0;box-sizing:border-box;
  background:rgba(255,255,255,.022);border:1px solid var(--line-2);border-radius:14px;
  padding:17px 18px;box-shadow:inset 0 2px 6px rgba(0,0,0,.25);
  padding:14px 15px;color:var(--tx);font-family:var(--f-disp);font-size:15px;
  transition:border-color .3s var(--ease),box-shadow .3s var(--ease),background .3s}
.field textarea{min-height:128px;resize:vertical;line-height:1.5}
.field input::placeholder,.field textarea::placeholder{color:var(--tx-faint)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--volt);background:rgba(57,255,20,.04);
  box-shadow:0 0 0 3px rgba(57,255,20,.14),0 0 30px -6px rgba(57,255,20,.4)}
.field.error input,.field.error select,.field.error textarea{border-color:#ff5a5a;box-shadow:0 0 0 3px rgba(255,90,90,.12)}
/* keep browser-autofilled fields on-theme (override Chrome/Safari white/blue fill) */
.field input:-webkit-autofill,
.field input:-webkit-autofill:hover,
.field input:-webkit-autofill:focus,
.field input:-webkit-autofill:active,
.field textarea:-webkit-autofill,
.field select:-webkit-autofill{
  -webkit-text-fill-color:#fff;
  caret-color:var(--volt);
  -webkit-box-shadow:0 0 0 1000px #14171a inset, 0 0 0 1px var(--line-2) inset;
  box-shadow:0 0 0 1000px #14171a inset, 0 0 0 1px var(--line-2) inset;
  transition:background-color 99999s ease-in-out 0s;
}
.field input:-webkit-autofill:focus{
  -webkit-box-shadow:0 0 0 1000px rgba(20,30,16,1) inset, 0 0 0 1px var(--volt) inset, 0 0 30px -6px rgba(57,255,20,.4);
  box-shadow:0 0 0 1000px rgba(20,30,16,1) inset, 0 0 0 1px var(--volt) inset, 0 0 30px -6px rgba(57,255,20,.4);
}
.err-msg{display:none;font-size:12px;color:#ff7676;font-family:var(--f-mono);letter-spacing:.02em}
.field.error .err-msg{display:block}
.selectwrap{position:relative}
.selectwrap::after{content:"";position:absolute;right:16px;top:50%;width:8px;height:8px;border-right:2px solid var(--tx-mut);border-bottom:2px solid var(--tx-mut);transform:translateY(-70%) rotate(45deg);pointer-events:none}
.field select{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:40px}
.field select option{background:#101010;color:#fff}
.checkrow{display:flex;align-items:flex-start;gap:13px;margin-top:6px;cursor:pointer}
.checkrow input{position:absolute;opacity:0;width:0;height:0}
.checkbox{flex:none;width:22px;height:22px;border:1px solid var(--line-2);border-radius:6px;display:grid;place-items:center;transition:.3s;margin-top:1px}
.checkbox svg{width:13px;height:13px;color:#06210A;opacity:0;transform:scale(.5);transition:.25s}
.checkrow input:checked+.checkbox{background:var(--volt);border-color:var(--volt)}
.checkrow input:checked+.checkbox svg{opacity:1;transform:scale(1)}
.checkrow input:focus-visible+.checkbox{box-shadow:0 0 0 3px rgba(57,255,20,.2)}
.checkrow span{font-size:14px;color:var(--tx-mut);line-height:1.45}
.form-actions{margin-top:26px}
.btn-submit{width:100%;justify-content:center;font-size:16px;padding:18px}
.btn-submit[disabled]{opacity:.7;cursor:wait}
.spinner{width:18px;height:18px;border:2px solid rgba(7,35,10,.35);border-top-color:#06210A;border-radius:50%;animation:spin .7s linear infinite;display:none}
.btn-submit.loading .spinner{display:block}
.btn-submit.loading .ar{display:none}
@keyframes spin{to{transform:rotate(360deg)}}
.form-foot{margin-top:16px;font-family:var(--f-mono);font-size:11px;letter-spacing:.04em;color:var(--tx-faint);text-align:center}

/* success state */
.form-success{display:none;flex-direction:column;align-items:center;text-align:center;padding:30px 10px}
.form-panel.sent .form-body{display:none}
.form-panel.sent .form-success{display:flex}
.succ-ring{width:84px;height:84px;border-radius:50%;background:rgba(57,255,20,.12);border:1px solid rgba(57,255,20,.5);display:grid;place-items:center;box-shadow:0 0 50px -10px rgba(57,255,20,.6);animation:pop .5s var(--ease) both}
.succ-ring svg{width:40px;height:40px;color:var(--volt);stroke-dasharray:40;stroke-dashoffset:40;animation:draw .6s var(--ease) .25s forwards}
@keyframes pop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes draw{to{stroke-dashoffset:0}}
.form-success h3{font-size:26px;font-weight:800;margin-top:24px;letter-spacing:-.02em;text-transform:uppercase}
.form-success p{color:var(--tx-mut);font-size:15px;line-height:1.6;margin-top:12px;max-width:36ch}
/* "back to homepage" button on the success state */
.succ-btn{display:inline-flex;align-items:center;justify-content:center;margin-top:30px;padding:15px 28px;border-radius:12px;background:var(--volt);color:#06210A;font-family:var(--f-disp);font-weight:700;font-size:14px;letter-spacing:.02em;text-decoration:none;transition:transform .3s var(--ease),box-shadow .35s var(--ease)}
.succ-btn:hover{transform:translateY(-2px);box-shadow:0 16px 44px -14px rgba(57,255,20,.7)}
/* staggered entrance of the success content (after the green border finishes drawing) */
.form-panel.sent .form-success h3{animation:fadeUp .55s var(--ease) .12s both}
.form-panel.sent .form-success p{animation:fadeUp .55s var(--ease) .26s both}
.form-panel.sent .succ-btn{animation:fadeUp .55s var(--ease) .4s both}
/* green line that draws around the form border on submit, before the success swap */
.form-beam{position:absolute;inset:0;z-index:7;pointer-events:none}
.form-beam rect{fill:none;stroke:var(--volt);stroke-width:2;filter:drop-shadow(0 0 6px rgba(57,255,20,.65))}

/* trust panel */
.trust-panel{padding-top:8px}
.trust-panel .eyebrow{margin-bottom:22px}
.trust-panel h2{font-size:clamp(26px,3vw,42px);font-weight:800;text-transform:uppercase;letter-spacing:.01em;line-height:1.02;margin-bottom:8px}
.tlist{margin-top:14px}
.titem{display:grid;grid-template-columns:auto 1fr;gap:20px;padding:24px 0;border-bottom:1px solid var(--line);align-items:start}
.titem:first-of-type{border-top:1px solid var(--line)}
.tnum{font-family:var(--f-mono);font-size:13px;color:var(--volt);padding-top:4px;letter-spacing:.08em}
.titem h4{font-size:clamp(17px,1.6vw,21px);font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:12px}
.titem h4::before{content:"";width:18px;height:1px;background:var(--volt);box-shadow:0 0 8px var(--volt);flex:none;opacity:0;transition:opacity .5s,width .5s}
.titem.in h4::before,.trust-panel .rv.in .titem h4::before{opacity:1}
.titem p{color:var(--tx-mut);font-size:14.5px;line-height:1.55;margin-top:8px}

/* ---------- DIRECT CONTACT CARDS ---------- */
.direct{padding:clamp(80px,11vh,140px) 0;border-bottom:1px solid var(--line)}
.dc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:clamp(40px,6vh,60px)}
.dc-card{position:relative;display:flex;flex-direction:column;justify-content:space-between;gap:40px;
  min-height:300px;padding:clamp(26px,2.6vw,38px);border:1px solid var(--line);background:var(--panel);
  overflow:hidden;transition:transform .5s var(--ease),border-color .5s,background .5s}
.dc-card::before{content:"";position:absolute;left:0;top:0;height:2px;width:0;background:var(--volt);box-shadow:0 0 12px var(--volt);transition:width .5s var(--ease)}
.dc-card::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 50% at 50% 120%,rgba(57,255,20,.18),transparent 70%);opacity:0;transition:opacity .5s;pointer-events:none}
.dc-card:hover{transform:translateY(-6px);border-color:rgba(57,255,20,.4);background:var(--panel-2)}
.dc-card:hover::before{width:100%}
.dc-card:hover::after{opacity:1}
.dc-top{display:flex;align-items:center;justify-content:space-between}
.dc-label{font-family:var(--f-mono);font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--tx-mut)}
.dc-ic{width:44px;height:44px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;color:var(--volt);transition:transform .5s var(--ease),background .4s,border-color .4s}
.dc-card:hover .dc-ic{transform:scale(1.08) rotate(-8deg);background:rgba(57,255,20,.1);border-color:var(--volt)}
.dc-ic svg{width:22px;height:22px}
.dc-card .dc-val{font-size:clamp(22px,2.2vw,30px);font-weight:800;letter-spacing:-.02em;line-height:1.1;word-break:break-word}
.dc-card .dc-sub{color:var(--tx-mut);font-size:14px;margin-top:8px}
.dc-cta{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--volt);margin-top:18px}
.dc-cta .ar{transition:transform .4s var(--ease)}
.dc-card:hover .dc-cta .ar{transform:translateX(6px)}
.wa-pulse{position:relative}
.wa-pulse::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(57,255,20,.5);animation:waring 2.4s ease-out infinite}
@keyframes waring{0%{transform:scale(.7);opacity:.8}100%{transform:scale(1.5);opacity:0}}

/* ---------- SERVICE AREA (custom map) ---------- */
.area{padding:clamp(80px,11vh,140px) 0;border-bottom:1px solid var(--line);background:var(--ink-2)}
.area-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(34px,5vw,72px);align-items:center}
.area-copy h2{font-size:clamp(28px,3.4vw,48px);font-weight:800;text-transform:uppercase;letter-spacing:.01em;line-height:1.02;margin-top:20px}
.area-copy p{color:var(--tx-mut);font-size:clamp(15px,1.3vw,18px);line-height:1.62;margin-top:20px;max-width:46ch}
.area-cities{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.area-cities span{font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;color:var(--tx-mut);border:1px solid var(--line);padding:8px 13px;border-radius:40px;transition:.3s}
.area-cities span.hub{color:#06210A;background:var(--volt);border-color:var(--volt)}
.mapwrap{position:relative;aspect-ratio:1/1;border:1px solid var(--line);background:
  radial-gradient(120% 120% at 50% 40%,#161616,#0a0a0a);overflow:hidden;border-radius:18px}
.mapdots{position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.16) 1.3px,transparent 1.3px);
  background-size:22px 22px;
  -webkit-mask:radial-gradient(70% 70% at 52% 44%,#000 38%,transparent 72%);
  mask:radial-gradient(70% 70% at 52% 44%,#000 38%,transparent 72%)}
.hub-node{position:absolute;left:52%;top:44%;transform:translate(-50%,-50%);z-index:3}
.hub-dot{width:16px;height:16px;border-radius:50%;background:var(--volt);box-shadow:0 0 24px 4px rgba(57,255,20,.8);position:relative;z-index:2}
.hub-ring{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;border:1.5px solid var(--volt)}
.hub-ring.r1{animation:hubpulse 3s ease-out infinite}
.hub-ring.r2{animation:hubpulse 3s ease-out infinite 1s}
.hub-ring.r3{animation:hubpulse 3s ease-out infinite 2s}
@keyframes hubpulse{0%{transform:translate(-50%,-50%) scale(1);opacity:.9}100%{transform:translate(-50%,-50%) scale(11);opacity:0}}
.hub-label{position:absolute;left:18px;top:-6px;white-space:nowrap;font-family:var(--f-mono);font-size:12px;letter-spacing:.1em;color:#fff;text-shadow:0 1px 6px #000}
.pin{position:absolute;width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.55);transform:translate(-50%,-50%)}
.pin span{position:absolute;left:11px;top:-7px;font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;color:var(--tx-mut);white-space:nowrap}
/* positioned by real compass direction from Amsterdam (hub ~52%/44%):
   Purmerend=N, Zaandam=NW, Haarlem=W, Amstelveen=S, Almere=E */
.pin.p1{left:60%;top:19%}   /* Purmerend - noord */
.pin.p2{left:15%;top:47%}   /* Haarlem - west */
.pin.p3{left:85%;top:49%}   /* Almere - oost */
.pin.p4{left:33%;top:29%}   /* Zaandam - noordwest */
.pin.p5{left:47%;top:71%}   /* Amstelveen - zuid */

/* ---------- FAST RESPONSE ---------- */
.fast{position:relative;overflow:hidden;text-align:center;padding:clamp(80px,13vh,150px) 0;border-bottom:1px solid var(--line)}
.fast .particles,.fcta .particles{position:absolute;inset:0;z-index:0;overflow:hidden}
.fast .pt,.fcta .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)}
.fast .pt:nth-child(1),.fcta .pt:nth-child(1){left:14%;bottom:-10px;animation:rise 14s linear infinite}
.fast .pt:nth-child(2),.fcta .pt:nth-child(2){left:30%;bottom:-10px;width:3px;height:3px;animation:rise 18s linear infinite 2s}
.fast .pt:nth-child(3),.fcta .pt:nth-child(3){left:48%;bottom:-10px;animation:rise 16s linear infinite 1s}
.fast .pt:nth-child(4),.fcta .pt:nth-child(4){left:64%;bottom:-10px;width:3px;height:3px;animation:rise 20s linear infinite 3s}
.fast .pt:nth-child(5),.fcta .pt:nth-child(5){left:80%;bottom:-10px;animation:rise 15s linear infinite 4s}
.fast .pt:nth-child(6),.fcta .pt:nth-child(6){left:90%;bottom:-10px;width:4px;height:4px;animation:rise 17s linear infinite 1.5s}
.fast .pt:nth-child(7),.fcta .pt:nth-child(7){left:38%;bottom:-10px;width:3px;height:3px;animation:rise 22s linear infinite 6s}
.fast .pt:nth-child(8),.fcta .pt:nth-child(8){left:55%;bottom:-10px;animation:rise 19s linear infinite 5s}
@keyframes rise{0%{transform:translateY(0);opacity:0}10%{opacity:.6}90%{opacity:.5}100%{transform:translateY(-104vh);opacity:0}}
.fast-inner{position:relative;z-index:2}
.fast .accent-line{width:0;height:2px;background:var(--volt);box-shadow:0 0 12px var(--volt);margin:0 auto 30px}
.fast.in .accent-line{width:90px;transition:width 1s var(--ease)}
.fast h2{font-size:clamp(30px,5vw,72px);font-weight:800;text-transform:uppercase;letter-spacing:0;line-height:1;max-width:18ch;margin:0 auto}
.fast h2 em{font-style:normal;color:var(--volt)}
.fast p{color:var(--tx-mut);font-size:clamp(15px,1.3vw,18px);margin-top:24px}

/* ---------- FAQ ---------- */
.faq{padding:clamp(80px,11vh,140px) 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}

/* ---------- FINAL CTA ---------- */
.fcta{position:relative;overflow:hidden;text-align:center;background:var(--ink)}
.fcta .glowfield{position:absolute;inset:0;z-index:0;background:radial-gradient(46% 56% at 50% 112%,rgba(57,255,20,.2),transparent 70%)}
.fcta-inner{position:relative;z-index:2;padding:clamp(90px,16vh,180px) 0}
.fcta-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}
.fcta-inner h2 em{font-style:normal;color:var(--volt)}
.fcta-actions{position:relative;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:42px}
.fcta-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){
  .cx-grid{grid-template-columns:1fr;gap:44px}
  .dc-grid{grid-template-columns:1fr;gap:14px}
  .dc-card{min-height:0;gap:28px}
  .area-grid{grid-template-columns:1fr;gap:40px}
  .mapwrap{max-width:480px;margin:0 auto;width:100%}
}
@media(max-width:560px){
  .chero-inner{padding-top:128px}
  .fgrid{grid-template-columns:1fr}
  .form-panel{padding:22px 18px;border-radius:18px}
  .faq-q{font-size:17px;gap:16px}
}
