/* ════════════════════════════════════════════════════════════
   SolidMotion - subpagina's (cases, over-ons, contact)
   Bouwt voort op mono.css; eigen werk in de vaste stijl.
   ════════════════════════════════════════════════════════════ */

/* ───── CASE ───── */
.cs__hero{padding:clamp(7rem,15vh,10rem) var(--gut) 0}
.cs__meta{display:flex;align-items:center;gap:1rem;margin-bottom:clamp(1.4rem,3.5vh,2.2rem)}
.cs__idx{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#8a877e}
.cs__idx b{border:1px solid rgba(236,233,225,.3);padding:.05rem .35rem;border-radius:3px;margin-left:.3rem;color:#b8b5aa;font-weight:500}
.cs__title{font-family:var(--display);font-weight:700;font-size:clamp(2.6rem,7.2vw,7rem);line-height:1.02;letter-spacing:-.025em;color:#ece9e1;max-width:14ch;margin:0 0 clamp(1.6rem,4vh,2.6rem)}
.cs__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:clamp(2rem,5vh,3.2rem)}
.cs__tags span{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:#b8b5aa;border:1px solid rgba(236,233,225,.22);padding:.3rem .6rem;border-radius:3px}
.cs__cover{margin:0 calc(-1*var(--gut));overflow:hidden;background:#11100d}
.cs__cover img,.cs__cover video{width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;display:block}
/* details: KLANT / CATEGORIE / DIENSTEN / RESULTAAT (referentie-anatomie) */
.cs__details{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;padding:clamp(2.2rem,5vh,3.4rem) var(--gut);border-bottom:1px solid var(--line-2)}
.cs__detail .label{display:block;margin-bottom:.55rem}
.cs__detail p{font-family:var(--sans);font-weight:600;font-size:clamp(.98rem,1.2vw,1.15rem);color:#ece9e1;line-height:1.4}
.cs__detail.is-hl p{color:var(--blue)}
/* samenvatting: kop links, tekst rechts */
.cs__sum{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:clamp(2rem,6vw,6rem);padding:clamp(4rem,10vh,7rem) var(--gut)}
.cs__sum h2{font-family:var(--sans);font-weight:500;font-size:clamp(1.8rem,3.4vw,3.3rem);line-height:1.08;letter-spacing:-.02em;color:#ece9e1;max-width:16ch}
.cs__sum-txt p{color:#a5a298;font-size:clamp(1rem,1.15vw,1.15rem);line-height:1.6;max-width:56ch}
.cs__sum-txt p+p{margin-top:1.1em}
.cs__sum-txt .cs__lead{color:#ece9e1;font-weight:500;font-size:clamp(1.1rem,1.4vw,1.35rem);line-height:1.45}
/* stats */
.cs__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:2rem;padding:clamp(2.6rem,6vh,4rem) var(--gut);border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
.cs__stat dt{font-family:var(--display);font-weight:800;font-size:clamp(2.2rem,4.2vw,4rem);line-height:.95;letter-spacing:-.03em;color:#ece9e1}
.cs__stat dd{margin:.6rem 0 0;font-size:.92rem;color:#8a877e;max-width:22ch}
/* verhaal-hoofdstukken: marker | tekst | beeld (naadloos, zoals processtappen) */
.cs__story{padding:clamp(3.5rem,9vh,6rem) var(--gut) 0}
.cs__chap{display:grid;grid-template-columns:.55fr 1.35fr 1.7fr;gap:0 clamp(1.4rem,3vw,3rem);align-items:start}
.cs__chap-idx{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#8a877e;padding-top:clamp(1.6rem,3.4vh,2.5rem)}
.cs__chap-txt{padding-top:clamp(1.4rem,3vh,2.2rem)}
.cs__chap-txt h3{font-family:var(--sans);font-weight:600;font-size:clamp(1.3rem,2.2vw,1.9rem);letter-spacing:-.015em;color:#ece9e1;margin-bottom:.8rem}
.cs__chap-txt p{color:#a5a298;font-size:clamp(.95rem,1.1vw,1.1rem);line-height:1.55;max-width:36ch}
.cs__chap-txt .cs__chap-meta{display:block;margin-top:1rem;font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:#6f6c64}
.cs__chap-media{overflow:hidden;background:#11100d;aspect-ratio:16/10;margin-right:calc(-1*var(--gut))}
.cs__chap-media img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:860px){.cs__chap{grid-template-columns:1fr;gap:1rem}.cs__chap-media{order:-1;margin-right:0}}
/* galerij: editorial 12-kolomsgrid */
.cs__gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1rem,2vw,1.8rem);padding:clamp(4rem,9vh,6.5rem) var(--gut)}
.cs__gallery figure{margin:0;overflow:hidden;border-radius:3px;background:#11100d}
.cs__gallery img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .75s var(--ease)}
@media(hover:hover){.cs__gallery figure:hover img{transform:scale(1.04)}}
.cs__gallery .g-tall{grid-column:span 5;aspect-ratio:4/5}
.cs__gallery .g-wide{grid-column:span 7;aspect-ratio:16/10}
.cs__gallery .g-sq{grid-column:span 4;aspect-ratio:1/1}
.cs__gallery .g-full{grid-column:span 8;aspect-ratio:16/9}
@media(max-width:760px){.cs__gallery figure{grid-column:span 6!important}}
/* volgende case */
.cs__next{display:block;padding:clamp(4rem,11vh,7.5rem) var(--gut);border-top:1px solid var(--line-2)}
.cs__next .label{display:block;margin-bottom:1.2rem}
.cs__next-title{font-family:var(--display);font-weight:700;font-size:clamp(2.4rem,6.4vw,6rem);letter-spacing:-.025em;line-height:1;color:#57544b;transition:color .45s var(--ease);display:flex;align-items:center;gap:.35em}
.cs__next-title span:last-child{font-size:.55em;transition:transform .45s var(--ease)}
@media(hover:hover){.cs__next:hover .cs__next-title{color:#ece9e1}.cs__next:hover .cs__next-title span:last-child{transform:translateX(.25em)}}
@media(max-width:860px){.cs__details{grid-template-columns:1fr 1fr}.cs__sum{grid-template-columns:1fr}}

/* ───── OVER ONS / CONTACT ───── */
.pg__hero{padding:clamp(8rem,18vh,12rem) var(--gut) clamp(2.5rem,6vh,4rem)}
.pg__title{font-family:var(--display);font-weight:700;font-size:clamp(3.4rem,10.5vw,10rem);line-height:.98;letter-spacing:-.025em;color:#ece9e1;margin:0;max-width:12ch}
.pg__intro{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:clamp(2rem,6vw,6rem);padding:clamp(3rem,8vh,5.5rem) var(--gut)}
.pg__intro h2{font-family:var(--sans);font-weight:500;font-size:clamp(1.7rem,3.2vw,3.1rem);line-height:1.1;letter-spacing:-.02em;color:#ece9e1;max-width:18ch}
.pg__intro-txt p{color:#a5a298;font-size:clamp(1rem,1.15vw,1.15rem);line-height:1.6;max-width:54ch}
.pg__intro-txt p+p{margin-top:1.1em}
.pg__photo{margin:0 calc(-1*var(--gut));overflow:hidden}
.pg__photo img{width:100%;height:auto;max-height:78vh;object-fit:cover;object-position:50% 28%;display:block;filter:grayscale(.15)}
.pg__duo{display:grid;grid-template-columns:minmax(240px,420px) 1fr;gap:clamp(2rem,6vw,5rem);align-items:start;padding:clamp(4rem,10vh,7rem) var(--gut)}
.pg__duo-photo{overflow:hidden;border-radius:3px;aspect-ratio:4/5;background:#11100d}
.pg__duo-photo img{width:100%;height:100%;object-fit:cover;display:block}
.pg__duo h2{font-family:var(--sans);font-weight:500;font-size:clamp(1.7rem,3vw,2.9rem);line-height:1.1;letter-spacing:-.02em;color:#ece9e1;margin-bottom:1.2rem}
.pg__duo p{color:#a5a298;font-size:clamp(1rem,1.15vw,1.15rem);line-height:1.6;max-width:52ch}
.pg__duo p+p{margin-top:1.1em}
.pg__duo .label{display:block;margin-bottom:1.4rem}
.pg__duo.is-rev{grid-template-columns:1fr minmax(240px,420px)}
.pg__duo.is-rev .pg__duo-photo{grid-column:2;grid-row:1}
.pg__duo ul.pg__duo-list{list-style:none;margin:1.4rem 0 0;padding:0;display:grid;gap:1rem;max-width:52ch}
.pg__duo ul.pg__duo-list li{position:relative;padding-left:1.5rem;color:#a5a298;font-size:clamp(1rem,1.15vw,1.15rem);line-height:1.55}
.pg__duo ul.pg__duo-list li::before{content:"";position:absolute;left:0;top:.6em;width:7px;height:7px;border:1px solid #6e6b61;border-radius:50%}
.pg__duo ul.pg__duo-list li strong{color:#ece9e1;font-weight:500}
@media(max-width:760px){.pg__duo,.pg__duo.is-rev{grid-template-columns:1fr}.pg__duo.is-rev .pg__duo-photo{grid-column:1;grid-row:auto;order:2}}
.ct__direct{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.5rem;padding:clamp(2.5rem,6vh,4rem) var(--gut)}
.ct__card{display:block;border:1px solid var(--line-2);border-radius:4px;padding:1.6rem;transition:background .35s var(--ease),border-color .35s var(--ease)}
.ct__card:hover{background:rgba(232,232,227,.06);border-color:rgba(236,233,225,.25)}
.ct__card .label{display:block;margin-bottom:.8rem}
.ct__card p{font-family:var(--sans);font-weight:600;font-size:clamp(1.05rem,1.5vw,1.4rem);color:#ece9e1}
.ct__card span{display:block;margin-top:.4rem;font-size:.9rem;color:#8a877e}
/* contact - kort formulier (Netlify Forms) */
.ct__form{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:clamp(2rem,6vw,6rem);padding:clamp(3.5rem,9vh,6rem) var(--gut);border-top:1px solid var(--line-2)}
.ct__form-intro .label{display:block;margin-bottom:1.4rem}
.ct__form-intro h2{font-family:var(--sans);font-weight:500;font-size:clamp(1.7rem,3vw,2.9rem);line-height:1.1;letter-spacing:-.02em;color:#ece9e1;margin-bottom:1.2rem;max-width:18ch}
.ct__form-intro p{color:#a5a298;font-size:clamp(1rem,1.15vw,1.15rem);line-height:1.6;max-width:44ch}
.ct__formgrid{display:grid;gap:1.4rem;max-width:560px;min-width:0}
.ct__field{display:grid;gap:.55rem;min-width:0}
.ct__field label{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:#8a877e}
.ct__field input,.ct__field textarea{width:100%;background:#11100d;border:1px solid var(--line-2);border-radius:4px;color:#ece9e1;font-family:var(--sans);font-size:1rem;line-height:1.5;padding:.85rem 1rem;transition:border-color .3s var(--ease)}
.ct__field input::placeholder,.ct__field textarea::placeholder{color:#6f6c64}
.ct__field input:focus,.ct__field textarea:focus{outline:none;border-color:rgba(236,233,225,.55)}
.ct__field textarea{min-height:9.5rem;resize:vertical}
.ct__hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
button.ct__submit{border:0;cursor:pointer;justify-self:start;margin-top:.2rem}
@media(max-width:760px){.ct__form{grid-template-columns:1fr;gap:2.2rem}}

/* ───── CASE horizontaal (desktop): verticaal scrollen = naar rechts reizen ─────
   JS bouwt .hz/.hz__track en zet .has-hz op <body>; zonder JS blijft alles verticaal. */
@media(min-width:861px){
  .has-hz .hz{overflow:hidden}
  .has-hz .hz__track{display:flex;align-items:stretch;height:100svh;width:max-content;will-change:transform}
  .has-hz .hz__track>*{flex:0 0 auto;height:100svh;display:flex;flex-direction:column;justify-content:center;margin:0}
  .has-hz .cs__hero{width:100vw;padding:0 var(--gut)}
  .has-hz .cs__cover{width:78vw}
  .has-hz .cs__cover img{height:100svh;aspect-ratio:auto;object-fit:cover}
  .has-hz .cs__details{display:grid;width:64vw;grid-template-columns:1fr 1fr;gap:3.5rem 4rem;align-content:center;border:0;padding:0 7vw}
  .has-hz .cs__sum{display:grid;width:88vw;align-content:center;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:clamp(2rem,6vw,6rem);padding:0 6vw}
  .has-hz .cs__stats{display:flex;width:auto;gap:6vw;padding:0 7vw;border:0;align-items:center;flex-direction:row}
  .has-hz .cs__story{display:flex;flex-direction:row;padding:0;align-items:stretch}
  .has-hz .cs__chap{display:grid;width:84vw;grid-template-columns:.45fr 1.15fr 1.55fr;gap:0 3vw;align-items:center;padding:0 4vw}
  .has-hz .cs__chap-idx,.has-hz .cs__chap-txt{padding-top:0}
  .has-hz .cs__chap-media{margin-right:0;aspect-ratio:16/10;max-height:64vh;width:auto;align-self:center}
  .has-hz .cs__chap-media img{height:100%;width:100%}
  .has-hz .cs__gallery{display:flex;flex-direction:row;gap:2.2vw;padding:0 5vw;align-items:center}
  .has-hz .cs__gallery figure{height:62vh;width:auto;flex:0 0 auto}
  .has-hz .cs__gallery figure.g-tall{aspect-ratio:4/5}
  .has-hz .cs__gallery figure.g-wide{aspect-ratio:16/10}
  .has-hz .cs__gallery figure.g-sq{aspect-ratio:1/1}
  .has-hz .cs__gallery figure.g-full{aspect-ratio:16/9}
  .has-hz .cs__next{width:96vw;justify-content:center;border:0;padding:0 var(--gut)}
}

/* ───── editorial paneel: één grote kernzin + drie compacte feiten (minder blokken, meer lucht) ───── */
.cs__edit{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,.7fr);gap:clamp(2rem,6vw,7rem);padding:clamp(4rem,12vh,8rem) var(--gut);align-items:end}
.cs__edit-lead{font-family:var(--sans);font-weight:500;font-size:clamp(1.6rem,3vw,2.9rem);line-height:1.15;letter-spacing:-.018em;color:#ece9e1;max-width:24ch}
.cs__edit-facts{display:flex;flex-direction:column;gap:1.2rem;margin:0}
.cs__edit-facts dt{font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:#8a877e;margin-bottom:.3rem}
.cs__edit-facts dd{margin:0;font-weight:600;font-size:1rem;color:#ece9e1;line-height:1.45}
@media(max-width:860px){.cs__edit{grid-template-columns:1fr;align-items:start}}
@media(min-width:861px){.has-hz .cs__edit{display:grid;width:86vw;align-content:center;align-items:center;padding:0 7vw;grid-template-columns:minmax(0,1.5fr) minmax(0,.7fr)}}

/* ───── CASE referentielayout: intro (titel+thumb+cijfers) / cover met meta-overlay / samenvatting ───── */
.csx__intro{min-height:92svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:clamp(7rem,14vh,9rem) var(--gut) 3rem;gap:1rem}
.csx__kicker{font-size:.95rem;color:#cfccc2}
.csx__title{font-family:var(--display);font-weight:700;font-size:clamp(2.7rem,5.5vw,5.5rem);line-height:1.04;letter-spacing:-.025em;color:#ece9e1;max-width:13ch;margin:0}
.csx__thumb{width:min(420px,68vw);aspect-ratio:16/9;overflow:hidden;margin:1.5rem 0 .8rem}
.csx__thumb img{width:100%;height:100%;object-fit:cover;display:block}
.csx__delivered{margin-top:.3rem}
.csx__stats{display:flex;gap:clamp(1.8rem,4.5vw,4rem);margin:.6rem 0 0;justify-content:center;align-items:start}
.csx__stat dt{font-family:var(--display);font-weight:800;font-size:clamp(1.8rem,2.7vw,2.7rem);letter-spacing:-.02em;color:#ece9e1;line-height:1}
.csx__stat dd{margin:.4rem 0 0;font-size:.82rem;color:#8a877e;max-width:17ch;line-height:1.35}
.csx__cover{position:relative;margin:0;overflow:hidden;background:#11100d}
.csx__cover>img{width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;display:block}
.csx__cover::after{content:"";position:absolute;inset:auto 0 0 0;height:42%;background:linear-gradient(180deg,transparent,rgba(8,8,6,.78));pointer-events:none}
.csx__meta{position:absolute;left:0;right:0;bottom:0;display:flex;flex-wrap:wrap;gap:clamp(1.6rem,5vw,4.5rem);padding:clamp(1.4rem,3vw,2.4rem) var(--gut);z-index:2;align-items:end}
.csx__meta span{display:block;font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:#b8b5aa;margin-bottom:.45rem}
.csx__meta p{margin:0;font-weight:700;font-size:clamp(.98rem,1.2vw,1.18rem);color:#fff;line-height:1.5}
.csx__sum{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);grid-template-rows:auto 1fr;gap:clamp(1.6rem,4vw,4rem);padding:clamp(4rem,10vh,7rem) var(--gut);align-items:end}
.csx__sumtitle{grid-column:1/-1;font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,3.3vw,3.3rem);line-height:1.12;letter-spacing:-.02em;color:#ece9e1;max-width:27ch;margin:0}
.csx__sumimgs{display:flex;flex-direction:column;gap:1.4rem;max-width:340px}
.csx__sumimgs figure{aspect-ratio:4/5;overflow:hidden;margin:0;background:#11100d}
.csx__sumimgs img{width:100%;height:100%;object-fit:cover;display:block}
.csx__sumtxt{align-self:end;justify-self:start;max-width:46ch}
.csx__arr{display:block;font-size:1.2rem;color:#cfccc2;margin-bottom:1.1rem}
.csx__sumtxt p{margin:0;color:#cfccc2;font-size:1rem;line-height:1.6}
.csx__sumtxt p+p{margin-top:1rem}
.csx__sumtxt strong{color:#fff}
@media(max-width:860px){.csx__sum{grid-template-columns:1fr}.csx__sumtxt{justify-self:start}}
/* horizontale reis-varianten */
@media(min-width:861px){
  .has-hz .csx__intro{width:58vw;min-height:0;padding:0 5vw}
  .has-hz .csx__cover{width:92vw;display:block}
  .has-hz .csx__cover>img{height:100svh;aspect-ratio:auto}
  .has-hz .csx__sum{display:grid;width:94vw;padding:11vh 5vw 8vh}
  .has-hz .csx__sumimgs figure{height:27vh;aspect-ratio:4/5;width:auto}
}

/* ───── video-cover + collage-clusters in de filmstrip ───── */
.csx__cover>video{width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;display:block}
@media(min-width:861px){.has-hz .csx__cover>video{height:100svh;aspect-ratio:auto}}
.cs__gallery .g-col{display:grid;gap:clamp(1rem,2vw,1.8rem);grid-column:span 4}
.cs__gallery .g-col figure{margin:0;overflow:hidden;border-radius:3px;aspect-ratio:4/5;background:#11100d}
.cs__gallery .g-col img{width:100%;height:100%;object-fit:cover;display:block}
@media(min-width:861px){
  .has-hz .cs__gallery .g-col{display:flex;flex-direction:column;gap:2vh;width:auto;flex:0 0 auto}
  .has-hz .cs__gallery .g-col figure{height:30vh;aspect-ratio:4/5;width:auto}
}

/* ───── case-videospeler: foto-poster met play-knop, speelt pas na klik (met geluid) ───── */
.csx__player{position:relative;padding:clamp(3rem,8vh,5rem) var(--gut)}
.csx__video{width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;display:block;background:#11100d;border-radius:3px;cursor:pointer}
.csx__play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:clamp(64px,6vw,88px);aspect-ratio:1;border-radius:50%;border:0;background:#e8e8e3;color:#0d0c0a;display:grid;place-items:center;cursor:pointer;transition:transform .3s var(--ease),opacity .3s var(--ease)}
.csx__play svg{width:42%;margin-left:6%}
.csx__play:hover{transform:translate(-50%,-50%) scale(1.08)}
.csx__player.is-playing .csx__play{opacity:0;pointer-events:none}
@media(min-width:861px){
  .has-hz .csx__player{width:88vw;display:flex;align-items:center;padding:0 4vw}
  .has-hz .csx__video{max-height:82svh;width:100%;aspect-ratio:16/9}
}

/* ───── speler-controlebalk: mute + doorspoelen + tijd (zichtbaar bij spelen/hover) ───── */
.csx__bar{position:absolute;left:calc(var(--gut) + 1rem);right:calc(var(--gut) + 1rem);bottom:clamp(4rem,9.5vh,6.2rem);display:flex;align-items:center;gap:.9rem;padding:.55rem .8rem;background:rgba(13,12,10,.72);backdrop-filter:blur(8px);border-radius:4px;opacity:0;pointer-events:none;transition:opacity .3s var(--ease);z-index:3}
.csx__player.is-playing .csx__bar,.csx__player:hover.is-playing .csx__bar,.csx__player.is-playing:hover .csx__bar{opacity:1;pointer-events:auto}
.csx__player:hover .csx__bar{opacity:1;pointer-events:auto}
.csx__mute{background:none;border:0;color:#ece9e1;width:26px;height:26px;cursor:pointer;display:grid;place-items:center;flex:none}
.csx__mute svg{width:20px;height:20px}
.csx__mute .is-uit{display:none}
.csx__player.is-muted .csx__mute .is-aan{display:none}
.csx__player.is-muted .csx__mute .is-uit{display:block}
.csx__seek{flex:1;accent-color:#e8e8e3;height:3px;cursor:pointer}
.csx__time{font-family:var(--mono);font-size:.68rem;letter-spacing:.04em;color:#b8b5aa;min-width:2.6rem;text-align:right}
/* touch: backdrop-blur boven een spélende video = elk frame opnieuw filteren; iets donkerder
   dekkend vlak leest hetzelfde en is gratis. Daarnaast vingermaat-bediening: de slider had
   een raakvlak van 3px hoog en de mute-knop 26px - met een duim niet te raken. */
@media(pointer:coarse){
  .csx__bar{background:rgba(13,12,10,.88);-webkit-backdrop-filter:none;backdrop-filter:none;gap:.55rem;padding:.3rem .55rem}
  .csx__seek{height:30px}
  .csx__mute{width:38px;height:38px}
  .csx__mute svg{width:22px;height:22px}
  /* eigen track + flinke thumb: de native accent-color-thumb is op iOS/Android een
     mini-bolletje van ~12px; appearance:none geeft een 18px-knop op een rustige track,
     en de 30px-hoogte hierboven blijft het echte raakvlak */
  .csx__seek{-webkit-appearance:none;appearance:none;background:transparent}
  .csx__seek::-webkit-slider-runnable-track{height:4px;border-radius:2px;background:rgba(232,232,227,.32)}
  .csx__seek::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#e8e8e3;border:0;margin-top:-7px}
  .csx__seek::-moz-range-track{height:4px;border-radius:2px;background:rgba(232,232,227,.32)}
  .csx__seek::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#e8e8e3;border:0}
}
@media(min-width:861px){.has-hz .csx__bar{left:calc(4vw + 1rem);right:calc(4vw + 1rem);bottom:11vh}}

/* ───── film-koppen boven spelers (case-specifieke drieluiken) ───── */
.csx__filmhead{padding:0 0 1.1rem}
.csx__filmidx{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:#8a877e;margin-bottom:.5rem}
.csx__filmidx b{border:1px solid rgba(236,233,225,.3);padding:.05rem .35rem;border-radius:3px;margin-left:.3rem;color:#b8b5aa;font-weight:500}
.csx__filmtitel{font-family:var(--sans);font-weight:600;font-size:clamp(1.2rem,1.8vw,1.6rem);letter-spacing:-.015em;color:#ece9e1;margin:0 0 .35rem}
.csx__filmregel{margin:0;color:#a5a298;font-size:.95rem;line-height:1.5;max-width:52ch}
@media(min-width:861px){
  .has-hz .csx__player{flex-direction:column;align-items:flex-start;justify-content:center}
  .has-hz .csx__player .csx__video{max-height:68svh}
  .has-hz .csx__play{top:auto;bottom:calc(34svh)}
}

/* ───── verticale spelers (telefoontjes), campagneblok & websiteknop ───── */
.csx__campagne{padding:clamp(3rem,8vh,5rem) var(--gut)}
.csx__phones{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(1rem,2.5vw,2rem);margin-top:1.8rem}
.csx__player.is-vert{padding:0;position:relative}
.csx__vidwrap{position:relative}
.csx__vidwrap .csx__play{position:absolute;left:50%;top:50%;bottom:auto}
.csx__player.is-vert .csx__video,.csx__vidwrap.is-vert .csx__video{aspect-ratio:9/16;height:auto;width:100%;border-radius:4px}
.csx__player.is-vert .csx__play{width:clamp(46px,3.6vw,58px)}
.csx__player.is-vert .csx__bar{left:.7rem;right:.7rem;bottom:.7rem;padding:.4rem .6rem}
.csx__filmhead.is-mini .csx__filmtitel{font-size:1.02rem}
.csx__filmhead.is-mini .csx__filmregel{font-size:.85rem}
.csx__player.is-solo{display:flex;flex-direction:column;align-items:center;text-align:center}
.csx__player.is-solo .csx__vidwrap{width:min(400px,78vw)}
.csx__player.is-solo .csx__filmregel{margin:0 auto}
.csx__sitebtn{margin-top:1.5rem}
.csx__btns{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.5rem}
@media(max-width:760px){.csx__phones{grid-template-columns:1fr}}
@media(min-width:861px){
  .has-hz .csx__campagne{width:auto;display:flex;flex-direction:column;justify-content:center;padding:0 4vw}
  .has-hz .csx__phones{display:flex;gap:2vw;margin-top:2.4vh}
  .has-hz .csx__player.is-vert{width:calc(56svh*9/16);flex:0 0 auto}
  .has-hz .csx__player.is-vert .csx__video{height:56svh;width:auto}
  .has-hz .csx__player.is-solo .csx__vidwrap{width:auto}
  .has-hz .csx__player.is-solo .csx__video{height:64svh;width:auto}
}

/* ── Case: website-mockup (laptop + telefoon) ───────────── */
.csx__mock{padding:clamp(3rem,8vh,5rem) var(--gut)}
.csx__devices{display:flex;align-items:flex-end;justify-content:center;gap:clamp(1.2rem,3vw,3rem);margin-top:1.8rem}
.mock-laptop{width:min(760px,58vw);margin:0}
.mock-laptop__screen{display:block;border:10px solid #1a1916;border-bottom:0;border-radius:12px 12px 0 0;overflow:hidden;background:#000}
.mock-laptop__screen img{display:block;width:100%}
.mock-laptop__base{display:block;height:13px;background:linear-gradient(#3a3731,#211f1b);border-radius:0 0 14px 14px;margin:0 -5%}
.mock-phone{width:min(170px,15vw);margin:0;border:7px solid #1a1916;border-radius:24px;overflow:hidden;background:#000}
.mock-phone img{display:block;width:100%}
@media(max-width:760px){.csx__devices{flex-direction:column;align-items:center}.mock-laptop{width:100%}.mock-phone{width:150px}}
@media(min-width:861px){.has-hz .csx__mock{width:92vw;display:flex;flex-direction:column;justify-content:center;padding:0 4vw}.has-hz .csx__devices{align-items:flex-end}.has-hz .mock-laptop__screen img{max-height:58svh;width:auto}}

/* ───── balk volgt de video bij verticale spelers + scale-veiligheid op lage vensters ───── */
.csx__vidwrap .csx__bar{left:.7rem;right:.7rem;bottom:.7rem;padding:.4rem .6rem}
.csx__player .csx__filmhead{flex:none}
@media(min-width:861px){
  .has-hz .csx__player.is-solo .csx__video{height:min(64svh,calc(100svh - 200px))}
  .has-hz .csx__player.is-vert .csx__video{height:min(56svh,calc(100svh - 240px))}
  .has-hz .csx__player .csx__video{max-height:min(68svh,calc(100svh - 200px))}
  .has-hz .mock-laptop__screen img{max-height:min(58svh,calc(100svh - 240px))}
}

/* ───── compactere reis: minder lege ruimte tussen panelen ───── */
.csx__player,.csx__campagne,.csx__mock{padding-top:clamp(2rem,5vh,3rem);padding-bottom:clamp(2rem,5vh,3rem)}
@media(min-width:861px){
  .has-hz .csx__intro{width:46vw;padding:0 3vw}
  .has-hz .csx__cover{width:74vw}
  .has-hz .csx__sum{width:76vw;padding:9vh 3.5vw 7vh;gap:clamp(1.4rem,3vw,3rem)}
  .has-hz .csx__player{width:auto;padding:0 2.5vw}
  .has-hz .csx__player .csx__video{width:auto;max-width:62vw}
  .has-hz .csx__campagne{padding:0 2.5vw}
  .has-hz .csx__phones{gap:1.4vw}
  .has-hz .csx__mock{width:auto;padding:0 3vw}
  .has-hz .cs__gallery{gap:1.6vw;padding:0 3vw}
  .has-hz .cs__next{width:60vw}
  .has-hz .csx__player.is-solo{padding:0 3vw}
}

/* ───── play-knop in huisstijl: cream blokje (zoals de pill-knoppen), donkere driehoek ───── */
.csx__play{border-radius:4px;background:#e8e8e3;color:#0d0c0a;box-shadow:0 14px 34px -14px rgba(0,0,0,.65)}
.csx__play svg{transition:transform .3s var(--ease)}
@media(hover:hover){.csx__play:hover{transform:translate(-50%,-50%) scale(1.07)}.csx__play:hover svg{transform:translateX(8%)}}

/* campagneposts - horizontale strip (4:5) */
.csx__posts{display:flex;gap:clamp(.9rem,2vw,1.6rem);margin-top:1.8rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:.6rem;scrollbar-width:thin;scrollbar-color:#3a3833 transparent}
.csx__posts figure{flex:0 0 clamp(220px,30vw,340px);scroll-snap-align:start;border-radius:4px;overflow:hidden;background:#11100d}
.csx__posts img{width:100%;aspect-ratio:4/5;object-fit:cover;display:block}
.has-hz .csx__posts{overflow:visible;scroll-snap-type:none;width:max-content;margin-top:2.4vh;padding-bottom:0}
.has-hz .csx__posts figure{flex:0 0 auto;width:calc(52svh*4/5)}
/* posts-strip variant voor 3:4-posters (artiesten-aankondigingen) */
.csx__posts.is-34 img{aspect-ratio:3/4}
.has-hz .csx__posts.is-34 figure{width:calc(min(52svh,calc(100svh - 260px))*3/4)}
/* telefoonrij met 2 video's i.p.v. 3 */
.csx__phones.is-2{grid-template-columns:repeat(2,minmax(0,1fr));max-width:740px}
.has-hz .csx__phones.is-2{max-width:none}
@media(max-width:760px){.csx__phones.is-2{grid-template-columns:1fr}}

/* live website in device-mockup - geschaalde iframe, geen pointer-trap in de hz-reis */
.mock-live{display:block;position:relative;overflow:hidden;background:#0d0c0a}
.mock-laptop__screen .mock-live{aspect-ratio:1440/900;width:100%}
.mock-phone .mock-live{aspect-ratio:390/844;width:100%}
.mock-live iframe{border:0;display:block;transform-origin:0 0;pointer-events:none}
.mock-live{cursor:pointer}
.mock-live.is-on{cursor:auto}
.mock-live.is-on iframe{pointer-events:auto}
.mock-live__hint{position:absolute;left:50%;bottom:7%;transform:translateX(-50%);z-index:2;white-space:nowrap;font-family:var(--mono);font-size:.62rem;letter-spacing:.07em;text-transform:uppercase;background:#e8e8e3;color:#161512;padding:.4em .85em;border-radius:3px;pointer-events:none;opacity:.92;transition:opacity .25s}
.mock-live.is-on .mock-live__hint{opacity:0}
.mock-phone .mock-live__hint{font-size:.48rem;padding:.32em .6em}

/* over-ons - team: plaatje, naam, rol, praatje */
.pg__team{padding:clamp(4rem,10vh,7rem) var(--gut)}
.pg__team-head{margin-bottom:clamp(2.2rem,5vh,3.6rem);max-width:60ch}
.pg__team-head .label{display:block;margin-bottom:1.4rem}
.pg__team-head h2{font-family:var(--sans);font-weight:500;font-size:clamp(1.7rem,3vw,2.9rem);line-height:1.1;letter-spacing:-.02em;color:#ece9e1;margin-bottom:1rem}
.pg__team-head p{color:#a5a298;font-size:clamp(1rem,1.15vw,1.15rem);line-height:1.6}
.pg__team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.2rem,2.4vw,2.2rem)}
.pg__member figure{overflow:hidden;border-radius:3px;aspect-ratio:4/5;background:#11100d;margin-bottom:1.1rem}
.pg__member img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.22,.61,.36,1)}
.pg__member:hover img{transform:scale(1.04)}
.pg__member h3{font-family:var(--sans);font-weight:500;font-size:clamp(1.2rem,1.6vw,1.5rem);color:#ece9e1;letter-spacing:-.01em}
.pg__member-rol{font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:#a5a298;margin:.3rem 0 .7rem}
.pg__member p{color:#a5a298;font-size:clamp(.95rem,1.05vw,1.05rem);line-height:1.6}
@media(max-width:1100px){.pg__team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.pg__team-grid{grid-template-columns:1fr;gap:2.4rem}}
