/* =====================================================================
   BLS Sports — multipage herontwerp (format-transformatie)
   Behoudt: Montserrat + bestaand kleurenpalet.
   Structuur: landing (index) + methode-trainingen + resultaten + beheer (admin).
   ===================================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* —— bestaand palet (ongewijzigd) —— */
  --zwart:#0d0d18;--blauw:#1976D2;--blauw-d:#1565C0;--blauw-l:#e8f1fc;
  --wit:#fff;--bg:#f4f5f8;--tekst:#10131a;--muted:#6b7280;--rand:#e7e9f0;--groen:#2E7D32;
  /* —— afgeleide surface-tints (zelfde palet) —— */
  --zwart-2:#14141f;--zwart-3:#1b1b29;
  --radius:14px;--radius-l:22px;
  --shadow-l:0 8px 30px rgba(0,0,0,.10);--shadow-xl:0 24px 60px rgba(13,13,24,.16);
  --maxw:1180px;
}

html{scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;background:var(--wit);color:var(--tekst);line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ===================== herbruikbare typografie ===================== */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;
  color:var(--blauw);text-transform:uppercase;letter-spacing:.14em}
.eyebrow::before{content:'';display:none}
.display{font-weight:300;letter-spacing:-.025em;line-height:1.08}
.display b,.display strong{font-weight:800;color:var(--blauw)}
.lead{color:var(--muted);font-size:clamp(15px,1.6vw,18px);max-width:60ch}
section{position:relative}

.knop{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--blauw);color:#fff;
  border:none;border-radius:30px;padding:13px 28px;font-size:14px;font-weight:700;letter-spacing:.01em;
  cursor:pointer;font-family:inherit;transition:background .2s,transform .12s,box-shadow .2s;white-space:nowrap}
