/* ============================================================
   PJ KAPTEIN WOONSUPPORT - Over ons (About)
   Builds on css/site.css (tokens, nav, footer, .rv, .proc-wrap, counters)
   ============================================================ */

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

/* ---------- STORY (split) ---------- */
.ostory{padding:clamp(80px,12vh,150px) 0;border-bottom:1px solid var(--line)}
.ostory-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,90px);align-items:center}
.ostory-media{position:relative;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/5;min-width:0}
.ostory-media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.35) contrast(1.08) brightness(.82);transform:scale(1.04);transition:transform 1.3s var(--ease),filter .8s}
.ostory-media:hover img{transform:scale(1.1);filter:grayscale(0) brightness(.9)}
.ostory-media .tagline{position:absolute;left:18px;bottom:18px;z-index:2;font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:#fff;background:rgba(8,8,8,.6);backdrop-filter:blur(6px);border:1px solid var(--line-2);padding:9px 14px;text-shadow:0 1px 6px #000}
.ostory-copy .eyebrow{margin-bottom:24px}
.ostory-copy h2{font-size:clamp(30px,4vw,58px);font-weight:800;text-transform:uppercase;letter-spacing:0;line-height:1.0}
.ostory-copy h2 em{font-style:normal;color:var(--volt)}
.ostory-copy p{color:#C3C6C0;font-size:clamp(16px,1.4vw,19px);line-height:1.7;margin-top:24px;max-width:52ch;text-wrap:pretty}
.ostory-copy .sig{margin-top:34px;display:flex;align-items:center;gap:16px}
.ostory-copy .sig b{display:block;font-weight:700;font-size:16px;color:#fff}
/* only the role line - NOT the .brand-mark span */
.ostory-copy .sig b + span{display:block;font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--tx-mut);margin-top:5px;font-weight:400}
.ostory-copy .sig .brand-mark{flex:none;width:50px;height:50px}

/* ---------- PHILOSOPHY ---------- */
.ophil{padding:clamp(86px,13vh,160px) 0;border-bottom:1px solid var(--line);background:var(--ink-2)}
.ophil .eyebrow{margin-bottom:clamp(40px,6vh,64px)}
.ophil-word{display:flex;align-items:center;gap:clamp(18px,3vw,44px);padding:clamp(14px,2.2vh,26px) 0;border-bottom:1px solid var(--line)}
.ophil-word:first-of-type{border-top:1px solid var(--line)}
.ophil-num{font-family:var(--f-mono);font-size:13px;color:var(--volt);letter-spacing:.06em;flex:none;width:42px}
.ophil-line{height:2px;background:var(--volt);box-shadow:0 0 10px var(--volt);width:0;flex:none;transition:width .9s var(--ease)}
.ophil-word.in .ophil-line{width:clamp(26px,5vw,80px)}
.ophil-word h3{font-size:clamp(28px,7vw,104px);font-weight:900;text-transform:uppercase;letter-spacing:0;line-height:.92;color:#fff;transition:color .5s;overflow-wrap:break-word;word-break:break-word;min-width:0}
.ophil-word:hover h3{color:var(--volt)}

/* ---------- HOW WE WORK (reuses .proc-wrap) ---------- */
.owork{padding:clamp(80px,12vh,150px) 0;border-bottom:1px solid var(--line)}

/* ---------- TRUST STATS ---------- */
.otrust{position:relative;overflow:hidden;padding:clamp(86px,13vh,160px) 0;border-bottom:1px solid var(--line);background:var(--ink)}
.otrust .particles{position:absolute;inset:0;z-index:0;overflow:hidden}
.otrust .pt{position:absolute;width:5px;height:5px;border-radius:50%;background:var(--volt);filter:blur(1px);opacity:.45;box-shadow:0 0 12px rgba(57,255,20,.8)}
.otrust .pt:nth-child(1){left:12%;bottom:-10px;animation:oFloat 15s linear infinite}
.otrust .pt:nth-child(2){left:30%;bottom:-10px;width:3px;height:3px;animation:oFloat 19s linear infinite 2s}
.otrust .pt:nth-child(3){left:48%;bottom:-10px;animation:oFloat 16s linear infinite 1s}
.otrust .pt:nth-child(4){left:66%;bottom:-10px;width:3px;height:3px;animation:oFloat 21s linear infinite 3s}
.otrust .pt:nth-child(5){left:82%;bottom:-10px;animation:oFloat 15s linear infinite 4s}
.otrust .pt:nth-child(6){left:92%;bottom:-10px;width:4px;height:4px;animation:oFloat 18s linear infinite 1.5s}
@keyframes oFloat{0%{transform:translateY(0);opacity:0}10%{opacity:.5}90%{opacity:.45}100%{transform:translateY(-104vh);opacity:0}}
.otrust-inner{position:relative;z-index:2}
.otrust-head{max-width:30ch;margin-bottom:clamp(48px,7vh,80px)}
.otrust-head h2{font-size:clamp(30px,4.2vw,58px);font-weight:800;text-transform:uppercase;letter-spacing:0;line-height:1.02;margin-top:20px}
.ostats{display:grid;grid-template-columns:repeat(4,1fr)}
.ostat{padding:8px clamp(18px,2.4vw,40px) 8px 0;position:relative}
.ostat+.ostat{border-left:1px solid var(--line);padding-left:clamp(20px,2.4vw,42px)}
.ostat .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)}
.ostat.in .tick{width:42px}
.ostat b{display:block;font-size:clamp(40px,5.4vw,84px);font-weight:800;letter-spacing:0;line-height:.95}
.ostat span{display:block;font-family:var(--f-mono);font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--tx-mut);margin-top:16px}