.knop:hover{background:var(--blauw-d);box-shadow:0 10px 24px rgba(25,118,210,.32)}
.knop:active{transform:scale(.97)}
.knop svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.knop-ghost{background:none;border:1.5px solid rgba(255,255,255,.28);color:#fff}
.knop-ghost:hover{background:rgba(255,255,255,.08);border-color:#fff;box-shadow:none}
.knop-licht{background:#fff;color:var(--blauw-d);border:1.5px solid var(--rand)}
.knop-licht:hover{background:var(--blauw-l);box-shadow:none}
.knop-groot{padding:16px 34px;font-size:15px}

/* ===================== fotoplaceholders ===================== */
.ph{position:relative;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);
  background:repeating-linear-gradient(45deg,rgba(25,118,210,.045) 0 14px,rgba(25,118,210,.085) 14px 28px),var(--blauw-l);
  border:1.5px dashed rgba(25,118,210,.40);color:var(--blauw-d);overflow:hidden;min-height:120px}
.ph-in{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;padding:18px}
.ph-in svg{width:34px;height:34px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;opacity:.6}
.ph-in span{font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;opacity:.75;line-height:1.4}
.ph::before{content:'FOTO';position:absolute;top:12px;left:12px;background:var(--blauw);color:#fff;
  font-size:9.5px;font-weight:800;letter-spacing:.1em;padding:4px 9px;border-radius:20px}
.ph-dark{background:repeating-linear-gradient(45deg,rgba(255,255,255,.035) 0 14px,rgba(255,255,255,.07) 14px 28px),var(--zwart-2);
  border-color:rgba(255,255,255,.22);color:rgba(255,255,255,.82)}
.ph-dark::before{background:var(--blauw)}

/* ===================== header ===================== */
.header{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .3s,box-shadow .3s,border-color .3s;
  border-bottom:1px solid transparent}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;
  max-width:var(--maxw);margin:0 auto;padding:18px 28px;transition:padding .3s}
.header.scrolled,.header.vast{background:rgba(13,13,24,.86);backdrop-filter:blur(14px);border-bottom-color:rgba(255,255,255,.08)}
.header.scrolled .header-inner{padding:12px 28px}
.header.scrolled .brand img,.header.vast .brand img{height:38px}
.brand img{height:46px;width:auto;filter:brightness(0) invert(1);display:block;transition:height .3s}
.hoofdnav{display:flex;align-items:center;gap:28px}
.hoofdnav a{color:rgba(255,255,255,.74);font-size:13.5px;font-weight:600;transition:color .15s;position:relative;padding:4px 0}
.hoofdnav a:hover,.hoofdnav a.actief{color:#fff}
.hoofdnav a.actief::after{content:'';position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--blauw);border-radius:2px}
.hoofdnav a.fbc-nav{color:#fff;display:inline-flex;align-items:center;gap:6px}
.hoofdnav a.fbc-nav::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--blauw)}
.header-acties{display:flex;align-items:center;gap:14px}
.header-acties .portaal{color:rgba(255,255,255,.74);font-size:13.5px;font-weight:600}
.header-acties .portaal:hover{color:#fff}
.header-acties .taal{display:inline-flex;align-items:center;color:rgba(255,255,255,.74);font-size:12.5px;font-weight:700;letter-spacing:.05em;padding:5px 11px;border:1px solid rgba(255,255,255,.22);border-radius:20px;transition:all .15s}
.header-acties .taal:hover{color:#fff;border-color:#fff}
.menu-toggle{display:none;background:none;border:none;color:#fff;cursor:pointer;padding:4px}
.menu-toggle svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}

/* ===================== hero ===================== */
.hero{position:relative;background:var(--zwart);color:#fff;overflow:hidden;min-height:92vh;display:flex;align-items:center;padding:150px 0 90px}
/* optionele full-bleed achtergrondfoto (zet .hero-bg img src of background-image) */
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
/* voetbalveld-lijnen — vullen de VOLLEDIGE achtergrond (svg met preserveAspectRatio slice) */
/* veld behoudt verhouding (geen vervorming) en vervaagt in de achtergrond */
.hero-pitch{position:absolute;inset:0;z-index:0;opacity:.5;
  -webkit-mask-image:radial-gradient(ellipse 84% 80% at 50% 42%,#000 20%,transparent 82%);
  mask-image:radial-gradient(ellipse 84% 80% at 50% 42%,#000 20%,transparent 82%)}
.hero-pitch svg{width:100%;height:100%;display:block}
.hero-pitch svg *{stroke:rgba(120,170,235,.5);fill:none;stroke-width:1.4;vector-effect:non-scaling-stroke}
.hero-glow{position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse 70% 62% at 26% 46%,rgba(25,118,210,.38) 0%,transparent 60%),
            radial-gradient(ellipse 46% 50% at 90% 8%,rgba(25,118,210,.18) 0%,transparent 55%)}
.hero-overlay{position:absolute;inset:0;z-index:2;
  background:linear-gradient(100deg,rgba(13,13,24,.92) 0%,rgba(13,13,24,.78) 46%,rgba(13,13,24,.46) 100%)}
.hero-grid{position:relative;z-index:3;display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;width:100%}
.hero-inner{max-width:620px}
.hero-index{display:flex;align-items:center;gap:12px;margin-bottom:26px;color:rgba(255,255,255,.5);
  font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;flex-wrap:wrap}
.hero-index b{color:#fff;font-weight:800}
.hero h1{font-size:clamp(40px,6.6vw,80px);font-weight:300;letter-spacing:-.03em;line-height:1;margin-bottom:24px}
.hero h1 b{font-weight:800;color:var(--blauw)}
.hero .lead{color:rgba(255,255,255,.66);font-size:clamp(15px,1.7vw,19px);margin-bottom:36px;max-width:46ch}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:46px}
.hero-feiten{display:flex;gap:36px;flex-wrap:wrap}
.hero-feit{display:flex;flex-direction:column;gap:3px}
.hero-feit .n{font-size:26px;font-weight:800;letter-spacing:-.02em}
.hero-feit .l{font-size:11.5px;font-weight:600;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.08em}
/* verticale fotobanner — foto's rouleren van beneden naar boven */
.foto-banner{position:relative;height:455px;max-height:64vh;width:236px;margin:0 auto;overflow:hidden;border-radius:var(--radius-l);
  border:1px solid rgba(255,255,255,.1);
  -webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 13%,#000 87%,transparent 100%);
  mask-image:linear-gradient(to bottom,transparent 0,#000 13%,#000 87%,transparent 100%)}
.foto-spoor{display:flex;flex-direction:column;gap:14px;animation:omhoog 24s linear infinite;will-change:transform}
.foto-banner:hover .foto-spoor{animation-play-state:paused}
.foto-spoor .ph{aspect-ratio:4/5;flex:0 0 auto;box-shadow:0 14px 40px rgba(0,0,0,.42)}
.foto-spoor img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--radius);flex:0 0 auto;display:block;box-shadow:0 14px 40px rgba(0,0,0,.42)}
@keyframes omhoog{from{transform:translateY(0)}to{transform:translateY(-50%)}}
.scroll-hint{position:absolute;left:28px;bottom:24px;z-index:3;display:flex;align-items:center;gap:10px;
  color:rgba(255,255,255,.45);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase}
.scroll-hint .lijn{width:1px;height:34px;background:linear-gradient(rgba(255,255,255,.5),transparent);animation:zak 1.8s infinite}
@keyframes zak{0%{transform:scaleY(.3);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}100%{transform:scaleY(.3);transform-origin:top}}

/* ===================== page-hero (subpagina's) ===================== */
.page-hero{position:relative;background:var(--zwart);color:#fff;overflow:hidden;padding:160px 0 80px;text-align:center}
.page-hero .hero-pitch{opacity:.4}
.page-hero .hero-glow{background:radial-gradient(ellipse 60% 70% at 50% 0%,rgba(25,118,210,.34) 0%,transparent 62%)}
.page-hero .container{position:relative;z-index:3}
.page-hero .eyebrow{justify-content:center}
.page-hero h1{font-size:clamp(34px,5.4vw,60px);margin:16px 0 14px}
.page-hero p{color:rgba(255,255,255,.66);font-size:clamp(15px,1.7vw,18px);max-width:62ch;margin:0 auto}

/* ===================== sectie-omhulsel ===================== */
.sectie{padding:104px 0}
.sectie.donker{background:var(--zwart);color:#fff}
.sectie.licht{background:var(--bg)}
.sectie-kop{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:52px;flex-wrap:wrap}
.sectie-kop .titelblok{max-width:62%}
.sectie-kop h2{font-size:clamp(30px,4.4vw,52px);margin-top:16px}
.sectie-kop .lead{margin-top:16px}
.sectie-nr{font-size:clamp(60px,9vw,130px);font-weight:800;line-height:.8;letter-spacing:-.04em;
  color:transparent;-webkit-text-stroke:1.5px var(--rand);text-stroke:1.5px var(--rand);user-select:none}
.donker .sectie-nr{-webkit-text-stroke-color:rgba(255,255,255,.14);text-stroke:1.5px rgba(255,255,255,.14)}
.donker .sectie-nr-vol{color:rgba(255,255,255,.06);-webkit-text-stroke:0}

/* ===================== teasers (landing) ===================== */
.teaser{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.teaser.omgekeerd .teaser-beeld{order:-1}
.teaser-beeld .ph{aspect-ratio:4/3}
.teaser-beeld img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center;border-radius:var(--radius-l);display:block;box-shadow:var(--shadow-xl)}
.teaser h2{font-size:clamp(28px,3.8vw,44px);margin:16px 0 16px}
.teaser .lead{margin-bottom:24px}
.mini-lijst{list-style:none;margin-bottom:28px;display:flex;flex-direction:column;gap:10px}
.mini-lijst li{font-size:15px;color:var(--muted);padding-left:28px;position:relative}
.mini-lijst li b{color:var(--tekst)}
.mini-lijst li::before{content:'';position:absolute;left:0;top:8px;width:16px;height:16px;background:var(--blauw-l);border-radius:50%}
.mini-lijst li::after{content:'';position:absolute;left:4.5px;top:12px;width:7px;height:4px;border-left:2px solid var(--blauw-d);border-bottom:2px solid var(--blauw-d);transform:rotate(-45deg)}
/* prijs-mini (landing trainingen-teaser) — even grote blokken, groep uitgelicht */
.prijs-mini{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:26px}
.prijs-chip{border:1px solid var(--rand);border-radius:14px;padding:16px 18px;position:relative}
.prijs-chip .t{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.prijs-chip .p{font-size:23px;font-weight:800;letter-spacing:-.02em;margin-top:4px}
.prijs-chip .p small{font-size:12px;font-weight:600;color:var(--muted)}
.prijs-chip.uit{background:var(--zwart);border-color:var(--zwart);color:#fff}
.prijs-chip.uit .t{color:rgba(255,255,255,.6)}
.prijs-chip.uit .p small{color:rgba(255,255,255,.5)}
.prijs-chip .uit-tag{position:absolute;top:-9px;right:12px;background:var(--blauw);color:#fff;font-size:9px;font-weight:800;
  letter-spacing:.05em;text-transform:uppercase;padding:3px 9px;border-radius:20px}

/* ===================== FBC-promoblok (endorsed) ===================== */
.fbc-promo{background:linear-gradient(120deg,var(--zwart) 0%,var(--zwart-3) 100%);color:#fff;border-radius:var(--radius-l);
  overflow:hidden;display:grid;grid-template-columns:1fr;align-items:stretch;position:relative}
.fbc-promo::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 30%,rgba(25,118,210,.28) 0%,transparent 55%)}
.fbc-promo-tekst{position:relative;z-index:1;padding:52px 48px}
.fbc-merkje{display:inline-flex;align-items:center;gap:9px;font-size:12px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:18px}
.fbc-merkje b{color:#fff}
.fbc-merkje .punt{width:8px;height:8px;border-radius:50%;background:var(--blauw)}
.fbc-promo h2{font-size:clamp(26px,3.4vw,40px);font-weight:300;letter-spacing:-.02em;line-height:1.1;margin-bottom:16px}
.fbc-promo h2 b{font-weight:800;color:var(--blauw)}
.fbc-promo p{color:rgba(255,255,255,.66);font-size:15.5px;max-width:46ch;margin-bottom:24px}
.fbc-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:30px}
.fbc-badge{border:1px solid rgba(255,255,255,.18);border-radius:30px;padding:7px 15px;font-size:12px;font-weight:700;color:rgba(255,255,255,.82)}
.fbc-badge.actief{background:var(--blauw);border-color:var(--blauw);color:#fff}
.fbc-promo-beeld{position:relative;z-index:1;padding:28px}
.fbc-promo-beeld .ph{height:100%}

/* ===================== methode (editorial split) ===================== */
.methode-layout{display:grid;grid-template-columns:.92fr 1.08fr;gap:60px;align-items:start}
.methode-beeld{position:sticky;top:110px}
.methode-beeld .ph{aspect-ratio:4/5}
.methode-beeld img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center 18%;border-radius:var(--radius-l);display:block;box-shadow:var(--shadow-xl)}
.methode-lijst{display:flex;flex-direction:column}
.methode-item{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:30px 0;border-top:1px solid var(--rand)}
.methode-item:first-child{border-top:none;padding-top:0}
.methode-item .nr{font-size:15px;font-weight:800;color:var(--blauw);letter-spacing:.04em;padding-top:3px}
.methode-item h3{font-size:21px;font-weight:700;margin-bottom:8px;letter-spacing:-.01em}
.methode-item p{font-size:15px;color:var(--muted)}

/* ===================== feiten-strip ===================== */
.feiten{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-l);overflow:hidden}
.feit{padding:34px 28px;border-right:1px solid rgba(255,255,255,.12)}
.feit:last-child{border-right:none}
.feit .k{font-size:11px;font-weight:700;color:var(--blauw);text-transform:uppercase;letter-spacing:.12em;margin-bottom:12px}
.feit .v{font-size:18px;font-weight:300;line-height:1.35}
.feit .v b{font-weight:800}

/* ===================== trainingen / prijzen ===================== */
/* taalschakelaar op mobiel verbergen (zit in het mobiele menu) */
@media (max-width:900px){.header-acties .taal{display:none}}

/* groepsabonnement iets breder (meest gekozen); de andere 3 even groot */
.prijs-grid{display:grid;grid-template-columns:1.35fr 1fr 1fr 1fr;gap:18px;align-items:stretch}
.prijs-kaart{background:#fff;border:1px solid var(--rand);border-radius:var(--radius-l);padding:32px 26px;
  display:flex;flex-direction:column;position:relative;transition:box-shadow .25s,transform .25s}
.prijs-kaart:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px)}
.prijs-kaart.uitgelicht{background:var(--zwart);color:#fff;border-color:var(--zwart)}
.prijs-kaart.uitgelicht .sub,.prijs-kaart.uitgelicht li{color:rgba(255,255,255,.66)}
.prijs-kaart.uitgelicht .noot{color:rgba(255,255,255,.5)}
.prijs-kaart.uitgelicht .prijs small{color:rgba(255,255,255,.55)}
.prijs-badge{position:absolute;top:-12px;left:26px;background:var(--blauw);color:#fff;padding:6px 15px;border-radius:30px;
  font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.prijs-kaart h3{font-size:19px;font-weight:800;margin-bottom:4px;letter-spacing:-.01em}
.prijs-kaart .sub{font-size:12.5px;font-weight:600;color:var(--muted);margin-bottom:22px}
.prijs{font-size:42px;font-weight:800;letter-spacing:-.03em;line-height:1;margin-bottom:4px}
.prijs small{font-size:14px;font-weight:600;color:var(--muted);letter-spacing:0}
.prijs-kaart .noot{font-size:12px;color:var(--muted);margin-bottom:22px}
.prijs-kaart ul{list-style:none;margin-bottom:26px;flex:1;display:flex;flex-direction:column}
.prijs-kaart li{font-size:13.5px;color:var(--muted);padding:7px 0 7px 26px;position:relative}
.prijs-kaart li::before{content:'';position:absolute;left:0;top:12px;width:15px;height:15px;background:var(--blauw-l);border-radius:50%}
.prijs-kaart li::after{content:'';position:absolute;left:4px;top:16px;width:7px;height:4px;border-left:2px solid var(--blauw-d);border-bottom:2px solid var(--blauw-d);transform:rotate(-45deg)}
.prijs-kaart.uitgelicht li::before{background:rgba(25,118,210,.28)}
.prijs-kaart.uitgelicht li::after{border-color:var(--blauw)}

/* rooster & locatie */
.rooster-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;margin-top:22px}
.rooster-kaart{background:#fff;border:1px solid var(--rand);border-radius:var(--radius-l);padding:34px}
.rooster-kaart h3{font-size:17px;font-weight:800;margin-bottom:20px;letter-spacing:-.01em}
.rooster-rij{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--rand);font-size:14px}
.rooster-rij:last-child{border-bottom:none}
.rooster-rij .dag{font-weight:700}
.rooster-rij .tijd{color:var(--muted);font-weight:600}
.tag{background:var(--blauw-l);color:var(--blauw-d);padding:5px 13px;border-radius:30px;font-size:11px;font-weight:700;white-space:nowrap}
.locatie-kaart{background:var(--zwart);color:#fff;border-radius:var(--radius-l);padding:34px;display:flex;flex-direction:column}
.locatie-kaart h3{font-size:17px;font-weight:800;margin-bottom:18px}
.locatie-kaart .ph{aspect-ratio:16/10;margin-bottom:20px;flex:0 0 auto}
.locatie-kaart img{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:var(--radius);display:block;margin-bottom:20px}
.soon-badge{display:inline-block;margin-bottom:16px;padding:7px 15px;border-radius:999px;background:var(--blauw);color:#fff;font-size:11px;font-weight:800;letter-spacing:.09em;text-transform:uppercase}
.knop-soon{background:rgba(255,255,255,.1);color:rgba(255,255,255,.62);border:1px solid rgba(255,255,255,.2);cursor:default;pointer-events:none}
.locatie-kaart p{font-size:14px;color:rgba(255,255,255,.66);margin-bottom:4px}
.locatie-kaart strong{color:#fff}
.locatie-kaart .knop{margin-top:auto;align-self:flex-start}

/* ===================== resultaten / testimonials ===================== */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.testi{background:var(--zwart-2);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius-l);padding:34px 30px;
  display:flex;flex-direction:column;transition:transform .25s,border-color .25s}
.testi:hover{transform:translateY(-4px);border-color:rgba(25,118,210,.5)}
.testi .quote{font-size:34px;font-weight:800;color:var(--blauw);line-height:1;height:22px;margin-bottom:18px}
.testi p{font-size:14.5px;color:rgba(255,255,255,.78);font-style:italic;flex:1;margin-bottom:24px;line-height:1.7}
.testi-persoon{display:flex;align-items:center;gap:14px}
.testi-avatar{width:54px;height:54px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:16px;color:#fff;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.06) 0 8px,rgba(255,255,255,.12) 8px 16px),var(--blauw);
  border:1.5px dashed rgba(255,255,255,.35)}
.testi-naam{font-size:14.5px;font-weight:700;color:#fff}
.testi-club{font-size:12px;color:rgba(255,255,255,.55);font-weight:600;margin-top:2px}

/* ===================== groei-testimonials (toen → nu) ===================== */
.groei-lijst{display:flex;flex-direction:column;gap:30px}
/* basis: foto (jong) | tekst | foto (nu) */
.groei{display:grid;grid-template-columns:1fr 1.12fr 1fr;gap:30px;align-items:start;padding:32px;border-radius:var(--radius-l)}
.groei-tekst{align-self:center}
.groei.kaart{background:#fff;border:1px solid var(--rand);box-shadow:var(--shadow-l)}
.groei.vlak{background:var(--bg)}
/* subtiele structuurvariaties — net even anders per testimonial */
.groei.breed-foto{grid-template-columns:1.08fr .96fr 1.08fr}
.groei.breed-tekst{grid-template-columns:.94fr 1.24fr .94fr}
.groei.geen-toen{grid-template-columns:1.35fr 1fr;align-items:center}
/* "trap"-versprong verwijderd — foto's lijnen nu gelijk uit (boven) */
/* foto-blokken */
.groei-foto{position:relative;margin:0}
/* alle testimonial-foto's zelfde verhouding (4/5) */
.groei-foto .ph{aspect-ratio:4/5}
.groei-foto img{width:100%;height:100%;aspect-ratio:4/5;object-fit:cover;object-position:center 25%;border-radius:var(--radius);display:block;box-shadow:0 10px 30px rgba(13,13,24,.20)}
.groei-foto{display:flex;flex-direction:column}
.groei-foto>img,.groei-foto>.ph{flex:0 0 auto}
.groei-chip{position:absolute;top:12px;left:12px;z-index:2;background:var(--muted);color:#fff;font-size:10px;font-weight:800;
  letter-spacing:.09em;text-transform:uppercase;padding:4px 11px;border-radius:20px}
.groei-chip.nu{background:var(--blauw)}
.groei-chip{display:none}
.groei-pijl{display:none!important}
.groei-foto .bij{margin-top:11px;text-align:center;font-size:12px;font-weight:600;color:var(--muted)}
/* tekstblok */
.groei-tekst{display:flex;flex-direction:column}
.groei-tekst .quote{font-size:44px;line-height:.6;color:var(--blauw);font-weight:800;height:26px}
.groei-tekst p{font-size:15px;color:var(--tekst);font-style:italic;line-height:1.7;margin-bottom:18px}
.groei-tekst.leeg p{font-style:normal;color:var(--muted)}
.groei-pijl{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--blauw);margin-bottom:14px}
.groei-pijl svg{width:30px;height:8px;stroke:var(--blauw);fill:none;stroke-width:1.6}
.groei-naam{font-size:16px;font-weight:800}
.groei-club{font-size:12.5px;font-weight:600;color:var(--muted);margin-top:3px}
@media (max-width:860px){
  .groei,.groei.breed-foto,.groei.breed-tekst{grid-template-columns:1fr;gap:18px;padding:22px}
  .groei.trap .groei-jong,.groei.trap .groei-ouder{transform:none}
  .groei-foto .ph{aspect-ratio:3/4}
}

/* ===================== galerij ===================== */
.galerij{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:150px;gap:14px}
.galerij .ph{height:100%}
.galerij img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius);display:block}
.galerij .span2c{grid-column:span 2}
.galerij .span2r{grid-row:span 2}

/* ===================== aanmelden / stappen ===================== */
.stappen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:54px}
.stap{background:#fff;border:1px solid var(--rand);border-radius:var(--radius-l);padding:34px 30px;position:relative}
.stap-num{width:46px;height:46px;border-radius:14px;background:var(--zwart);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;margin-bottom:18px}
.stap h3{font-size:17px;font-weight:800;margin-bottom:9px}
.stap p{font-size:14px;color:var(--muted)}
.aanmeld-cta{background:var(--zwart);color:#fff;border-radius:var(--radius-l);padding:56px 48px;position:relative;overflow:hidden}
.aanmeld-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(25,118,210,.35) 0%,transparent 60%)}
.aanmeld-cta>*{position:relative;z-index:1}
.aanmeld-cta h2{font-size:clamp(26px,3.4vw,40px);margin:14px 0 14px}
.aanmeld-cta .lead{color:rgba(255,255,255,.66);margin-bottom:30px}
.aanmeld-knoppen{display:flex;gap:14px;flex-wrap:wrap}
.aanmeld-noot{margin-top:24px;font-size:12.5px;color:rgba(255,255,255,.5)}
.aanmeld-noot a{color:rgba(255,255,255,.8);text-decoration:underline;text-underline-offset:2px}
/* contactkaarten */
.veld-foto{position:relative;margin-top:34px;border-radius:var(--radius-l);overflow:hidden;box-shadow:var(--shadow-xl)}
.veld-foto img{width:100%;height:clamp(220px,30vw,360px);object-fit:cover;object-position:center 42%;display:block}
.veld-foto figcaption{position:absolute;left:16px;bottom:14px;color:#fff;font-weight:700;font-size:12.5px;letter-spacing:.04em;background:rgba(15,17,21,.45);padding:7px 14px;border-radius:999px;backdrop-filter:blur(6px)}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.contact-kaart{background:#fff;border:1px solid var(--rand);border-radius:var(--radius);padding:28px 26px;display:flex;align-items:center;gap:16px}
.contact-ico{width:46px;height:46px;border-radius:12px;background:var(--blauw-l);color:var(--blauw-d);flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.contact-ico svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.contact-kaart h3{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.contact-kaart p,.contact-kaart a{font-size:14px;color:var(--muted)}
.contact-kaart a:hover{color:var(--blauw)}

/* ===================== footer ===================== */
.footer{background:var(--zwart);color:rgba(255,255,255,.6);border-top:1px solid rgba(255,255,255,.08);padding:64px 0 34px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:44px}
.footer-grid img{height:30px;filter:brightness(0) invert(1);margin-bottom:18px}
.footer-merk p{font-size:13.5px;color:rgba(255,255,255,.55);line-height:1.8;max-width:34ch}
.footer-grid h4{color:#fff;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}
.footer-grid li{list-style:none;margin-bottom:9px}
.footer-grid a{font-size:13.5px;color:rgba(255,255,255,.55)}
.footer-grid a:hover{color:#fff}
.footer-grid address{font-size:13.5px;color:rgba(255,255,255,.55);font-style:normal;line-height:1.8}
.footer-onder{border-top:1px solid rgba(255,255,255,.08);padding-top:26px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:12px;color:rgba(255,255,255,.4)}
.footer-onder .mini{display:flex;gap:18px;flex-wrap:wrap}
.footer-onder .mini a{color:rgba(255,255,255,.45)}
.footer-onder .mini a:hover{color:#fff}
.socials{display:flex;gap:14px}
.socials a{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:all .15s}
.socials a:hover{color:#fff;border-color:var(--blauw);background:var(--blauw)}
.socials svg{width:17px;height:17px;fill:currentColor}

/* ===================== sticky mobiele CTA ===================== */
.mobiel-cta{display:none;position:fixed;left:14px;right:14px;bottom:14px;z-index:190;gap:10px}
.mobiel-cta .knop{flex:1;box-shadow:0 10px 30px rgba(0,0,0,.3)}

/* ===================== dot-navigatie (alleen landing) ===================== */
.dotnav{position:fixed;right:24px;top:50%;transform:translateY(-50%);z-index:150;display:flex;flex-direction:column;gap:16px}
.dotnav a{width:11px;height:11px;border-radius:50%;border:2px solid var(--muted);opacity:.45;transition:all .2s;position:relative}
.dotnav a.actief{opacity:1;border-color:var(--blauw);background:var(--blauw);transform:scale(1.1)}
.dotnav a::after{content:attr(data-titel);position:absolute;right:22px;top:50%;transform:translateY(-50%);
  background:var(--zwart);color:#fff;font-size:11px;font-weight:600;padding:5px 11px;border-radius:6px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .18s}
.dotnav a:hover::after{opacity:1}

/* ===================== beheer / admin-login ===================== */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;
  background:radial-gradient(ellipse 60% 60% at 50% 0%,rgba(25,118,210,.18) 0%,transparent 60%),var(--zwart)}
.login-kaart{width:100%;max-width:400px;background:var(--zwart-2);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-l);padding:40px 36px;color:#fff}
.login-kaart .logo{height:30px;filter:brightness(0) invert(1);margin:0 auto 26px;display:block}
.login-kaart h1{font-size:21px;font-weight:800;text-align:center;margin-bottom:6px}
.login-kaart .sub{font-size:13px;color:rgba(255,255,255,.5);text-align:center;margin-bottom:28px}
.login-veld{margin-bottom:16px}
.login-veld label{display:block;font-size:12px;font-weight:700;color:rgba(255,255,255,.7);margin-bottom:7px;text-transform:uppercase;letter-spacing:.05em}
.login-veld input{width:100%;background:var(--zwart);border:1px solid rgba(255,255,255,.14);border-radius:12px;
  padding:13px 15px;color:#fff;font-family:inherit;font-size:15px;transition:border-color .15s}
.login-veld input:focus{outline:none;border-color:var(--blauw)}
.login-kaart .knop{width:100%;margin-top:8px;padding:14px}
.login-fout{display:none;background:rgba(220,40,40,.12);border:1px solid rgba(220,40,40,.4);color:#ff9b9b;
  font-size:13px;font-weight:600;padding:11px 14px;border-radius:10px;margin-bottom:18px}
.login-fout.toon{display:block}
.login-terug{display:block;text-align:center;margin-top:22px;font-size:12.5px;color:rgba(255,255,255,.45)}
.login-terug:hover{color:#fff}

/* ===================== responsive ===================== */
@media (max-width:1080px){
  .sectie-kop .titelblok{max-width:100%}
  .feiten{grid-template-columns:repeat(2,1fr)}
  .feit:nth-child(2){border-right:none}
  .feit:nth-child(1),.feit:nth-child(2){border-bottom:1px solid rgba(255,255,255,.12)}
}
@media (max-width:900px){
  .dotnav{display:none}
  .hoofdnav{display:none}
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .foto-banner{height:400px;max-height:none}
  .teaser,.methode-layout{grid-template-columns:1fr;gap:40px}
  .teaser.omgekeerd .teaser-beeld{order:0}
  .methode-beeld{position:static}
  .methode-beeld .ph{aspect-ratio:16/10}
  .fbc-promo{grid-template-columns:1fr}
  .fbc-promo-beeld{padding:0 48px 48px}
  .fbc-promo-beeld .ph{aspect-ratio:16/9}
  .prijs-grid{grid-template-columns:repeat(2,1fr)}
  .rooster-grid{grid-template-columns:1fr}
  .testi-grid,.stappen-grid,.contact-grid{grid-template-columns:1fr}
  .galerij{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px}
  .galerij .span2c,.galerij .span2r{grid-column:auto;grid-row:auto}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-merk{grid-column:1/-1}
  .menu-toggle{display:block}
  .header-acties .portaal{display:none}
}
@media (max-width:560px){
  .hero{padding:128px 0 70px;min-height:auto}
  .hero-pitch{opacity:.35}
  .foto-banner{height:330px}
  .sectie{padding:72px 0}
  .page-hero{padding:130px 0 60px}
  .prijs-grid{grid-template-columns:1fr}
  .feiten{grid-template-columns:1fr}
  .feit{border-right:none;border-bottom:1px solid rgba(255,255,255,.12)}
  .feit:last-child{border-bottom:none}
  .fbc-promo-tekst{padding:40px 28px}
  .aanmeld-cta{padding:40px 26px}
  .aanmeld-knoppen,.hero-ctas{flex-direction:column}
  .aanmeld-knoppen .knop,.hero-ctas .knop{width:100%}
  .knop-groot{padding:15px 18px;font-size:14px}
  .mobiel-cta{display:none}
  .footer-onder{justify-content:center;text-align:center}
}

/* mobiel uitklapmenu */
.mobiel-menu{position:fixed;inset:0;z-index:300;background:var(--zwart);display:none;flex-direction:column;padding:80px 32px 32px}
.mobiel-menu.open{display:flex}
.mobiel-menu a{color:#fff;font-size:22px;font-weight:300;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.mobiel-menu a b{font-weight:800;color:var(--blauw)}
.mobiel-menu .knop{margin-top:26px;font-size:16px;padding:16px}
.mobiel-sluit{position:absolute;top:24px;right:28px;background:none;border:none;color:#fff;cursor:pointer}
.mobiel-sluit svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}