/* ---------- CRAFTSMANSHIP SHOWCASE ---------- */
.ocraft{padding:clamp(80px,12vh,150px) 0;border-bottom:1px solid var(--line);background:var(--ink-2)}
.ocraft-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;margin-bottom:clamp(36px,5vh,52px)}
.ocraft-head h2{font-size:clamp(26px,3.4vw,46px);font-weight:800;text-transform:uppercase;letter-spacing:.01em;line-height:1.05;max-width:20ch}
.ocraft-head h2 em{font-style:normal;color:var(--volt)}
.ocraft-head .hint{font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--tx-faint);display:flex;align-items:center;gap:10px}
.ocraft-strip{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:14px;
  scrollbar-width:none;scrollbar-color:rgba(255,255,255,.18) transparent;-webkit-overflow-scrolling:touch}
.ocraft-strip::-webkit-scrollbar{height:0;display:none}.ocraft-strip::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:12px}
.ocraft-card{position:relative;flex:0 0 clamp(280px,42vw,520px);aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);scroll-snap-align:start}
.ocraft-card img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3) brightness(.74) contrast(1.05);transform:scale(1.05);transition:transform 1.2s var(--ease),filter .8s}
.ocraft-card:hover img{transform:scale(1.12);filter:grayscale(0) brightness(.86)}
.ocraft-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(5,5,5,.85));pointer-events:none}
.ocraft-card span{position:absolute;left:20px;bottom:18px;z-index:2;font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:#fff;text-shadow:0 1px 8px #000}

/* ---------- CLIENT PROMISE ---------- */
.opromise{padding:clamp(100px,16vh,200px) 0;border-bottom:1px solid var(--line);text-align:center}
.opromise .eyebrow{justify-content:center;margin-bottom:34px}
.opromise h2{font-size:clamp(28px,4.6vw,68px);font-weight:800;text-transform:uppercase;letter-spacing:0;line-height:1.06;max-width:22ch;margin:0 auto;text-wrap:balance}
.opromise h2 .uline{position:relative;display:inline-block}
.opromise h2 .uline::after{content:"";position:absolute;left:0;bottom:-.08em;height:4px;width:0;background:var(--volt);box-shadow:0 0 14px var(--volt);transition:width 1.1s var(--ease) .25s}
.opromise h2.in .uline::after{width:100%}

/* ---------- FINAL CTA ---------- */
.octa{position:relative;overflow:hidden;text-align:center;background:var(--ink)}
.octa .glowfield{position:absolute;inset:0;z-index:0;background:radial-gradient(46% 56% at 50% 112%,rgba(57,255,20,.2),transparent 70%)}
.octa .particles{position:absolute;inset:0;z-index:0;overflow:hidden}
.octa .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)}
.octa .pt:nth-child(1){left:16%;bottom:-10px;animation:oFloat 14s linear infinite}
.octa .pt:nth-child(2){left:34%;bottom:-10px;width:3px;height:3px;animation:oFloat 18s linear infinite 2s}
.octa .pt:nth-child(3){left:50%;bottom:-10px;animation:oFloat 16s linear infinite 1s}
.octa .pt:nth-child(4){left:66%;bottom:-10px;width:3px;height:3px;animation:oFloat 20s linear infinite 3s}
.octa .pt:nth-child(5){left:82%;bottom:-10px;animation:oFloat 15s linear infinite 4s}
.octa .pt:nth-child(6){left:90%;bottom:-10px;width:4px;height:4px;animation:oFloat 17s linear infinite 1.5s}
.octa-inner{position:relative;z-index:2;padding:clamp(90px,16vh,180px) 0}
.octa-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}
.octa-inner h2 em{font-style:normal;color:var(--volt)}
.octa-actions{position:relative;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:42px}
.octa-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){
  .ostory-grid{grid-template-columns:1fr;gap:40px}
  .ostory-media{max-width:460px;aspect-ratio:4/3}
  .ostats{grid-template-columns:1fr 1fr;gap:0}
  .ostat{padding:clamp(22px,4vw,32px) clamp(16px,3vw,28px)}
  .ostat:nth-child(3),.ostat:nth-child(4){border-top:1px solid var(--line)}
  .ostat:nth-child(odd){border-left:0;padding-left:0}
}
@media(max-width:600px){
  .ohero-inner{padding-top:128px}
  .ophil-word{gap:14px}
  .ophil-num{width:30px;font-size:11px}
  .ostats{grid-template-columns:1fr}
  .ostat{border-left:0!important;padding-left:0!important;border-top:1px solid var(--line)}
  .ostat:first-child{border-top:0}
  .ostat b{font-size:clamp(46px,15vw,72px)}
  .ocraft-card{flex-basis:78vw}
}
