/* ==========================================================================
   Preventielab 2026 — Hoofdstylesheet
   Schoon, modern, mobile-first. Zelfde tokens als /intern/.
   ========================================================================== */

*{box-sizing:border-box;margin:0;padding:0}
:root{
	--ink:#0F0F11;
	--ink-2:#1A1A1D;
	--ink-3:#26262A;
	--lime:#B5F84A;
	--lime-2:#A4E83E;
	--lime-dim:#7AAD22;
	--lime-deep:#2F4A0B;
	--text-on-lime:#0F0F11;
	--paper:#FAFAF6;
	--text:#1A1814;
	--text-mute:#5A5550;
	--text-dim:#8B8780;
	--rule:#ECE8DD;
}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;color:var(--text);background:var(--ink);line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
.pl-wrap{max-width:1280px;margin:0 auto;padding:0 32px}

/* === LOGO === */
.pl-logo{display:inline-flex;align-items:center;gap:12px;font-weight:800;font-size:18px;letter-spacing:0.4px}
.pl-logo-mark{width:36px;height:38px;flex-shrink:0}
.pl-logo-text{color:white;white-space:nowrap}
.pl-logo-text span{color:var(--lime)}

/* === TOPBAR === */
.pl-topbar{position:sticky;top:0;z-index:50;background:rgba(15,15,17,0.97);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,0.06);padding:18px 0}
.pl-topbar .pl-wrap{display:flex;align-items:center;justify-content:space-between;gap:24px}
.pl-nav{display:flex;align-items:center;gap:30px}
.pl-nav a{color:rgba(255,255,255,0.78);font-size:14px;font-weight:500;transition:color .15s}
.pl-nav a:hover{color:var(--lime)}
.pl-nav-cta{display:flex;align-items:center;gap:10px}

/* === BUTTONS === */
.pl-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;font-weight:700;font-size:13.5px;letter-spacing:0.3px;border:1px solid transparent;cursor:pointer;transition:all .15s;border-radius:100px;white-space:nowrap}
.pl-btn-lime{background:var(--lime);color:var(--ink) !important}
.pl-btn-lime:hover{background:var(--lime-2);transform:translateY(-1px);box-shadow:0 8px 22px rgba(181,248,74,0.28)}
.pl-btn-ghost{color:white !important;border-color:rgba(255,255,255,0.2)}
.pl-btn-ghost:hover{border-color:var(--lime);color:var(--lime) !important}
.pl-btn-dark{background:var(--ink);color:#FFFFFF !important}
.pl-btn-dark:hover{background:var(--ink-3);color:#FFFFFF !important}
.pl-btn-outline-ink{color:var(--ink) !important;border-color:var(--ink);background:transparent}
.pl-btn-outline-ink:hover{background:var(--ink);color:white !important}
.pl-btn-lg{padding:16px 32px;font-size:15px}
.pl-menu-toggle{display:none;background:transparent;border:1px solid rgba(255,255,255,0.15);color:white;padding:8px 12px;font-size:14px;cursor:pointer;border-radius:6px}

/* === HERO === */
.pl-hero{background:var(--ink);color:white;padding:100px 0 130px;position:relative;overflow:hidden}
.pl-hero::before{content:'';position:absolute;top:-300px;right:-200px;width:700px;height:700px;background:radial-gradient(circle,rgba(181,248,74,0.18) 0%,transparent 65%);pointer-events:none}
.pl-hero::after{content:'';position:absolute;bottom:-200px;left:-200px;width:500px;height:500px;background:radial-gradient(circle,rgba(181,248,74,0.08) 0%,transparent 65%);pointer-events:none}
.pl-hero .pl-wrap{position:relative;z-index:2;text-align:center;max-width:960px}
.pl-hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;border:1px solid rgba(181,248,74,0.3);border-radius:100px;color:var(--lime);font-size:11px;font-weight:700;letter-spacing:2.4px;text-transform:uppercase;margin-bottom:36px}
.pl-hero-eyebrow .pl-dot{width:6px;height:6px;background:var(--lime);border-radius:50%;animation:pl-pulse 2.5s infinite}
@keyframes pl-pulse{0%,100%{opacity:1}50%{opacity:0.35}}
.pl-hero h1{font-size:clamp(40px, 8vw, 92px);line-height:0.95;font-weight:900;letter-spacing:-0.04em;margin-bottom:30px}
.pl-hero h1 em{font-style:normal;color:var(--lime)}
.pl-hero p.pl-lead{font-size:clamp(16px, 1.8vw, 20px);color:rgba(255,255,255,0.72);line-height:1.5;max-width:640px;margin:0 auto 44px}
.pl-hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* === MANIFEST (lime) — v5 compact 2-koloms === */
.pl-manifest{background:var(--lime);color:var(--text-on-lime);padding:80px 0}
.pl-manifest-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center}
.pl-manifest-left{}
.pl-manifest-eyebrow{display:inline-block;font-size:11px;font-weight:800;letter-spacing:2.4px;text-transform:uppercase;color:var(--lime-deep);background:rgba(15,15,17,0.1);padding:6px 14px;border-radius:100px;margin-bottom:24px}
.pl-manifest h2{font-size:clamp(26px, 3.4vw, 42px);line-height:1.1;font-weight:900;letter-spacing:-0.03em;margin-bottom:0;max-width:520px}
.pl-manifest h2 em{font-style:normal;background:var(--ink);color:var(--lime);padding:0 10px;border-radius:5px;display:inline-block;line-height:1.18}
.pl-manifest-items{display:flex;flex-direction:column;gap:24px}
.pl-manifest-item{display:flex;gap:20px;align-items:flex-start}
.pl-manifest-num{display:flex;align-items:center;justify-content:center;width:38px;height:38px;background:var(--ink);color:var(--lime);font-weight:900;font-size:13px;border-radius:50%;flex-shrink:0;font-family:'SF Mono',ui-monospace,monospace;margin-top:2px}
.pl-manifest-item-content{flex:1}
.pl-manifest-item h3{font-size:18px;font-weight:800;line-height:1.2;letter-spacing:-0.3px;margin-bottom:6px}
.pl-manifest-item p{font-size:14.5px;color:rgba(15,15,17,0.75);line-height:1.55}

/* === SECTION HEAD === */
.pl-section-head{text-align:center;margin-bottom:64px;max-width:780px;margin-left:auto;margin-right:auto;padding:0 16px}
.pl-section-eyebrow{display:inline-block;font-size:11px;font-weight:800;letter-spacing:2.4px;text-transform:uppercase;margin-bottom:18px}
.pl-section-head h2{font-size:clamp(28px, 5vw, 52px);line-height:1.05;font-weight:900;letter-spacing:-0.03em;margin-bottom:18px}
.pl-section-head h2 em{font-style:normal}
.pl-section-head p{font-size:clamp(15px, 1.6vw, 17px);line-height:1.55;max-width:620px;margin:0 auto}

/* === DIENSTEN === */
.pl-diensten{background:var(--ink);color:white;padding:120px 0}
.pl-diensten .pl-section-eyebrow{color:var(--lime)}
.pl-diensten .pl-section-head h2 em{color:var(--lime)}
.pl-diensten .pl-section-head p{color:rgba(255,255,255,0.7)}
.pl-diensten-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(255,255,255,0.08);padding:1px;border:1px solid rgba(255,255,255,0.08)}
.pl-dienst{background:var(--ink);padding:44px 40px;display:flex;flex-direction:column;transition:all .25s;position:relative;overflow:hidden}
.pl-dienst::after{content:'';position:absolute;left:0;top:0;width:0;height:3px;background:var(--lime);transition:width .35s ease}
.pl-dienst:hover{background:var(--ink-2)}
.pl-dienst:hover::after{width:100%}
.pl-dienst-num{font-family:'SF Mono',ui-monospace,monospace;font-size:11px;color:var(--lime);font-weight:700;letter-spacing:2px;margin-bottom:24px}
.pl-dienst-icon{width:60px;height:60px;border:1.5px solid rgba(181,248,74,0.6);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:26px;color:var(--lime)}
.pl-dienst-icon svg{width:26px;height:26px}
.pl-dienst h3{font-size:clamp(22px, 2.5vw, 28px);font-weight:800;letter-spacing:-0.5px;margin-bottom:14px;color:white}
.pl-dienst p{font-size:15px;color:rgba(255,255,255,0.7);line-height:1.6;margin-bottom:28px;flex:1}
.pl-dienst-bullets{list-style:none;padding:0 0 26px;margin:0}
.pl-dienst-bullets li{font-size:14px;color:rgba(255,255,255,0.85);padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.07);display:flex;align-items:center;gap:12px}
.pl-dienst-bullets li:last-child{border-bottom:0}
.pl-dienst-bullets li::before{content:'→';color:var(--lime);font-weight:700;flex-shrink:0}
.pl-dienst-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:var(--lime);padding-top:12px;border-top:1px solid rgba(255,255,255,0.08);transition:gap .2s}
.pl-dienst:hover .pl-dienst-link{gap:14px}

/* === VOOR WIE === */
.pl-voor-wie{background:var(--lime);color:var(--text-on-lime);padding:120px 0}
.pl-voor-wie .pl-section-eyebrow{color:var(--lime-deep)}
.pl-voor-wie .pl-section-head h2{color:var(--ink)}
.pl-voor-wie .pl-section-head h2 em{background:var(--ink);color:var(--lime);padding:0 14px;border-radius:6px;display:inline-block;line-height:1.15}
.pl-voor-wie .pl-section-head p{color:rgba(15,15,17,0.7)}
.pl-aud-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:8px}
.pl-aud{background:rgba(15,15,17,0.06);border:1px solid rgba(15,15,17,0.12);padding:34px 24px;text-align:center;color:var(--ink);transition:all .25s;position:relative;overflow:hidden;cursor:pointer}
.pl-aud::before{content:'';position:absolute;top:0;left:0;width:100%;height:0;background:var(--ink);transition:height .35s;z-index:0}
.pl-aud > *{position:relative;z-index:1}
.pl-aud:hover::before{height:100%}
.pl-aud:hover{color:white}
.pl-aud:hover .pl-aud-icon{background:var(--lime);color:var(--ink);border-color:var(--lime)}
.pl-aud:hover h3{color:white}
.pl-aud:hover p{color:rgba(255,255,255,0.75)}
.pl-aud-icon{width:58px;height:58px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--ink);border-radius:50%;transition:all .25s;background:transparent}
.pl-aud-icon svg{width:26px;height:26px}
.pl-aud h3{font-size:19px;font-weight:800;margin-bottom:8px;letter-spacing:-0.3px;transition:color .25s}
.pl-aud p{font-size:13.5px;color:rgba(15,15,17,0.7);line-height:1.5;transition:color .25s}

/* === EXPERTISE === */
.pl-expertise{background:var(--ink);color:white;padding:120px 0}
.pl-exp-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:center}
.pl-exp-text .pl-section-eyebrow{color:var(--lime);margin-bottom:18px}
.pl-exp-text h2{font-size:clamp(28px, 4.5vw, 50px);line-height:1.05;font-weight:900;letter-spacing:-0.03em;margin-bottom:22px}
.pl-exp-text h2 em{font-style:normal;color:var(--lime)}
.pl-exp-text p.pl-lead{font-size:clamp(15px, 1.6vw, 18px);color:rgba(255,255,255,0.75);line-height:1.55;margin-bottom:32px;max-width:540px}
.pl-exp-list{list-style:none;padding:0;margin-bottom:32px}
.pl-exp-list li{padding:16px 0;border-bottom:1px solid rgba(255,255,255,0.08);display:flex;align-items:baseline;gap:18px}
.pl-exp-list li:last-child{border-bottom:0}
.pl-exp-list-num{font-family:'SF Mono',ui-monospace,monospace;font-size:11px;color:var(--lime);font-weight:700;letter-spacing:1.5px;flex-shrink:0;min-width:32px}
.pl-exp-list-content strong{display:block;font-size:17px;color:white;margin-bottom:4px;font-weight:700}
.pl-exp-list-content span{font-size:14px;color:rgba(255,255,255,0.6);line-height:1.5}
.pl-exp-visual{position:relative;height:480px;display:flex;align-items:center;justify-content:center}
.pl-exp-shape{width:300px;height:300px;border:1.5px solid rgba(181,248,74,0.3);border-radius:50%;position:relative;display:flex;align-items:center;justify-content:center}
.pl-exp-shape::before,.pl-exp-shape::after{content:'';position:absolute;border:1.5px solid rgba(181,248,74,0.2);border-radius:50%}
.pl-exp-shape::before{width:380px;height:380px}
.pl-exp-shape::after{width:460px;height:460px;border-color:rgba(181,248,74,0.1)}
.pl-exp-shape-inner{width:160px;height:160px;background:radial-gradient(circle,rgba(181,248,74,0.18) 0%,transparent 70%);border-radius:50%;display:flex;align-items:center;justify-content:center}
.pl-exp-shape-inner svg{width:90px;height:90px;color:var(--lime)}
.pl-exp-tag{position:absolute;background:rgba(15,15,17,0.85);border:1px solid rgba(181,248,74,0.3);backdrop-filter:blur(10px);padding:10px 16px;border-radius:100px;font-size:12px;font-weight:700;color:var(--lime);letter-spacing:0.5px;animation:pl-floaty 6s ease-in-out infinite;white-space:nowrap}
.pl-exp-tag-1{top:20px;right:0;animation-delay:0s}
.pl-exp-tag-2{bottom:80px;left:-20px;animation-delay:2s}
.pl-exp-tag-3{top:55%;left:-40px;animation-delay:4s}
.pl-exp-tag-4{top:20px;left:20px;animation-delay:1s}
.pl-exp-tag-5{bottom:20px;right:-30px;animation-delay:3s}
.pl-exp-tag-6{top:50%;right:-35px;animation-delay:5s}
.pl-exp-tag-7{bottom:40px;left:35%;animation-delay:1.5s}
@keyframes pl-floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* === CTA FINAL === */
.pl-cta-final{background:var(--ink);color:#FFFFFF;padding:120px 0;text-align:center}
.pl-cta-final .pl-wrap{max-width:860px}
.pl-cta-final-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;background:var(--lime);color:var(--ink);font-size:11px;font-weight:700;letter-spacing:2.4px;text-transform:uppercase;border-radius:100px;margin-bottom:30px}
.pl-cta-final h2{font-size:clamp(30px, 5.5vw, 58px);line-height:1.02;font-weight:900;letter-spacing:-0.04em;margin-bottom:22px;color:#FFFFFF}
.pl-cta-final h2 em{font-style:normal;background:var(--lime);color:var(--ink);padding:0 12px;border-radius:5px;display:inline-block;line-height:1.18}
.pl-cta-final p{font-size:clamp(15px, 1.7vw, 18px);color:rgba(255,255,255,0.78);line-height:1.55;margin-bottom:40px;max-width:640px;margin-left:auto;margin-right:auto}
.pl-cta-final-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}
.pl-cta-contact{display:flex;justify-content:center;gap:40px;flex-wrap:wrap;padding-top:36px;border-top:1px solid rgba(255,255,255,0.15)}
.pl-cta-contact-item{display:flex;align-items:center;gap:12px}
.pl-cta-contact-icon{width:42px;height:42px;background:var(--lime);color:var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pl-cta-contact-icon svg{width:18px;height:18px}
.pl-cta-contact-text{text-align:left}
.pl-cta-contact-label{font-size:10px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;color:rgba(255,255,255,0.6);margin-bottom:2px}
.pl-cta-contact-value{font-size:14.5px;font-weight:700;color:#FFFFFF}
.pl-cta-contact-value a{color:#FFFFFF}

/* === FOOTER === */
.pl-footer{background:var(--ink);color:rgba(255,255,255,0.55);padding:64px 0 28px;font-size:13.5px;border-top:1px solid rgba(255,255,255,0.06)}
.pl-footer .pl-wrap{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.08);margin-bottom:24px}
.pl-foot-brand-block .pl-logo{margin-bottom:16px}
.pl-foot-brand-block p{line-height:1.6;font-size:13.5px;max-width:340px}
.pl-foot-col h4{color:white;font-size:11px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;margin-bottom:18px}
.pl-foot-col ul{list-style:none;padding:0}
.pl-foot-col li{margin-bottom:10px}
.pl-foot-col a{color:rgba(255,255,255,0.55);font-size:13.5px;transition:color .15s}
.pl-foot-col a:hover{color:var(--lime)}
.pl-foot-bottom{display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,0.4);gap:24px;flex-wrap:wrap;padding:0 32px}
.pl-foot-bottom a{color:rgba(255,255,255,0.4)}
.pl-foot-bottom a:hover{color:var(--lime)}

/* === GENERIC PAGES (post.php / page.php) === */
.pl-page{background:var(--paper);color:var(--text);padding:80px 0 100px;min-height:60vh}
.pl-page .pl-wrap{max-width:780px}
.pl-page-eyebrow{font-size:11px;font-weight:800;letter-spacing:2.4px;text-transform:uppercase;color:var(--lime-dim);margin-bottom:14px}
.pl-page h1{font-size:clamp(32px, 5vw, 48px);line-height:1.1;font-weight:900;letter-spacing:-0.03em;margin-bottom:24px;color:var(--ink)}
.pl-page .pl-page-content{font-size:16.5px;line-height:1.7;color:var(--text)}
.pl-page .pl-page-content p{margin-bottom:18px}
.pl-page .pl-page-content h2{font-size:28px;font-weight:800;margin:36px 0 14px;color:var(--ink)}
.pl-page .pl-page-content h3{font-size:22px;font-weight:800;margin:28px 0 12px;color:var(--ink)}
.pl-page .pl-page-content a{color:var(--lime-dim);text-decoration:underline}
.pl-page .pl-page-content ul,.pl-page .pl-page-content ol{margin:0 0 18px 24px}
.pl-page .pl-page-content li{margin-bottom:6px}
.pl-page .pl-page-content blockquote{border-left:3px solid var(--lime);padding:8px 18px;margin:18px 0;background:white;font-style:italic;color:var(--text-mute)}
.pl-page .pl-page-content img{margin:18px 0;border-radius:4px}

/* === RESPONSIVE === */

/* iPad landscape / kleinere laptops (900-1100px) — meer ademruimte zonder volledige desktop layout */
@media (min-width: 900px) and (max-width: 1099px) {
	.pl-wrap { padding: 0 32px; }
	.pl-cta-final { padding: 96px 0; }
	.pl-cta-final .pl-wrap { max-width: 760px; }
	.pl-cta-contact { gap: 32px; }
	.pl-cta-contact-item { flex: 1; min-width: 0; justify-content: flex-start; }
	.pl-cta-final-actions { gap: 16px; }
	.pl-diensten-grid { gap: 24px; }
	.pl-voor-wie-grid { gap: 20px; }
}

/* iPad portrait (768-899px) — net iets ruimer dan klein mobiel */
@media (min-width: 768px) and (max-width: 899px) {
	.pl-wrap { padding: 0 28px; }
	.pl-cta-final { padding: 72px 0; }
	.pl-cta-contact { gap: 28px; flex-direction: row; flex-wrap: wrap; justify-content: center; }
	.pl-cta-contact-item { flex: 0 0 calc(50% - 14px); }
}

@media (max-width:1100px){
	.pl-wrap{padding:0 24px}
	.pl-exp-grid{gap:48px}
	.pl-exp-visual{height:400px}
}
@media (max-width:920px){
	.pl-menu-toggle{display:block}
	.pl-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--ink);border-bottom:1px solid rgba(255,255,255,0.1);padding:18px 24px;flex-direction:column;align-items:stretch;gap:14px}
	.pl-nav.pl-open{display:flex}
	.pl-nav a{padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.06)}
	.pl-nav-cta .pl-btn-ghost{display:none}
	.pl-topbar{position:relative}
	.pl-hero{padding:56px 0 70px}
	.pl-manifest,.pl-diensten,.pl-voor-wie,.pl-expertise,.pl-cta-final{padding:64px 0}
	.pl-manifest-grid{grid-template-columns:1fr;gap:36px}
	.pl-manifest h2{max-width:none}
	.pl-diensten-grid{grid-template-columns:1fr}
	.pl-aud-grid{grid-template-columns:1fr 1fr}
	.pl-exp-grid{grid-template-columns:1fr;gap:40px}
	.pl-exp-visual{height:320px;order:-1}
	.pl-exp-shape{width:220px;height:220px}
	.pl-exp-shape::before{width:280px;height:280px}
	.pl-exp-shape::after{width:340px;height:340px}
	.pl-exp-shape-inner{width:130px;height:130px}
	.pl-exp-shape-inner svg{width:70px;height:70px}
	.pl-footer .pl-wrap{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:600px){
	.pl-wrap{padding:0 18px}
	.pl-topbar{padding:14px 0}
	.pl-hero{padding:50px 0 80px}
	.pl-hero-eyebrow{font-size:10px;letter-spacing:1.8px;padding:6px 14px;margin-bottom:24px}
	.pl-hero p.pl-lead{margin-bottom:32px}
	.pl-hero-cta .pl-btn{padding:14px 24px;font-size:14px}
	.pl-dienst{padding:32px 24px}
	.pl-dienst-icon{width:54px;height:54px;margin-bottom:22px}
	.pl-aud-grid{grid-template-columns:1fr}
	.pl-aud{padding:30px 22px}
	.pl-exp-tag-3{display:block}
	.pl-exp-tag{padding:6px 11px;font-size:10px;letter-spacing:0.3px}
	.pl-exp-tag-1{top:10px;right:-10px}
	.pl-exp-tag-2{bottom:40px;left:-15px}
	.pl-exp-tag-3{top:55%;left:-25px}
	.pl-exp-tag-4{top:10px;left:0}
	.pl-exp-tag-5{bottom:10px;right:-15px}
	.pl-exp-tag-6{top:50%;right:-15px}
	.pl-exp-tag-7{bottom:24px;left:30%}
	.pl-cta-final-actions{flex-direction:column;align-items:stretch}
	.pl-cta-final-actions .pl-btn{justify-content:center}
	.pl-cta-contact{flex-direction:column;align-items:flex-start;gap:20px;padding-left:8px;padding-right:8px}
	.pl-cta-contact-item{width:100%;align-items:center}
	.pl-cta-contact-text{text-align:left;flex:1;min-width:0}
	.pl-cta-contact-value{word-break:break-word;overflow-wrap:anywhere}
	.pl-footer .pl-wrap{grid-template-columns:1fr;gap:28px}
	.pl-foot-bottom{flex-direction:column;text-align:center}
	.pl-section-head{margin-bottom:48px}
}

/* === ARCHIVE & SINGLE PAGES === */
.pl-archive-hero{background:var(--ink);color:white;padding:80px 0 60px;border-bottom:1px solid rgba(255,255,255,0.08)}
.pl-archive-hero .pl-wrap{max-width:820px;text-align:center}
.pl-archive-eyebrow{display:inline-block;font-size:11px;font-weight:800;letter-spacing:2.4px;text-transform:uppercase;color:var(--lime);margin-bottom:16px}
.pl-archive-hero h1{font-size:clamp(32px, 5vw, 52px);line-height:1.05;font-weight:900;letter-spacing:-0.03em;margin-bottom:18px;color:white}
.pl-archive-hero p{font-size:clamp(15px, 1.5vw, 17.5px);color:rgba(255,255,255,0.72);max-width:620px;margin:0 auto;line-height:1.55}

.pl-archive{background:var(--paper);padding:64px 0 100px;min-height:50vh}
.pl-card-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:24px}
.pl-card{background:white;border:1px solid var(--rule);display:block;color:var(--ink);overflow:hidden;transition:all .25s;text-decoration:none}
.pl-card:hover{border-color:var(--ink);transform:translateY(-3px);box-shadow:0 10px 28px rgba(15,15,17,0.08)}
.pl-card-image{aspect-ratio:16/10;overflow:hidden;background:#F4F1EB;display:flex;align-items:center;justify-content:center}
.pl-card-image img{width:100%;height:100%;object-fit:cover}
.pl-card-image-placeholder{color:rgba(15,15,17,0.25)}
.pl-card-body{padding:24px 22px}
.pl-card-tag{font-size:10px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--lime-dim);margin-bottom:10px}
.pl-card h2{font-size:20px;font-weight:800;letter-spacing:-0.3px;line-height:1.25;margin-bottom:10px;color:var(--ink)}
.pl-card p{font-size:14.5px;color:var(--text-mute);line-height:1.5;margin-bottom:16px}
.pl-card-link{display:inline-block;font-size:13.5px;font-weight:700;color:var(--lime-dim);transition:transform .2s}
.pl-card:hover .pl-card-link{transform:translateX(4px)}

.pl-empty{text-align:center;padding:80px 24px;background:white;border:1px dashed var(--rule)}
.pl-empty h2{font-size:24px;font-weight:800;color:var(--ink);margin-bottom:10px}
.pl-empty p{color:var(--text-mute);margin-bottom:24px}

.pl-pagination{margin-top:40px;text-align:center}
.pl-pagination .page-numbers{display:inline-block;padding:10px 16px;margin:0 4px;background:white;border:1px solid var(--rule);color:var(--ink);font-weight:600;text-decoration:none;font-size:14px}
.pl-pagination .page-numbers.current{background:var(--ink);color:var(--lime);border-color:var(--ink)}
.pl-pagination .page-numbers:hover{border-color:var(--ink)}

/* === SINGLE PAGE === */
.pl-single-hero{background:var(--ink);color:white;padding:60px 0 50px;border-bottom:1px solid rgba(255,255,255,0.08)}
.pl-single-hero .pl-wrap{max-width:820px}
.pl-back-link{display:inline-block;font-size:13px;color:rgba(255,255,255,0.6);margin-bottom:24px;transition:color .15s}
.pl-back-link:hover{color:var(--lime)}
.pl-single-eyebrow{display:inline-block;font-size:11px;font-weight:800;letter-spacing:2.4px;text-transform:uppercase;color:var(--lime);margin-bottom:14px}
.pl-single-hero h1{font-size:clamp(28px, 4.5vw, 44px);line-height:1.1;font-weight:900;letter-spacing:-0.03em;margin-bottom:16px;color:white}
.pl-single-lead{font-size:clamp(15px, 1.5vw, 18px);color:rgba(255,255,255,0.75);line-height:1.55;max-width:620px}

.pl-single-body{background:var(--paper);padding:56px 0 90px}
.pl-single-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:48px;align-items:start}
.pl-single-content{}
.pl-single-image{margin-bottom:30px;border:1px solid var(--rule)}
.pl-single-image img{width:100%;height:auto;display:block}
.pl-single-content .pl-page-content{font-size:16.5px;line-height:1.7;color:var(--text)}
.pl-single-aside{position:sticky;top:90px}
.pl-aside-card{background:white;border:1px solid var(--rule);padding:24px 22px;margin-bottom:16px}
.pl-aside-card h3{font-size:16px;font-weight:800;letter-spacing:-0.2px;margin-bottom:10px;color:var(--ink)}
.pl-aside-card p{font-size:14px;color:var(--text-mute);line-height:1.5;margin-bottom:18px}
.pl-aside-card .pl-btn{width:100%;justify-content:center}
.pl-aside-sep{height:1px;background:var(--rule);margin:18px 0}
.pl-aside-contact{font-size:14px;color:var(--text);line-height:1.7}
.pl-aside-contact a{color:var(--lime-dim);font-weight:600}

/* === CONTACT FORM === */
.pl-contact-hero{background:var(--ink);color:white;padding:70px 0 56px;border-bottom:1px solid rgba(255,255,255,0.08)}
.pl-contact-hero .pl-wrap{max-width:820px;text-align:center}
.pl-contact-hero h1{font-size:clamp(30px, 4.5vw, 46px);line-height:1.1;font-weight:900;letter-spacing:-0.03em;margin-bottom:16px;color:white}
.pl-contact-hero p{font-size:clamp(15px, 1.5vw, 17px);color:rgba(255,255,255,0.72);max-width:600px;margin:0 auto;line-height:1.55}

.pl-contact-section{background:var(--paper);padding:64px 0 90px}
.pl-contact-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:start}
.pl-contact-form-wrap{}
.pl-alert{padding:14px 18px;margin-bottom:24px;font-size:14px;line-height:1.5;border-left:3px solid}
.pl-alert-ok{background:#F0FBD9;border-color:var(--lime-dim);color:var(--lime-deep)}
.pl-alert-err{background:#FEF2F2;border-color:#B91C1C;color:#991B1B}

.pl-form{background:white;border:1px solid var(--rule);padding:32px 28px}
.pl-form-row{margin-bottom:18px}
.pl-form-row:last-child{margin-bottom:0}
.pl-form-row label{display:block;font-size:11.5px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;color:var(--text-dim);margin-bottom:6px}
.pl-req{color:#B91C1C}
.pl-form-row input[type=text],.pl-form-row input[type=email],.pl-form-row input[type=tel],.pl-form-row select,.pl-form-row textarea{width:100%;padding:11px 14px;border:1px solid var(--rule);background:white;font-family:inherit;font-size:14.5px;color:var(--text);transition:border-color .15s}
.pl-form-row input:focus,.pl-form-row select:focus,.pl-form-row textarea:focus{outline:none;border-color:var(--ink)}
.pl-form-row textarea{resize:vertical;min-height:120px;line-height:1.5}
.pl-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
.pl-form-grid .pl-form-row{margin-bottom:0}
.pl-form-actions{margin-top:24px;padding-top:20px;border-top:1px solid var(--rule)}
.pl-form-actions .pl-btn{justify-content:center}
.pl-form-note{margin-top:12px;font-size:12.5px;color:var(--text-dim)}

.pl-contact-aside .pl-aside-card{padding:22px 22px}
.pl-contact-direct{}
.pl-contact-direct-item{padding:10px 0;border-bottom:1px solid var(--rule)}
.pl-contact-direct-item:last-child{border-bottom:0}
.pl-contact-direct-label{font-size:10px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;color:var(--text-dim);margin-bottom:3px}
.pl-contact-direct-item a{color:var(--ink);font-weight:600;font-size:14px}
.pl-contact-direct-item a:hover{color:var(--lime-dim)}
.pl-contact-direct-item span{color:var(--ink);font-weight:600;font-size:14px}
.pl-aside-steps{list-style:none;padding:0;counter-reset:step}
.pl-aside-steps li{counter-increment:step;padding:8px 0 8px 30px;position:relative;font-size:13.5px;color:var(--text);line-height:1.5;border-bottom:1px solid var(--rule)}
.pl-aside-steps li:last-child{border-bottom:0}
.pl-aside-steps li::before{content:counter(step);position:absolute;left:0;top:8px;width:22px;height:22px;background:var(--ink);color:var(--lime);border-radius:50%;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;font-family:'SF Mono',ui-monospace,monospace}

/* === RESPONSIVE archieven + contact === */
@media (max-width:980px){
	.pl-card-grid{grid-template-columns:repeat(2, 1fr);gap:18px}
	.pl-single-grid,.pl-contact-grid{grid-template-columns:1fr;gap:32px}
	.pl-single-aside{position:static}
}
@media (max-width:600px){
	.pl-card-grid{grid-template-columns:1fr}
	.pl-archive,.pl-single-body,.pl-contact-section{padding:48px 0 64px}
	.pl-form{padding:24px 20px}
	.pl-form-grid{grid-template-columns:1fr;gap:14px}
}

/* === CONSENT CHECKBOXES === */
.pl-form-consent{margin:18px 0 8px;background:#FAFAF6;padding:14px 18px;border-left:3px solid var(--lime)}
.pl-consent-row{display:flex;align-items:flex-start;gap:12px;padding:6px 0;cursor:pointer;font-size:13px;line-height:1.55;color:var(--text)}
.pl-consent-row input[type=checkbox]{width:18px;height:18px;margin-top:1px;flex-shrink:0;cursor:pointer;accent-color:var(--lime-dim)}
.pl-consent-row a{color:var(--lime-dim);font-weight:600;text-decoration:underline}
.pl-consent-row a:hover{color:var(--ink)}

/* === COMPACT TRAINING-AANVRAAG-FORMULIER === */
.pl-aside-form{padding:24px 22px}
.pl-form-compact{background:transparent;border:0;padding:0}
.pl-form-compact .pl-form-row{margin-bottom:12px}
.pl-form-compact label{font-size:10.5px;margin-bottom:4px}
.pl-form-compact input[type=text],.pl-form-compact input[type=email],.pl-form-compact input[type=tel],.pl-form-compact input[type=number],.pl-form-compact textarea{padding:9px 12px;font-size:13.5px}
.pl-form-compact textarea{min-height:90px}
.pl-form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.pl-form-grid-2 .pl-form-row{margin-bottom:0}
.pl-form-compact .pl-form-consent{margin:14px 0 12px;padding:10px 14px;font-size:12px}
.pl-form-compact .pl-consent-row{font-size:11.5px;gap:9px}
.pl-form-compact .pl-consent-row input[type=checkbox]{width:15px;height:15px}

/* === RELATED ELEARNINGS === */
.pl-related{margin-top:48px;padding-top:32px;border-top:1px solid var(--rule)}
.pl-related h3{font-size:20px;font-weight:800;letter-spacing:-0.3px;color:var(--ink);margin-bottom:18px}
.pl-related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.pl-related-card{background:white;border:1px solid var(--rule);padding:18px 18px 14px;color:var(--ink);transition:all .2s}
.pl-related-card:hover{border-color:var(--ink);transform:translateY(-2px)}
.pl-related-tag{font-size:10px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;color:var(--lime-dim);margin-bottom:8px}
.pl-related-card h4{font-size:15.5px;font-weight:700;line-height:1.3;margin-bottom:6px;letter-spacing:-0.2px}
.pl-related-card p{font-size:13px;color:var(--text-mute);line-height:1.5;margin-bottom:10px}
.pl-related-link{font-size:12px;font-weight:700;color:var(--lime-dim)}

/* === MOBILE TRAINING-AANVRAAG FORM === */
@media (max-width:600px){
	.pl-related-grid{grid-template-columns:1fr}
	.pl-form-grid-2{grid-template-columns:1fr}
}

/* ==========================================================================
   GEANIMEERDE CARDS (Option C)
   ========================================================================== */
.pl-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pl-card-grid .pl-card{background:white;border:1px solid var(--rule);display:flex;flex-direction:column;overflow:hidden;transition:all .25s;text-decoration:none;color:var(--ink)}
.pl-card-grid .pl-card:hover{border-color:var(--ink);transform:translateY(-3px);box-shadow:0 12px 28px rgba(15,15,17,0.08)}
.pl-card-visual{aspect-ratio:16/10;position:relative;overflow:hidden;background:var(--ink);display:flex;align-items:center;justify-content:center}
.pl-card-topic-tag{position:absolute;top:18px;left:18px;background:rgba(15,15,17,0.6);backdrop-filter:blur(8px);color:var(--lime);font-size:10px;font-weight:800;letter-spacing:1.8px;text-transform:uppercase;padding:5px 11px;border-radius:100px;z-index:3;border:1px solid rgba(181,248,74,0.25)}
.pl-card-duration{position:absolute;bottom:18px;right:18px;color:rgba(181,248,74,0.85);font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;z-index:3}

.pl-card-grid .pl-card .pl-card-body{padding:22px 22px}
.pl-card-grid .pl-card .pl-card-tag{font-size:10px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--lime-dim);margin-bottom:10px}
.pl-card-grid .pl-card h2{font-size:19px;font-weight:800;letter-spacing:-0.3px;line-height:1.28;margin-bottom:10px}
.pl-card-grid .pl-card p{font-size:14px;color:var(--text-mute);line-height:1.5;margin-bottom:16px}
.pl-card-link{font-size:13px;font-weight:700;color:var(--lime-dim);transition:transform .2s;display:inline-block}
.pl-card-grid .pl-card:hover .pl-card-link{transform:translateX(4px)}

/* ANIMATIE 1: pulserend schild */
@keyframes pl-shieldPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:0.85}}
@keyframes pl-shieldRing{0%{transform:scale(0.8);opacity:0.8}100%{transform:scale(1.6);opacity:0}}
.pl-anim-shield{position:relative;width:120px;height:120px}
.pl-anim-shield .pl-shield-ring{position:absolute;inset:0;border:2px solid var(--lime);border-radius:50%;animation:pl-shieldRing 2.5s infinite ease-out}
.pl-anim-shield .pl-shield-ring:nth-child(2){animation-delay:.8s}
.pl-anim-shield .pl-shield-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;animation:pl-shieldPulse 3s infinite ease-in-out;color:var(--lime)}
.pl-anim-shield .pl-shield-icon svg{width:64px;height:64px}

/* ANIMATIE 2: radar */
@keyframes pl-radarSweep{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
.pl-anim-radar{position:relative;width:140px;height:140px}
.pl-anim-radar .pl-radar-rings{position:absolute;inset:0}
.pl-anim-radar .pl-radar-rings::before,.pl-anim-radar .pl-radar-rings::after{content:'';position:absolute;border:1.5px solid rgba(181,248,74,0.25);border-radius:50%}
.pl-anim-radar .pl-radar-rings::before{inset:25%}
.pl-anim-radar .pl-radar-rings::after{inset:0}
.pl-anim-radar .pl-radar-rings span{position:absolute;inset:12%;border:1.5px solid rgba(181,248,74,0.4);border-radius:50%}
.pl-anim-radar .pl-radar-sweep{position:absolute;inset:0;animation:pl-radarSweep 3s infinite linear;transform-origin:center}
.pl-anim-radar .pl-radar-sweep::before{content:'';position:absolute;top:50%;left:50%;width:50%;height:2px;background:linear-gradient(90deg,var(--lime),transparent);transform-origin:left center}
.pl-anim-radar .pl-radar-dot{position:absolute;width:8px;height:8px;background:var(--lime);border-radius:50%;top:30%;right:25%;box-shadow:0 0 12px var(--lime);animation:pl-shieldPulse 1.5s infinite}

/* ANIMATIE 3: data bars */
@keyframes pl-lineGrow{0%,100%{transform:scaleY(1)}50%{transform:scaleY(1.4)}}
.pl-anim-bars{display:flex;align-items:end;gap:6px;height:120px}
.pl-anim-bars span{width:10px;background:var(--lime);border-radius:2px;animation:pl-lineGrow 1.8s infinite ease-in-out;transform-origin:bottom}
.pl-anim-bars span:nth-child(1){height:30%;animation-delay:0s}
.pl-anim-bars span:nth-child(2){height:55%;animation-delay:.15s}
.pl-anim-bars span:nth-child(3){height:80%;animation-delay:.3s}
.pl-anim-bars span:nth-child(4){height:45%;animation-delay:.45s}
.pl-anim-bars span:nth-child(5){height:90%;animation-delay:.6s}
.pl-anim-bars span:nth-child(6){height:65%;animation-delay:.75s}
.pl-anim-bars span:nth-child(7){height:35%;animation-delay:.9s}

/* ANIMATIE 4: concentrische pulse */
@keyframes pl-dotFloat{0%,100%{transform:translate(0,0)}33%{transform:translate(10px,-8px)}66%{transform:translate(-6px,10px)}}
.pl-anim-pulse{position:relative;width:140px;height:140px;display:flex;align-items:center;justify-content:center}
.pl-anim-pulse .pl-pulse-circle{position:absolute;border:1.5px solid var(--lime);border-radius:50%;opacity:0.3}
.pl-anim-pulse .pl-pulse-circle:nth-child(1){inset:0;animation:pl-shieldPulse 3s infinite}
.pl-anim-pulse .pl-pulse-circle:nth-child(2){inset:18%;animation:pl-shieldPulse 3s infinite .5s}
.pl-anim-pulse .pl-pulse-circle:nth-child(3){inset:36%;animation:pl-shieldPulse 3s infinite 1s}
.pl-anim-pulse .pl-pulse-center{position:relative;z-index:2;color:var(--lime)}
.pl-anim-pulse .pl-pulse-center svg{width:56px;height:56px}
.pl-anim-pulse .pl-floating-dot{position:absolute;width:6px;height:6px;background:var(--lime);border-radius:50%;opacity:0.7;box-shadow:0 0 8px rgba(181,248,74,0.6)}
.pl-anim-pulse .pl-floating-dot:nth-child(4){top:15%;left:20%;animation:pl-dotFloat 4s infinite}
.pl-anim-pulse .pl-floating-dot:nth-child(5){top:75%;right:18%;animation:pl-dotFloat 5s infinite .8s}
.pl-anim-pulse .pl-floating-dot:nth-child(6){top:50%;left:8%;animation:pl-dotFloat 4.5s infinite 1.4s}

/* Versnel bij hover */
.pl-card-grid .pl-card:hover .pl-shield-ring,.pl-card-grid .pl-card:hover .pl-shield-icon{animation-duration:1.5s}
.pl-card-grid .pl-card:hover .pl-radar-sweep{animation-duration:1.5s}
.pl-card-grid .pl-card:hover .pl-pulse-circle{animation-duration:1.5s}

@media (max-width:980px){.pl-card-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.pl-card-grid{grid-template-columns:1fr}}
@media (prefers-reduced-motion: reduce){
	.pl-shield-ring,.pl-shield-icon,.pl-radar-sweep,.pl-radar-dot,.pl-pulse-circle,.pl-floating-dot,.pl-anim-bars span{animation:none !important}
}

/* ==========================================================================
   B1-DETAIL PAGE STYLING
   ========================================================================== */
.pl-detail-meta-bar{background:var(--ink-2);border-top:1px solid rgba(255,255,255,0.06);padding:14px 0;color:rgba(255,255,255,0.75)}
.pl-detail-meta-bar .pl-wrap{display:flex;gap:32px;flex-wrap:wrap;font-size:13.5px}
.pl-detail-meta-bar strong{color:white;font-weight:700;margin-right:6px}

.pl-quick-box{background:white;border:1px solid var(--rule);padding:24px 26px;margin-bottom:28px;border-left:4px solid var(--lime)}
.pl-quick-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.pl-quick-icon{width:28px;height:28px;background:var(--lime);color:var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:14px}
.pl-quick-head strong{font-size:14px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;color:var(--ink)}
.pl-quick-box ul{list-style:none;padding:0;margin:0}
.pl-quick-box li{padding:6px 0 6px 26px;position:relative;font-size:15px;line-height:1.55;color:var(--text)}
.pl-quick-box li::before{content:'';position:absolute;left:0;top:14px;width:14px;height:2px;background:var(--lime-dim)}

.pl-aside-meta-list{display:flex;flex-direction:column;gap:0;font-size:14px}
.pl-aside-meta-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--rule);gap:12px}
.pl-aside-meta-row:last-child{border-bottom:0}
.pl-aside-meta-label{color:var(--text-dim);font-size:11px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;flex-shrink:0}
.pl-aside-meta-value{color:var(--ink);font-weight:700;text-align:right}

/* B1-prose typografie: korter, ruimer, makkelijker te lezen */
.pl-b1-prose{font-size:16px;line-height:1.7;color:var(--text);max-width:680px}
.pl-b1-prose p{margin-bottom:14px}
.pl-b1-prose h2{font-size:24px;font-weight:800;letter-spacing:-0.3px;margin:36px 0 14px;color:var(--ink);line-height:1.2}
.pl-b1-prose h2:first-child{margin-top:0}
.pl-b1-prose h3{font-size:19px;font-weight:700;margin:24px 0 10px;color:var(--ink)}
.pl-b1-prose ul,.pl-b1-prose ol{margin:14px 0 18px 20px}
.pl-b1-prose li{margin-bottom:6px}
.pl-b1-prose strong{color:var(--ink);font-weight:700}
.pl-b1-prose blockquote{border-left:3px solid var(--lime);padding:8px 18px;margin:18px 0;background:white;color:var(--text-mute);font-style:italic}

.pl-b1-tag{display:inline-flex;align-items:center;gap:6px;background:#F0FBD9;color:var(--lime-deep);font-size:11px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;padding:5px 11px;border-radius:100px;margin-bottom:20px}

/* ==========================================================================
   ANIMATIES 5-8 + FOTO-CARD (extensie voor sprekers/producten/trainingen)
   ========================================================================== */

/* ANIMATIE 5: roterende zeshoeken */
@keyframes pl-hexRotate{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.pl-anim-hex{position:relative;width:130px;height:130px;color:var(--lime)}
.pl-anim-hex .pl-hex-rotate{position:absolute;inset:0;animation:pl-hexRotate 18s linear infinite;transform-origin:center}
.pl-card-grid .pl-card:hover .pl-anim-hex .pl-hex-rotate{animation-duration:6s}

/* ANIMATIE 6: oog met scan-lijn */
@keyframes pl-eyeScan{0%,100%{transform:translateY(-22px)}50%{transform:translateY(22px)}}
.pl-anim-eye{position:relative;width:140px;height:90px;color:var(--lime)}
.pl-anim-eye svg{width:100%;height:100%}
.pl-anim-eye .pl-eye-scan{position:absolute;top:50%;left:8%;right:8%;height:2px;background:linear-gradient(90deg,transparent,var(--lime),transparent);box-shadow:0 0 8px var(--lime);animation:pl-eyeScan 2.5s ease-in-out infinite}

/* ANIMATIE 7: diagonale lijnen die over het frame schuiven */
@keyframes pl-lineSlide{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.pl-anim-lines{position:relative;width:140px;height:120px;overflow:hidden;display:flex;flex-direction:column;gap:14px;justify-content:center}
.pl-anim-lines span{display:block;height:3px;background:var(--lime);opacity:0.7;border-radius:2px;animation:pl-lineSlide 3s ease-in-out infinite}
.pl-anim-lines span:nth-child(1){width:60%;animation-delay:0s}
.pl-anim-lines span:nth-child(2){width:90%;animation-delay:.3s}
.pl-anim-lines span:nth-child(3){width:40%;animation-delay:.6s}
.pl-anim-lines span:nth-child(4){width:75%;animation-delay:.9s}
.pl-anim-lines span:nth-child(5){width:55%;animation-delay:1.2s}
.pl-card-grid .pl-card:hover .pl-anim-lines span{animation-duration:1.5s}

/* ANIMATIE 8: slot met expanderende ring */
@keyframes pl-lockRingPulse{0%{transform:scale(0.7);opacity:0.9}100%{transform:scale(1.4);opacity:0}}
@keyframes pl-lockBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.pl-anim-lock{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}
.pl-anim-lock .pl-lock-icon{color:var(--lime);width:64px;height:64px;animation:pl-lockBob 3s ease-in-out infinite;position:relative;z-index:2}
.pl-anim-lock .pl-lock-ring{position:absolute;inset:5%;border:2px solid var(--lime);border-radius:14px;animation:pl-lockRingPulse 2.4s ease-out infinite}
.pl-anim-lock .pl-lock-ring:nth-child(3){animation-delay:1.2s}
.pl-card-grid .pl-card:hover .pl-anim-lock .pl-lock-ring{animation-duration:1.2s}

/* FOTO-CARD (sprekers) */
.pl-card-visual.pl-card-photo{background-size:cover;background-position:center;background-color:var(--ink)}
.pl-card-visual.pl-card-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,15,17,0.05) 0%,rgba(15,15,17,0.7) 100%);pointer-events:none}
.pl-card-visual.pl-card-photo .pl-card-topic-tag{background:rgba(15,15,17,0.8);z-index:4}
.pl-card-visual.pl-card-photo .pl-card-duration{color:white;z-index:4;text-shadow:0 1px 4px rgba(0,0,0,0.6)}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
	.pl-hex-rotate,.pl-eye-scan,.pl-anim-lines span,.pl-lock-icon,.pl-lock-ring{animation:none !important}
}

/* ==========================================================================
   FIX — Headings binnen lime-secties moeten zwart zijn
   Override de oude theme die h1-h5 standaard wit kleurt.
   ========================================================================== */
.pl-manifest h1, .pl-manifest h2, .pl-manifest h3, .pl-manifest h4, .pl-manifest h5,
.pl-voor-wie h1, .pl-voor-wie h2, .pl-voor-wie h3, .pl-voor-wie h4, .pl-voor-wie h5{
	color: var(--ink) !important;
}
.pl-manifest p, .pl-voor-wie p{
	color: rgba(15,15,17,0.78);
}

/* ==========================================================================
   ONDERWERP-SPECIFIEKE ANIMATIES (kassa / computer / klas)
   ========================================================================== */

/* KASSA — scan-beam loopt heen en weer */
@keyframes pl-kassaBeam{
	0%,100%{transform:translateX(-22px);opacity:0.3}
	50%{transform:translateX(22px);opacity:1}
}
.pl-anim-kassa-wrap{position:relative;width:135px;height:110px;color:var(--lime)}
.pl-anim-kassa-wrap svg{width:100%;height:100%}
.pl-anim-kassa-wrap .pl-kassa-beam{position:absolute;top:24%;left:50%;width:2px;height:14px;background:var(--lime);box-shadow:0 0 8px var(--lime);animation:pl-kassaBeam 2s ease-in-out infinite;transform-origin:center;margin-left:-1px}
.pl-card:hover .pl-anim-kassa-wrap .pl-kassa-beam{animation-duration:1s}

/* COMPUTER — code-regels veranderen van breedte (typing-feel) */
@keyframes pl-codeLine{0%,100%{width:30%}50%{width:80%}}
.pl-anim-computer-wrap{position:relative;width:140px;height:100px;color:var(--lime)}
.pl-anim-computer-wrap svg{width:100%;height:100%}
.pl-computer-screen{position:absolute;top:22%;left:20%;right:20%;display:flex;flex-direction:column;gap:5px}
.pl-computer-screen span{display:block;height:2.5px;background:var(--lime);border-radius:2px;animation:pl-codeLine 1.6s ease-in-out infinite}
.pl-computer-screen span:nth-child(1){animation-delay:0s}
.pl-computer-screen span:nth-child(2){animation-delay:.2s}
.pl-computer-screen span:nth-child(3){animation-delay:.4s}
.pl-computer-screen span:nth-child(4){animation-delay:.6s}
.pl-card:hover .pl-computer-screen span{animation-duration:.8s}

/* KLAS — krijt-lijntjes verschijnen op het bord */
@keyframes pl-chalkDraw{
	0%,15%{transform:scaleX(0);opacity:0}
	35%,75%{transform:scaleX(1);opacity:1}
	95%,100%{transform:scaleX(0);opacity:0}
}
.pl-anim-klas-wrap{position:relative;width:155px;height:100px;color:var(--lime)}
.pl-anim-klas-wrap svg{width:100%;height:100%}
.pl-klas-chalk{position:absolute;top:22%;left:16%;right:16%;display:flex;flex-direction:column;gap:7px}
.pl-klas-chalk span{display:block;height:2px;background:var(--lime);border-radius:1px;transform-origin:left;animation:pl-chalkDraw 5s ease-in-out infinite}
.pl-klas-chalk span:nth-child(1){width:75%;animation-delay:0s}
.pl-klas-chalk span:nth-child(2){width:55%;animation-delay:.6s}
.pl-klas-chalk span:nth-child(3){width:85%;animation-delay:1.2s}
.pl-klas-chalk span:nth-child(4){width:50%;animation-delay:1.8s}

@media (prefers-reduced-motion: reduce){
	.pl-kassa-beam,.pl-computer-screen span,.pl-klas-chalk span{animation:none !important}
}

/* ==========================================================================
   FORCE — ALLES in lime secties is zwart (geen wit meer)
   ========================================================================== */
.pl-manifest, .pl-manifest *,
.pl-voor-wie, .pl-voor-wie * {
	color: var(--ink) !important;
}
/* Behalve nummerpills die zelf lime tekst op zwart hebben */
.pl-manifest .pl-manifest-num, .pl-manifest h2 em, 
.pl-voor-wie h2 em {
	color: var(--lime) !important;
}
/* Eyebrow nog steeds donker-groen */
.pl-manifest-eyebrow {
	color: var(--lime-deep) !important;
}
/* P-tekst iets minder zwart voor leesbaarheid */
.pl-manifest p, .pl-voor-wie p,
.pl-manifest-item p {
	color: rgba(15,15,17,0.78) !important;
}

/* ==========================================================================
   DONKERE CTA-FINAL — witte tekst, lime accentvlakken
   ========================================================================== */
.pl-cta-final, .pl-cta-final * {
	color: #FFFFFF !important;
}
/* Accentvlakken: zwarte tekst op lime achtergrond */
.pl-cta-final h2 em,
.pl-cta-final-eyebrow, .pl-cta-final-eyebrow *,
.pl-cta-contact-icon, .pl-cta-contact-icon * {
	color: var(--ink) !important;
}
/* Paragraaf en labels gedimd wit voor rust */
.pl-cta-final p {
	color: rgba(255,255,255,0.78) !important;
}
.pl-cta-contact-label {
	color: rgba(255,255,255,0.6) !important;
}

/* ==========================================================================
   TOPIC-SPECIFIEKE CARD ALIASES
   Onze nieuwe class-namen koppelen aan bestaande animatie-CSS
   ========================================================================== */
.pl-anim-topic-shield { /* hergebruik anim-1 */ }
.pl-anim-topic-shield .pl-shield-ring,
.pl-anim-topic-shield .pl-shield-icon {  /* erft van bestaande regels indien class .pl-anim-shield ook gebruikt */ }

/* GEBOUW — ramen knipperen één voor één */
@keyframes pl-buildingBlink{0%,80%{opacity:0.2}90%{opacity:1}100%{opacity:0.2}}
.pl-anim-building{position:relative;width:120px;height:120px;color:var(--lime)}
.pl-anim-building svg{width:100%;height:100%}
.pl-anim-building .pl-building-light{position:absolute;width:9px;height:11px;background:var(--lime);box-shadow:0 0 6px var(--lime);top:46px;left:30px;animation:pl-buildingBlink 4s infinite}
.pl-anim-building .pl-building-light:nth-child(3){animation-delay:1.3s}
.pl-anim-building .pl-building-light:nth-child(4){animation-delay:2.6s}
.pl-card:hover .pl-anim-building .pl-building-light{animation-duration:2s}

/* Maak topic-classes compatibel met bestaande animatie-css */
.pl-anim-topic-shield   .pl-shield-ring{position:absolute;inset:0;border:2px solid var(--lime);border-radius:50%;animation:pl-shieldRing 2.5s infinite ease-out}
.pl-anim-topic-shield   .pl-shield-ring:nth-child(2){animation-delay:.8s}
.pl-anim-topic-shield   .pl-shield-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;animation:pl-shieldPulse 3s infinite ease-in-out;color:var(--lime)}
.pl-anim-topic-shield   .pl-shield-icon svg{width:64px;height:64px}

/* lock alias */
.pl-anim-topic-lock     .pl-lock-icon{color:var(--lime);width:64px;height:64px;animation:pl-lockBob 3s ease-in-out infinite;position:relative;z-index:2}
.pl-anim-topic-lock     .pl-lock-ring{position:absolute;inset:5%;border:2px solid var(--lime);border-radius:14px;animation:pl-lockRingPulse 2.4s ease-out infinite}
.pl-anim-topic-lock     .pl-lock-ring:nth-child(3){animation-delay:1.2s}
.pl-anim-topic-lock{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
	.pl-building-light{animation:none !important}
}

/* ==========================================================================
   RUSTIGER ANIMATIES — vervangt alle eerdere snelle bewegingen
   Tragere cycli (6-15s) + kleinere amplitudes + zachtere fades
   ========================================================================== */

/* === SCHILD — langzame ademhaling, geen scherpe ringen meer === */
@keyframes pl-shieldPulse {
	0%, 100% { transform: scale(1); opacity: 1; }
	50%      { transform: scale(1.02); opacity: 0.92; }
}
@keyframes pl-shieldRing {
	0%   { transform: scale(0.95); opacity: 0.45; }
	100% { transform: scale(1.25); opacity: 0; }
}
.pl-anim-shield .pl-shield-ring,
.pl-anim-topic-shield .pl-shield-ring {
	animation: pl-shieldRing 8s infinite ease-out !important;
}
.pl-anim-shield .pl-shield-ring:nth-child(2),
.pl-anim-topic-shield .pl-shield-ring:nth-child(2) {
	animation-delay: 4s !important;
}
.pl-anim-shield .pl-shield-icon,
.pl-anim-topic-shield .pl-shield-icon {
	animation: pl-shieldPulse 10s infinite ease-in-out !important;
}

/* === RADAR — vier keer trager === */
.pl-anim-radar .pl-radar-sweep {
	animation: pl-radarSweep 12s infinite linear !important;
}
.pl-anim-radar .pl-radar-dot {
	animation: pl-shieldPulse 6s infinite !important;
}

/* === DATA BARS — zacht golven, kleinere amplitude === */
@keyframes pl-lineGrow {
	0%, 100% { transform: scaleY(1); opacity: 0.85; }
	50%      { transform: scaleY(1.12); opacity: 1; }
}
.pl-anim-bars span {
	animation: pl-lineGrow 6s infinite ease-in-out !important;
}
.pl-anim-bars span:nth-child(1) { animation-delay: 0s    !important; }
.pl-anim-bars span:nth-child(2) { animation-delay: 0.6s  !important; }
.pl-anim-bars span:nth-child(3) { animation-delay: 1.2s  !important; }
.pl-anim-bars span:nth-child(4) { animation-delay: 1.8s  !important; }
.pl-anim-bars span:nth-child(5) { animation-delay: 2.4s  !important; }
.pl-anim-bars span:nth-child(6) { animation-delay: 3s    !important; }
.pl-anim-bars span:nth-child(7) { animation-delay: 3.6s  !important; }

/* === PULSE — trage ademhaling, drijvende stippen subtieler === */
.pl-anim-pulse .pl-pulse-circle:nth-child(1) { animation: pl-shieldPulse 8s infinite        !important; }
.pl-anim-pulse .pl-pulse-circle:nth-child(2) { animation: pl-shieldPulse 8s infinite 1.5s   !important; }
.pl-anim-pulse .pl-pulse-circle:nth-child(3) { animation: pl-shieldPulse 8s infinite 3s     !important; }
@keyframes pl-dotFloat {
	0%, 100% { transform: translate(0, 0); }
	33%      { transform: translate(4px, -3px); }
	66%      { transform: translate(-2px, 4px); }
}
.pl-anim-pulse .pl-floating-dot:nth-child(4) { animation: pl-dotFloat 10s infinite        !important; }
.pl-anim-pulse .pl-floating-dot:nth-child(5) { animation: pl-dotFloat 12s infinite 2s     !important; }
.pl-anim-pulse .pl-floating-dot:nth-child(6) { animation: pl-dotFloat 11s infinite 4s     !important; }

/* === HEXAGON — bijna stilstaand === */
.pl-anim-hex .pl-hex-rotate {
	animation: pl-hexRotate 60s linear infinite !important;
}

/* === OOG — scan-lijn beweegt traag === */
@keyframes pl-eyeScan {
	0%, 100% { transform: translateY(-12px); opacity: 0.6; }
	50%      { transform: translateY(12px);  opacity: 1; }
}
.pl-anim-eye .pl-eye-scan {
	animation: pl-eyeScan 8s ease-in-out infinite !important;
}

/* === SCHUIVENDE LIJNEN — langer schuif-interval === */
.pl-anim-lines span {
	animation: pl-lineSlide 8s ease-in-out infinite !important;
}
.pl-anim-lines span:nth-child(1) { animation-delay: 0s    !important; }
.pl-anim-lines span:nth-child(2) { animation-delay: 0.8s  !important; }
.pl-anim-lines span:nth-child(3) { animation-delay: 1.6s  !important; }
.pl-anim-lines span:nth-child(4) { animation-delay: 2.4s  !important; }
.pl-anim-lines span:nth-child(5) { animation-delay: 3.2s  !important; }

/* === SLOT — ring expandeert traag, slot wipt nauwelijks === */
@keyframes pl-lockRingPulse {
	0%   { transform: scale(0.85); opacity: 0.6; }
	100% { transform: scale(1.15); opacity: 0; }
}
@keyframes pl-lockBob {
	0%, 100% { transform: translateY(0); }
	50%      { transform: translateY(-2px); }
}
.pl-anim-lock .pl-lock-icon,
.pl-anim-topic-lock .pl-lock-icon {
	animation: pl-lockBob 8s ease-in-out infinite !important;
}
.pl-anim-lock .pl-lock-ring,
.pl-anim-topic-lock .pl-lock-ring {
	animation: pl-lockRingPulse 6s ease-out infinite !important;
}
.pl-anim-lock .pl-lock-ring:nth-child(3),
.pl-anim-topic-lock .pl-lock-ring:nth-child(3) {
	animation-delay: 3s !important;
}

/* === KASSA — scan-beam glijdt rustig === */
@keyframes pl-kassaBeam {
	0%, 100% { transform: translateX(-14px); opacity: 0.3; }
	50%      { transform: translateX(14px);  opacity: 0.9; }
}
.pl-anim-kassa-wrap .pl-kassa-beam {
	animation: pl-kassaBeam 6s ease-in-out infinite !important;
}

/* === COMPUTER — code-regels veranderen langzaam === */
@keyframes pl-codeLine {
	0%, 100% { width: 40%; opacity: 0.7; }
	50%      { width: 75%; opacity: 1; }
}
.pl-computer-screen span {
	animation: pl-codeLine 5s ease-in-out infinite !important;
}
.pl-computer-screen span:nth-child(1) { animation-delay: 0s    !important; }
.pl-computer-screen span:nth-child(2) { animation-delay: 0.6s  !important; }
.pl-computer-screen span:nth-child(3) { animation-delay: 1.2s  !important; }
.pl-computer-screen span:nth-child(4) { animation-delay: 1.8s  !important; }

/* === KLAS — krijt tekent langzaam, lange pauzes === */
@keyframes pl-chalkDraw {
	0%, 8%   { transform: scaleX(0); opacity: 0; }
	25%, 75% { transform: scaleX(1); opacity: 1; }
	92%, 100%{ transform: scaleX(0); opacity: 0; }
}
.pl-klas-chalk span {
	animation: pl-chalkDraw 10s ease-in-out infinite !important;
}
.pl-klas-chalk span:nth-child(1) { animation-delay: 0s   !important; }
.pl-klas-chalk span:nth-child(2) { animation-delay: 1.2s !important; }
.pl-klas-chalk span:nth-child(3) { animation-delay: 2.4s !important; }
.pl-klas-chalk span:nth-child(4) { animation-delay: 3.6s !important; }

/* === GEBOUW — ramen knipperen rustig, geen flikkers === */
@keyframes pl-buildingBlink {
	0%, 100% { opacity: 0.55; }
	50%      { opacity: 1; }
}
.pl-anim-building .pl-building-light {
	animation: pl-buildingBlink 7s ease-in-out infinite !important;
}
.pl-anim-building .pl-building-light:nth-child(3) { animation-delay: 2.3s !important; }
.pl-anim-building .pl-building-light:nth-child(4) { animation-delay: 4.6s !important; }

/* === HOVER — versneld iets, maar nog steeds rustig === */
.pl-card:hover .pl-shield-icon,
.pl-card:hover .pl-shield-ring,
.pl-card:hover .pl-radar-sweep,
.pl-card:hover .pl-pulse-circle,
.pl-card:hover .pl-eye-scan,
.pl-card:hover .pl-anim-lines span,
.pl-card:hover .pl-lock-icon,
.pl-card:hover .pl-lock-ring,
.pl-card:hover .pl-kassa-beam,
.pl-card:hover .pl-computer-screen span,
.pl-card:hover .pl-building-light,
.pl-card:hover .pl-anim-bars span {
	animation-duration: 4s !important;
}

/* ==========================================================================
   UNIEKE VARIATIE PER KAART
   --pl-spd:   snelheidsfactor (0.75 - 1.5)
   --pl-dly:   vertraging (0 - 2.4s)
   --pl-scale: visuele schaal (0.88 - 1.15)
   --pl-flip:  -1 of 1 (mirror)
   --pl-dir:   normal / reverse
   ========================================================================== */

/* Schaal toepassen op alle animatie-wrappers */
.pl-card-visual > div[class*="pl-anim-"] {
	transform: scale(var(--pl-scale, 1)) scaleX(calc(var(--pl-flip, 1)));
}

/* Bestaande animaties — duration nu gebaseerd op --pl-spd-factor */
.pl-anim-shield .pl-shield-ring,
.pl-anim-topic-shield .pl-shield-ring {
	animation: pl-shieldRing calc(8s * var(--pl-spd, 1)) infinite ease-out var(--pl-dir, normal) !important;
	animation-delay: var(--pl-dly, 0s) !important;
}
.pl-anim-shield .pl-shield-icon,
.pl-anim-topic-shield .pl-shield-icon {
	animation: pl-shieldPulse calc(10s * var(--pl-spd, 1)) infinite ease-in-out !important;
	animation-delay: calc(var(--pl-dly, 0s) * 0.5) !important;
}

.pl-anim-radar .pl-radar-sweep {
	animation: pl-radarSweep calc(12s * var(--pl-spd, 1)) infinite linear var(--pl-dir, normal) !important;
	animation-delay: var(--pl-dly, 0s) !important;
}

.pl-anim-bars span {
	animation: pl-lineGrow calc(6s * var(--pl-spd, 1)) infinite ease-in-out !important;
}

.pl-anim-pulse .pl-pulse-circle:nth-child(1) { animation: pl-shieldPulse calc(8s * var(--pl-spd, 1)) infinite calc(var(--pl-dly, 0s) + 0s)   !important; }
.pl-anim-pulse .pl-pulse-circle:nth-child(2) { animation: pl-shieldPulse calc(8s * var(--pl-spd, 1)) infinite calc(var(--pl-dly, 0s) + 1.5s) !important; }
.pl-anim-pulse .pl-pulse-circle:nth-child(3) { animation: pl-shieldPulse calc(8s * var(--pl-spd, 1)) infinite calc(var(--pl-dly, 0s) + 3s)   !important; }

.pl-anim-eye .pl-eye-scan {
	animation: pl-eyeScan calc(8s * var(--pl-spd, 1)) ease-in-out infinite var(--pl-dir, normal) !important;
	animation-delay: var(--pl-dly, 0s) !important;
}

.pl-anim-lock .pl-lock-icon,
.pl-anim-topic-lock .pl-lock-icon {
	animation: pl-lockBob calc(8s * var(--pl-spd, 1)) ease-in-out infinite !important;
}
.pl-anim-lock .pl-lock-ring,
.pl-anim-topic-lock .pl-lock-ring {
	animation: pl-lockRingPulse calc(6s * var(--pl-spd, 1)) ease-out infinite !important;
	animation-delay: var(--pl-dly, 0s) !important;
}

.pl-anim-kassa-wrap .pl-kassa-beam {
	animation: pl-kassaBeam calc(6s * var(--pl-spd, 1)) ease-in-out infinite var(--pl-dir, normal) !important;
	animation-delay: var(--pl-dly, 0s) !important;
}

.pl-computer-screen span {
	animation: pl-codeLine calc(5s * var(--pl-spd, 1)) ease-in-out infinite !important;
}

.pl-klas-chalk span {
	animation: pl-chalkDraw calc(10s * var(--pl-spd, 1)) ease-in-out infinite !important;
}

.pl-anim-building .pl-building-light {
	animation: pl-buildingBlink calc(7s * var(--pl-spd, 1)) ease-in-out infinite !important;
	animation-delay: var(--pl-dly, 0s) !important;
}

/* ==========================================================================
   NIEUWE VARIANT-ANIMATIES
   ========================================================================== */

/* WINKELMANDJE — items dalen één voor één */
@keyframes pl-basketDrop {
	0%, 25%   { transform: translateY(-30px); opacity: 0; }
	35%, 80%  { transform: translateY(0); opacity: 1; }
	95%, 100% { transform: translateY(-30px); opacity: 0; }
}
.pl-anim-basket-wrap { position: relative; width: 140px; height: 110px; color: var(--lime); }
.pl-anim-basket-wrap svg { width: 100%; height: 100%; }
.pl-basket-item {
	position: absolute; top: 60%; width: 8px; height: 8px;
	background: var(--lime); border-radius: 2px;
	animation: pl-basketDrop calc(7s * var(--pl-spd, 1)) ease-in-out infinite;
}
.pl-anim-basket-wrap .pl-basket-item:nth-child(2) { animation-delay: calc(var(--pl-dly, 0s) + 0s); }
.pl-anim-basket-wrap .pl-basket-item:nth-child(3) { animation-delay: calc(var(--pl-dly, 0s) + 1.5s); }
.pl-anim-basket-wrap .pl-basket-item:nth-child(4) { animation-delay: calc(var(--pl-dly, 0s) + 3s); }

/* NETWERK — knooppunten gloeien */
@keyframes pl-netNode { 0%, 100% { opacity: 0.5; transform: scale(1); } 50% { opacity: 1; transform: scale(1.15); } }
@keyframes pl-netLine { 0%, 100% { opacity: 0.25; } 50% { opacity: 0.8; } }
.pl-anim-network-wrap { position: relative; width: 140px; height: 110px; color: var(--lime); }
.pl-anim-network-wrap svg { width: 100%; height: 100%; }
.pl-net-node {
	animation: pl-netNode calc(6s * var(--pl-spd, 1)) ease-in-out infinite;
	transform-origin: center;
}
.pl-anim-network-wrap .pl-net-node:nth-child(3) { animation-delay: calc(var(--pl-dly, 0s) + 0.4s); }
.pl-anim-network-wrap .pl-net-node:nth-child(4) { animation-delay: calc(var(--pl-dly, 0s) + 0.8s); }
.pl-anim-network-wrap .pl-net-node:nth-child(5) { animation-delay: calc(var(--pl-dly, 0s) + 1.2s); }
.pl-anim-network-wrap .pl-net-node:nth-child(6) { animation-delay: calc(var(--pl-dly, 0s) + 1.6s); }
.pl-anim-network-wrap .pl-net-node:nth-child(7) { animation-delay: calc(var(--pl-dly, 0s) + 2s); }
.pl-net-line { stroke: var(--lime); animation: pl-netLine calc(8s * var(--pl-spd, 1)) ease-in-out infinite; }
.pl-anim-network-wrap .pl-net-line:nth-child(2) { animation-delay: 0.5s; }
.pl-anim-network-wrap .pl-net-line:nth-child(3) { animation-delay: 1s; }
.pl-anim-network-wrap .pl-net-line:nth-child(4) { animation-delay: 1.5s; }

/* BOEKEN — stapel ademt */
@keyframes pl-bookFloat { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }
.pl-anim-books-wrap { position: relative; width: 140px; height: 110px; color: var(--lime); }
.pl-anim-books-wrap svg { width: 100%; height: 100%; }
.pl-book { fill: rgba(181, 248, 74, 0.15); animation: pl-bookFloat calc(8s * var(--pl-spd, 1)) ease-in-out infinite; }
.pl-anim-books-wrap .pl-book-1 { animation-delay: calc(var(--pl-dly, 0s) + 0s); }
.pl-anim-books-wrap .pl-book-2 { animation-delay: calc(var(--pl-dly, 0s) + 0.8s); }
.pl-anim-books-wrap .pl-book-3 { animation-delay: calc(var(--pl-dly, 0s) + 1.6s); }

/* SLEUTEL — schuift heen en weer */
@keyframes pl-keySlide { 0%, 100% { transform: translateX(-8px); } 50% { transform: translateX(8px); } }
.pl-anim-key-wrap { position: relative; width: 140px; height: 70px; color: var(--lime); animation: pl-keySlide calc(8s * var(--pl-spd, 1)) ease-in-out infinite; }
.pl-anim-key-wrap svg { width: 100%; height: 100%; }

/* VERGROOTGLAS — beweegt over content */
@keyframes pl-magnifyMove {
	0%, 100% { transform: translate(-12px, -8px); }
	33%      { transform: translate(8px, 6px); }
	66%      { transform: translate(-4px, 10px); }
}
.pl-anim-magnify-wrap { position: relative; width: 140px; height: 110px; color: var(--lime); }
.pl-anim-magnify-wrap svg { width: 100%; height: 100%; animation: pl-magnifyMove calc(12s * var(--pl-spd, 1)) ease-in-out infinite; }

/* CCTV — kegel knippert */
@keyframes pl-cctvCone { 0%, 100% { opacity: 0.5; } 50% { opacity: 1; } }
.pl-anim-cctv-wrap { position: relative; width: 140px; height: 100px; color: var(--lime); }
.pl-anim-cctv-wrap svg { width: 100%; height: 100%; }
.pl-cctv-cone { animation: pl-cctvCone calc(6s * var(--pl-spd, 1)) ease-in-out infinite; transform-origin: 82px 40px; }

/* GRAFIEK — lijn tekent zich */
@keyframes pl-graphDraw {
	0%   { stroke-dasharray: 0 400; }
	60%, 100% { stroke-dasharray: 400 0; }
}
@keyframes pl-graphDot { 0%, 100% { opacity: 0.4; } 50% { opacity: 1; } }
.pl-anim-graph-wrap { position: relative; width: 140px; height: 100px; color: var(--lime); }
.pl-anim-graph-wrap svg { width: 100%; height: 100%; }
.pl-graph-line { stroke: var(--lime); animation: pl-graphDraw calc(8s * var(--pl-spd, 1)) ease-in-out infinite; }
.pl-graph-dot { animation: pl-graphDot calc(5s * var(--pl-spd, 1)) ease-in-out infinite; }
.pl-anim-graph-wrap .pl-graph-dot:nth-child(5) { animation-delay: 0.4s; }
.pl-anim-graph-wrap .pl-graph-dot:nth-child(6) { animation-delay: 0.8s; }
.pl-anim-graph-wrap .pl-graph-dot:nth-child(7) { animation-delay: 1.2s; }

/* BADGE — vinkje verschijnt */
@keyframes pl-badgeRotate { from { transform: rotate(0); } to { transform: rotate(360deg); } }
@keyframes pl-badgeCheck {
	0%, 30% { stroke-dasharray: 0 60; }
	60%, 90% { stroke-dasharray: 60 0; }
	95%, 100% { stroke-dasharray: 0 60; }
}
.pl-anim-badge-wrap { position: relative; width: 120px; height: 120px; color: var(--lime); }
.pl-anim-badge-wrap svg { width: 100%; height: 100%; }
.pl-badge-star { stroke: var(--lime); fill: rgba(181, 248, 74, 0.08); animation: pl-badgeRotate calc(40s * var(--pl-spd, 1)) linear infinite; transform-origin: center; }
.pl-badge-check { stroke: var(--lime); stroke-width: 3; animation: pl-badgeCheck calc(6s * var(--pl-spd, 1)) ease-in-out infinite; }

@media (prefers-reduced-motion: reduce) {
	.pl-basket-item, .pl-net-node, .pl-net-line, .pl-book, .pl-anim-key-wrap,
	.pl-anim-magnify-wrap svg, .pl-cctv-cone, .pl-graph-line, .pl-graph-dot,
	.pl-badge-star, .pl-badge-check { animation: none !important; }
}

/* ==========================================================================
   FIX — sommige browsers/contexten respecteren aspect-ratio niet altijd.
   Min-height garandeert dat het visual-vlak nooit instort.
   ========================================================================== */
.pl-card-visual {
	min-height: 220px !important;
	height: auto !important;
	background: var(--ink) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	overflow: hidden;
	position: relative;
}

/* ==========================================================================
   HOVER FIX — voor-wie cards: zwart bg krijgt lime/wit tekst
   ========================================================================== */
.pl-aud:hover, .pl-aud:focus-visible {
	background: var(--ink) !important;
	border-color: var(--ink) !important;
}
.pl-aud:hover h3,
.pl-aud:hover p,
.pl-aud:focus-visible h3,
.pl-aud:focus-visible p,
.pl-voor-wie .pl-aud:hover h3,
.pl-voor-wie .pl-aud:hover p,
.pl-voor-wie .pl-aud:focus-visible h3,
.pl-voor-wie .pl-aud:focus-visible p {
	color: var(--lime) !important;
}
.pl-aud:hover .pl-aud-icon svg,
.pl-aud:focus-visible .pl-aud-icon svg {
	color: var(--lime) !important;
}
.pl-aud:hover .pl-aud-icon,
.pl-aud:focus-visible .pl-aud-icon {
	background: rgba(181, 248, 74, 0.12) !important;
	border-color: var(--lime) !important;
}

/* Diensten cards op zwarte sectie ook checken */
.pl-dienst:hover h3,
.pl-dienst:hover p,
.pl-dienst:hover li {
	color: var(--lime) !important;
}

/* ==========================================================================
   PRODUCTEN/TRAININGEN ARCHIVE — gelijke kaart-hoogte + vol visual-vlak
   ========================================================================== */
.pl-card-grid {
	grid-auto-rows: 1fr !important; /* alle rijen even hoog */
}
.pl-card {
	display: flex !important;
	flex-direction: column;
	height: 100%;
}
.pl-card-visual {
	flex-shrink: 0;
	width: 100% !important;
	min-height: 220px !important;
	aspect-ratio: 16/10;
	background: var(--ink) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	overflow: hidden;
	position: relative;
}
.pl-card-body {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
}
.pl-card-body .pl-card-link {
	margin-top: auto; /* "Lees meer →" altijd onderaan */
}
/* Animatie-wrappers vullen het visual-vlak gecentreerd */
.pl-card-visual > div[class*="pl-anim-"] {
	width: auto;
	height: auto;
	max-width: 60%;
	max-height: 70%;
	display: flex !important;
	align-items: center;
	justify-content: center;
}

/* ==========================================================================
   OVER-PAGINA — bio + foto kader
   ========================================================================== */
.pl-over-hero { background: var(--ink); color: var(--text); padding: 100px 0 80px; }
.pl-over-hero__grid {
	display: grid; grid-template-columns: 360px 1fr; gap: 64px; align-items: center;
}
@media (max-width: 800px) {
	.pl-over-hero__grid { grid-template-columns: 1fr; gap: 40px; }
}

/* Foto-kader — gestileerd vierkant met lime accent */
.pl-over-photo-frame {
	position: relative; aspect-ratio: 1/1; max-width: 360px;
	border: 1px solid rgba(181, 248, 74, 0.2);
	background: rgba(181, 248, 74, 0.03);
	overflow: hidden;
}
.pl-over-photo-frame::before {
	content: ''; position: absolute; top: -1px; left: -1px; width: 50px; height: 50px;
	border-top: 3px solid var(--lime); border-left: 3px solid var(--lime);
	z-index: 2;
}
.pl-over-photo-frame::after {
	content: ''; position: absolute; bottom: -1px; right: -1px; width: 50px; height: 50px;
	border-bottom: 3px solid var(--lime); border-right: 3px solid var(--lime);
	z-index: 2;
}
.pl-over-photo {
	width: 100%; height: 100%; object-fit: cover; display: block;
}
.pl-over-photo-tag {
	position: absolute; bottom: 14px; left: 14px; z-index: 3;
	background: var(--ink); color: var(--lime);
	padding: 5px 10px; font-size: 9px; font-weight: 800; letter-spacing: 2.5px;
}
.pl-over-photo-frame--empty {
	display: flex; align-items: center; justify-content: center;
}
.pl-over-photo-placeholder {
	text-align: center; padding: 24px;
}
.pl-over-photo-initials {
	font-size: 64px; font-weight: 900; color: var(--lime); letter-spacing: -2px;
	margin-bottom: 12px;
}
.pl-over-photo-hint {
	font-size: 11px; color: rgba(239, 237, 230, 0.5); line-height: 1.5;
}

/* Bio-blok rechts */
.pl-over-intro .pl-section-eyebrow { color: var(--lime); margin-bottom: 16px; }
.pl-over-name {
	font-size: clamp(36px, 5vw, 52px); font-weight: 900; color: white;
	letter-spacing: -0.04em; line-height: 1.05; margin-bottom: 6px;
}
.pl-over-role {
	font-size: 14px; color: var(--lime); font-weight: 600;
	letter-spacing: 0.5px; margin-bottom: 28px;
}
.pl-over-quote {
	font-size: clamp(18px, 2vw, 22px); color: white; font-style: italic;
	line-height: 1.4; padding-left: 18px; border-left: 3px solid var(--lime);
	margin-bottom: 24px;
}
.pl-over-bio {
	font-size: 16px; color: #FFFFFF !important; line-height: 1.65; opacity: 0.92;
}
.pl-over-hero .pl-section-eyebrow { color: var(--lime) !important; }
.pl-over-hero h1, .pl-over-hero p { color: #FFFFFF !important; }
.pl-over-hero .pl-over-role { color: var(--lime) !important; }
.pl-over-hero .pl-over-quote { color: #FFFFFF !important; font-style: italic; }

/* Content-secties */
.pl-over-content { background: var(--paper, #FAFAF6); padding: 80px 0; }
.pl-over-content__inner { max-width: 760px; margin: 0 auto; }
.pl-over-content__inner h2 {
	font-size: 24px; font-weight: 800; color: var(--ink);
	margin: 36px 0 14px; letter-spacing: -0.5px;
}
.pl-over-content__inner h2:first-child { margin-top: 0; }
.pl-over-content__inner p {
	font-size: 16.5px; line-height: 1.7; color: var(--ink); margin-bottom: 16px;
}
.pl-over-content__inner ul {
	margin: 14px 0 20px; padding-left: 22px;
}
.pl-over-content__inner ul li {
	font-size: 16px; line-height: 1.7; color: var(--ink); margin-bottom: 8px;
}

/* CTA-onderaan */
.pl-over-cta {
	background: var(--lime); color: var(--ink);
	padding: 70px 0; text-align: center;
}
.pl-over-cta h2 {
	font-size: clamp(28px, 4vw, 38px); font-weight: 900;
	letter-spacing: -0.03em; margin-bottom: 12px; color: var(--ink);
}
.pl-over-cta p {
	font-size: 17px; color: rgba(15, 15, 17, 0.75);
	margin-bottom: 28px;
}

/* Over-pagina extra leesbaarheid — overschrijf welke regel dan ook */
.pl-over-hero,
.pl-over-hero *,
.pl-over-intro,
.pl-over-intro p,
.pl-over-bio,
.pl-over-hero .pl-over-bio,
section.pl-over-hero p {
	color: #FFFFFF !important;
	opacity: 1 !important;
}
.pl-over-hero .pl-over-role,
.pl-over-hero .pl-section-eyebrow {
	color: #B5F84A !important;
}

/* ==========================================================================
   FIX — knop op lime CTA-sectie + bio-tekst contrast
   ========================================================================== */
.pl-over-cta .pl-btn,
.pl-over-cta a.pl-btn-lime,
.pl-over-cta a.pl-btn-lg {
	background: var(--ink) !important;
	color: var(--lime) !important;
	border: 2px solid var(--ink) !important;
	padding: 14px 28px !important;
	font-weight: 700;
	letter-spacing: 0.3px;
	transition: all 0.2s;
}
.pl-over-cta .pl-btn:hover {
	background: white !important;
	color: var(--ink) !important;
	border-color: var(--ink) !important;
}

/* Bio-tekst beter leesbaar op zwarte achtergrond */
.pl-over-bio {
	color: rgba(255, 255, 255, 0.85) !important;
	font-size: 17px !important;
	line-height: 1.7 !important;
}
.pl-over-quote {
	color: white !important;
}

/* ==========================================================================
   DOELGROEP-PAGINA'S (/voor-wie/{slug}/)
   ========================================================================== */
.pl-doelgroep-hero { background: var(--ink); color: var(--text); padding: 100px 0 80px; }
.pl-doelgroep-hero__grid {
	display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; align-items: center;
}
@media (max-width: 800px) {
	.pl-doelgroep-hero__grid { grid-template-columns: 1fr; gap: 48px; }
}
.pl-doelgroep-hero__text .pl-section-eyebrow { color: var(--lime); margin-bottom: 18px; }
.pl-doelgroep-hero__text h1 {
	font-size: clamp(36px, 5.5vw, 56px); font-weight: 900;
	letter-spacing: -0.04em; line-height: 1.05;
	color: white; margin-bottom: 24px;
}
.pl-doelgroep-intro {
	font-size: clamp(16px, 1.8vw, 19px); color: rgba(255,255,255,0.85);
	line-height: 1.6; margin-bottom: 32px; max-width: 600px;
}
.pl-doelgroep-hero__cta { display: flex; gap: 14px; flex-wrap: wrap; }

/* Icoon-kader rechts in hero */
.pl-doelgroep-hero__icon {
	display: flex; flex-direction: column; align-items: center; gap: 16px;
}
.pl-doelgroep-icon-frame {
	position: relative; aspect-ratio: 1/1; width: 100%; max-width: 280px;
	background: rgba(181, 248, 74, 0.06);
	border: 1px solid rgba(181, 248, 74, 0.25);
	display: flex; align-items: center; justify-content: center;
	color: var(--lime);
}
.pl-doelgroep-icon-frame svg { width: 50%; height: 50%; }
.pl-doelgroep-icon-frame::before {
	content: ''; position: absolute; top: -1px; left: -1px;
	width: 36px; height: 36px;
	border-top: 3px solid var(--lime); border-left: 3px solid var(--lime);
}
.pl-doelgroep-icon-frame::after {
	content: ''; position: absolute; bottom: -1px; right: -1px;
	width: 36px; height: 36px;
	border-bottom: 3px solid var(--lime); border-right: 3px solid var(--lime);
}
.pl-doelgroep-kicker {
	font-size: 11px; color: var(--lime);
	letter-spacing: 3px; font-weight: 800;
}

/* Situaties-sectie */
.pl-doelgroep-situaties { background: var(--paper, #FAFAF6); padding: 90px 0; }
.pl-doelgroep-situaties .pl-section-head { margin-bottom: 48px; }
.pl-doelgroep-situaties h2 {
	font-size: clamp(28px, 4vw, 40px); font-weight: 900;
	letter-spacing: -0.03em; color: var(--ink);
}
.pl-doelgroep-grid {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px;
}
@media (max-width: 700px) {
	.pl-doelgroep-grid { grid-template-columns: 1fr; }
}
.pl-doelgroep-card {
	background: white; padding: 28px 26px; border: 1px solid var(--rule);
	transition: all 0.2s;
}
.pl-doelgroep-card:hover {
	border-color: var(--ink); transform: translateY(-2px);
	box-shadow: 0 10px 28px rgba(15,15,17,0.08);
}
.pl-doelgroep-num {
	display: inline-block; background: var(--lime); color: var(--ink);
	font-size: 11px; font-weight: 800; letter-spacing: 1.5px;
	padding: 4px 10px; margin-bottom: 14px;
}
.pl-doelgroep-card h3 {
	font-size: 18px; font-weight: 800; color: var(--ink);
	margin-bottom: 10px; line-height: 1.3;
}
.pl-doelgroep-card p {
	font-size: 14.5px; color: var(--text-mute, #5A5550);
	line-height: 1.6; margin: 0;
}

/* Diensten-sectie */
.pl-doelgroep-diensten { background: var(--ink); color: var(--text); padding: 80px 0; }
.pl-doelgroep-diensten .pl-section-eyebrow { color: var(--lime); }
.pl-doelgroep-diensten h2 {
	font-size: clamp(28px, 4vw, 40px); font-weight: 900; color: white;
	letter-spacing: -0.03em; margin-bottom: 32px;
}
.pl-doelgroep-diensten-lijst {
	list-style: none; padding: 0; margin: 0;
	display: grid; gap: 12px;
}
.pl-doelgroep-diensten-lijst li {
	background: rgba(255,255,255,0.04); padding: 16px 22px;
	border-left: 3px solid var(--lime);
	color: white; font-size: 16px;
}
.pl-doelgroep-arrow {
	color: var(--lime); font-weight: 800; margin-right: 8px;
}

/* CTA-onder */
.pl-doelgroep-cta {
	background: var(--lime); color: var(--ink); padding: 80px 0; text-align: center;
}
.pl-doelgroep-cta h2 {
	font-size: clamp(28px, 4vw, 42px); font-weight: 900;
	letter-spacing: -0.03em; color: var(--ink); margin-bottom: 12px;
}
.pl-doelgroep-cta p {
	font-size: 17px; color: rgba(15,15,17,0.75); margin-bottom: 28px;
}
.pl-doelgroep-cta .pl-btn {
	background: var(--ink) !important; color: var(--lime) !important;
	border: 2px solid var(--ink) !important;
}
.pl-doelgroep-cta .pl-btn:hover {
	background: white !important; color: var(--ink) !important;
}

/* ==========================================================================
   ARCHIVE PER DOELGROEP — Producten + Trainingen
   ========================================================================== */
.pl-arch-hero {
	background: var(--ink);
	color: var(--text);
	padding: 50px 0 36px;
}
.pl-arch-eyebrow {
	font-size: 10px;
	font-weight: 800;
	letter-spacing: 3px;
	color: var(--lime);
	margin-bottom: 14px;
}
.pl-arch-hero h1 {
	font-size: 30px;
	font-weight: 900;
	letter-spacing: -0.03em;
	line-height: 1.1;
	color: white;
	margin-bottom: 14px;
}
.pl-arch-lead {
	font-size: 14.5px;
	color: rgba(255,255,255,0.85);
	line-height: 1.55;
	max-width: 640px;
}

/* DOELGROEP-INGANGEN */
.pl-arch-dgcards-section {
	background: var(--paper, #FAFAF6);
	padding: 36px 0 24px;
}
.pl-arch-section-eyebrow {
	font-size: 10px;
	font-weight: 800;
	letter-spacing: 2.5px;
	color: var(--lime-soft, #7AAD22);
	margin-bottom: 8px;
}
.pl-arch-section-title {
	font-size: 24px;
	font-weight: 900;
	color: var(--ink);
	letter-spacing: -0.02em;
	margin-bottom: 22px;
	line-height: 1.2;
}
.pl-arch-dgcards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 14px;
}
.pl-arch-dgcard {
	background: var(--ink);
	color: var(--text);
	padding: 22px;
	position: relative;
	cursor: pointer;
	border: 1.5px solid transparent;
	transition: all 0.2s;
	min-height: 150px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	text-decoration: none;
}
.pl-arch-dgcard:hover {
	border-color: var(--lime);
	transform: translateY(-2px);
}
.pl-arch-dgcard-top {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	margin-bottom: 12px;
}
.pl-arch-dgcard-icon {
	width: 44px;
	height: 44px;
	flex-shrink: 0;
	color: var(--lime);
}
.pl-arch-dgcard-icon svg {
	width: 100%;
	height: 100%;
}
.pl-arch-dgcard-kicker {
	font-size: 9px;
	font-weight: 800;
	letter-spacing: 2.5px;
	color: var(--lime);
	margin-bottom: 4px;
}
.pl-arch-dgcard-name {
	font-size: 22px;
	font-weight: 900;
	color: white;
	letter-spacing: -0.01em;
	line-height: 1.2;
}
.pl-arch-dgcard-desc {
	font-size: 13.5px;
	color: rgba(255,255,255,0.75);
	line-height: 1.5;
	margin-bottom: 14px;
}
.pl-arch-dgcard-foot {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: 14px;
	border-top: 1px solid rgba(181,248,74,0.2);
}
.pl-arch-dgcard-count {
	font-size: 11px;
	color: var(--lime);
	font-weight: 700;
	letter-spacing: 1px;
}
.pl-arch-dgcard-arrow {
	color: var(--lime);
	font-weight: 800;
	font-size: 18px;
	transition: transform 0.2s;
}
.pl-arch-dgcard:hover .pl-arch-dgcard-arrow {
	transform: translateX(4px);
}
.pl-arch-toon-alles {
	text-align: center;
	margin: 28px 0 12px;
}
.pl-arch-toon-alles a {
	color: var(--ink);
	text-decoration: underline;
	font-size: 13px;
	font-weight: 600;
}

/* GEFILTERDE LIJST */
.pl-arch-filtered {
	background: white;
	padding: 36px 0 60px;
	border-top: 1px solid #E5E2D8;
}
.pl-arch-filter-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 24px;
	gap: 12px;
	flex-wrap: wrap;
}
.pl-arch-filter-tag {
	display: inline-flex;
	align-items: center;
	background: var(--ink);
	color: var(--lime);
	padding: 8px 14px;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 2px;
}
.pl-arch-filter-close {
	display: inline-flex;
	align-items: center;
	background: var(--ink);
	color: var(--lime);
	padding: 8px 14px;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 2px;
	text-transform: uppercase;
	text-decoration: none;
	border: 1.5px solid var(--ink);
	transition: all 0.18s;
	cursor: pointer;
}
.pl-arch-filter-close:hover {
	background: var(--lime);
	color: var(--ink);
	border-color: var(--lime);
}

/* DESKTOP / TABLET breakpoints */
@media (min-width: 700px) {
	.pl-arch-hero { padding: 70px 0 50px; }
	.pl-arch-hero h1 { font-size: 44px; max-width: 720px; margin-bottom: 18px; }
	.pl-arch-lead { font-size: 17px; }
	.pl-arch-dgcards-section { padding: 56px 0 32px; }
	.pl-arch-section-title { font-size: 32px; margin-bottom: 28px; }
	.pl-arch-dgcards {
		grid-template-columns: repeat(2, 1fr);
		gap: 18px;
	}
	.pl-arch-dgcard {
		padding: 28px 30px;
		min-height: 210px;
	}
	.pl-arch-dgcard-name { font-size: 26px; }
	.pl-arch-dgcard-icon { width: 52px; height: 52px; }
	.pl-arch-dgcard-desc { font-size: 15px; }
	.pl-arch-filtered { padding: 56px 0 80px; }
}
@media (min-width: 1000px) {
	.pl-arch-hero h1 { font-size: 56px; }
	.pl-arch-dgcards {
		grid-template-columns: repeat(4, 1fr);
		gap: 16px;
	}
	.pl-arch-dgcard {
		min-height: 240px;
		padding: 26px 24px;
	}
	.pl-arch-dgcard-name { font-size: 22px; }
}

/* ==========================================================================
   DIENST-PAGINA'S (/diensten/{slug}/)
   ========================================================================== */
.pl-dienst-hero { background: var(--ink); color: var(--text); padding: 80px 0 60px; }
.pl-dienst-hero__grid {
	display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: center;
}
@media (max-width: 800px) {
	.pl-dienst-hero__grid { grid-template-columns: 1fr; gap: 40px; }
	.pl-dienst-hero { padding: 50px 0 40px; }
}
.pl-dienst-hero__text .pl-section-eyebrow { color: var(--lime); margin-bottom: 16px; }
.pl-dienst-hero__text h1 {
	font-size: clamp(32px, 5vw, 52px); font-weight: 900;
	letter-spacing: -0.04em; line-height: 1.05;
	color: white; margin-bottom: 20px;
}
.pl-dienst-hero__subtitle {
	font-size: clamp(15px, 1.7vw, 18px); color: rgba(255,255,255,0.85);
	line-height: 1.55; margin-bottom: 28px; max-width: 600px;
}
.pl-dienst-hero__icon {
	display: flex; justify-content: center;
}
.pl-dienst-icon-frame {
	position: relative; aspect-ratio: 1/1; width: 100%; max-width: 320px;
	background: rgba(181,248,74,0.05);
	border: 1px solid rgba(181,248,74,0.25);
	display: flex; align-items: center; justify-content: center;
	color: var(--lime);
	overflow: hidden;
}
.pl-dienst-icon-frame svg { width: 100%; height: 100%; display: block; }
.pl-dienst-icon-frame::before {
	content: ''; position: absolute; top: -1px; left: -1px; z-index: 2;
	width: 36px; height: 36px;
	border-top: 3px solid var(--lime); border-left: 3px solid var(--lime);
}
.pl-dienst-icon-frame::after {
	content: ''; position: absolute; bottom: -1px; right: -1px; z-index: 2;
	width: 36px; height: 36px;
	border-bottom: 3px solid var(--lime); border-right: 3px solid var(--lime);
}

/* Wat houdt het in */
.pl-dienst-watdoet { background: var(--paper, #FAFAF6); padding: 70px 0; }
.pl-dienst-watdoet .pl-section-head { margin-bottom: 28px; }
.pl-dienst-watdoet h2 {
	font-size: clamp(26px, 4vw, 36px); font-weight: 900;
	letter-spacing: -0.03em; color: var(--ink);
}
.pl-dienst-watdoet__text {
	font-size: clamp(16px, 1.8vw, 19px); line-height: 1.65; color: var(--ink);
	max-width: 800px;
}
.pl-dienst-watdoet__meer { margin-top: 22px; }
.pl-dienst-watdoet__meer a {
	display: inline-flex; align-items: center; gap: 6px;
	font-weight: 700; font-size: 16px; color: var(--ink);
	text-decoration: none; border-bottom: 2px solid var(--lime, #B5F84A);
	padding-bottom: 2px; transition: opacity 0.15s ease;
}
.pl-dienst-watdoet__meer a:hover { opacity: 0.7; }

/* Voor wie */
.pl-dienst-voorwie { background: white; padding: 70px 0; }
.pl-dienst-voorwie h2 {
	font-size: clamp(26px, 4vw, 36px); font-weight: 900;
	letter-spacing: -0.03em; color: var(--ink);
}
.pl-dienst-voorwie-grid {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; margin-top: 32px;
}
@media (max-width: 700px) {
	.pl-dienst-voorwie-grid { grid-template-columns: 1fr; }
}
.pl-dienst-voorwie-card {
	background: var(--paper, #FAFAF6); padding: 24px 22px;
	border-left: 3px solid var(--lime);
}
.pl-dienst-voorwie-num {
	display: inline-block; background: var(--ink); color: var(--lime);
	font-size: 10px; font-weight: 800; letter-spacing: 1.5px;
	padding: 3px 9px; margin-bottom: 12px;
}
.pl-dienst-voorwie-card h3 {
	font-size: 17px; font-weight: 800; color: var(--ink);
	margin-bottom: 6px; line-height: 1.3;
}
.pl-dienst-voorwie-card p {
	font-size: 14.5px; color: var(--text-mute, #5A5550);
	line-height: 1.55; margin: 0;
}

/* Proces */
.pl-dienst-proces { background: var(--ink); color: var(--text); padding: 70px 0; }
.pl-dienst-proces .pl-section-eyebrow { color: var(--lime); }
.pl-dienst-proces h2 {
	font-size: clamp(26px, 4vw, 36px); font-weight: 900; color: white;
	letter-spacing: -0.03em;
}
.pl-dienst-proces-list { display: grid; gap: 14px; margin-top: 32px; }
.pl-dienst-proces-step {
	display: flex; gap: 22px; align-items: flex-start;
	background: rgba(255,255,255,0.03);
	padding: 22px 24px;
	border-left: 3px solid var(--lime);
}
.pl-dienst-proces-num {
	flex-shrink: 0; width: 38px; height: 38px;
	background: var(--lime); color: var(--ink);
	display: flex; align-items: center; justify-content: center;
	font-size: 18px; font-weight: 900;
}
.pl-dienst-proces-content h3 {
	font-size: 17px; font-weight: 800; color: white;
	margin-bottom: 4px; line-height: 1.3;
}
.pl-dienst-proces-content p {
	font-size: 14.5px; color: rgba(255,255,255,0.75);
	line-height: 1.55; margin: 0;
}

/* Praktisch */
.pl-dienst-praktisch { background: var(--paper, #FAFAF6); padding: 60px 0; }
.pl-dienst-praktisch-grid {
	display: grid; grid-template-columns: 1fr 1fr 1.5fr; gap: 40px;
}
@media (max-width: 800px) {
	.pl-dienst-praktisch-grid { grid-template-columns: 1fr; gap: 28px; }
}
.pl-dienst-praktisch-block .pl-section-eyebrow {
	color: var(--lime-soft, #7AAD22); margin-bottom: 10px;
}
.pl-dienst-praktisch-block p {
	font-size: 15px; line-height: 1.55; color: var(--ink); margin: 0;
}
.pl-dienst-voorbeelden {
	list-style: none; padding: 0; margin: 0;
}
.pl-dienst-voorbeelden li {
	padding: 7px 0; border-bottom: 1px solid var(--rule);
	font-size: 14.5px; color: var(--ink);
}
.pl-dienst-voorbeelden li::before {
	content: '→ '; color: var(--lime-soft, #7AAD22); font-weight: 700; margin-right: 6px;
}
.pl-dienst-voorbeelden li:last-child { border-bottom: none; }

/* CTA-strip */
.pl-dienst-cta {
	background: var(--lime); color: var(--ink); padding: 70px 0; text-align: center;
}
.pl-dienst-cta h2 {
	font-size: clamp(26px, 4vw, 38px); font-weight: 900;
	color: var(--ink); letter-spacing: -0.03em; margin-bottom: 12px;
}
.pl-dienst-cta p {
	font-size: 16px; color: rgba(15,15,17,0.75);
	margin-bottom: 28px; max-width: 560px; margin-left: auto; margin-right: auto;
}
.pl-dienst-cta .pl-btn {
	background: var(--ink) !important; color: var(--lime) !important;
	border: 2px solid var(--ink) !important; padding: 14px 32px !important;
	font-weight: 700;
}
.pl-dienst-cta .pl-btn:hover {
	background: white !important; color: var(--ink) !important;
}

/* ==========================================================================
   MAATWERK-BLOK (onderaan /trainingen/, /producten/, /diensten/training/, /diensten/advies/)
   ========================================================================== */
.pl-maatwerk {
	background: var(--paper, #FAFAF6);
	padding: 70px 0 90px;
}
.pl-maatwerk-card {
	background: white;
	border: 1px solid var(--rule, #E5E2D8);
	display: grid;
	grid-template-columns: 80px 1fr;
	overflow: hidden;
}
@media (max-width: 700px) {
	.pl-maatwerk-card { grid-template-columns: 1fr; }
}

/* Linker lime-strook met groot icoon */
.pl-maatwerk-side {
	background: var(--lime);
	color: var(--ink);
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding: 36px 0;
}
@media (max-width: 700px) {
	.pl-maatwerk-side { padding: 22px 0; }
}
.pl-maatwerk-side svg {
	width: 38px; height: 38px;
}

.pl-maatwerk-content {
	padding: 44px 48px;
}
@media (max-width: 700px) {
	.pl-maatwerk-content { padding: 30px 24px; }
}

.pl-maatwerk-eyebrow {
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 3px;
	color: var(--lime-soft, #7AAD22);
	margin-bottom: 14px;
}
.pl-maatwerk-title {
	font-size: clamp(22px, 3.2vw, 32px);
	font-weight: 900;
	letter-spacing: -0.025em;
	line-height: 1.18;
	color: var(--ink);
	margin-bottom: 14px;
	max-width: 700px;
}
.pl-maatwerk-lead {
	font-size: 16px;
	color: #4A4744;
	line-height: 1.6;
	margin-bottom: 32px;
	max-width: 640px;
}

/* Proces-stappen, horizontaal op desktop, vertikaal op mobiel */
.pl-maatwerk-stappen {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	margin-bottom: 32px;
	border-top: 1px solid var(--rule, #E5E2D8);
	border-bottom: 1px solid var(--rule, #E5E2D8);
	padding: 26px 0;
}
@media (max-width: 700px) {
	.pl-maatwerk-stappen { grid-template-columns: 1fr; gap: 18px; padding: 22px 0; }
}
.pl-maatwerk-stap {
	position: relative;
	padding-left: 44px;
	min-height: 40px;
}
.pl-maatwerk-stap-num {
	position: absolute;
	left: 0; top: 0;
	width: 32px; height: 32px;
	background: var(--ink);
	color: var(--lime);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 900;
}
.pl-maatwerk-stap-kop {
	font-size: 14px;
	font-weight: 800;
	color: var(--ink);
	margin-bottom: 4px;
	line-height: 1.3;
}
.pl-maatwerk-stap-tekst {
	font-size: 13px;
	color: var(--mute, #8B8780);
	line-height: 1.5;
}

/* CTA-rij */
.pl-maatwerk-cta-row {
	display: flex;
	gap: 18px;
	align-items: center;
	flex-wrap: wrap;
}
.pl-maatwerk-btn-primary {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 26px;
	background: var(--ink);
	color: var(--lime);
	text-decoration: none;
	font-size: 14.5px;
	font-weight: 800;
	transition: all 0.18s;
}
.pl-maatwerk-btn-primary:hover {
	background: var(--lime);
	color: var(--ink);
}
.pl-maatwerk-btn-secondary {
	display: inline-flex;
	align-items: center;
	color: var(--ink);
	text-decoration: none;
	font-size: 13.5px;
	font-weight: 700;
	border-bottom: 1.5px solid var(--ink);
	padding-bottom: 2px;
}
.pl-maatwerk-btn-secondary:hover {
	color: var(--lime-soft, #7AAD22);
	border-color: var(--lime-soft, #7AAD22);
}

   MONITOR OVEREENKOMST (/monitor-overeenkomst/)
   ========================================================================== */
.pl-ovk-hero {
	background: var(--ink); color: var(--text);
	padding: 60px 0 40px;
}
.pl-ovk-hero .pl-section-eyebrow { color: var(--lime); margin-bottom: 14px; }
.pl-ovk-hero h1 {
	font-size: clamp(32px, 5vw, 48px); font-weight: 900;
	letter-spacing: -0.03em; color: white; margin-bottom: 14px;
}
.pl-ovk-lead {
	font-size: 16px; color: rgba(255,255,255,0.8);
	line-height: 1.6; max-width: 720px; margin-bottom: 22px;
}
.pl-ovk-meta {
	display: flex; gap: 24px; flex-wrap: wrap;
	font-size: 12px; letter-spacing: 1.5px;
	color: rgba(255,255,255,0.5); text-transform: uppercase;
}
.pl-ovk-meta strong { color: var(--lime); font-weight: 800; }

.pl-ovk-content { background: var(--paper, #FAFAF6); padding: 60px 0 90px; }
.pl-ovk-block {
	background: white; margin-bottom: 16px;
	display: grid; grid-template-columns: 80px 1fr;
}
@media (max-width: 700px) { .pl-ovk-block { grid-template-columns: 60px 1fr; } }
.pl-ovk-block-num {
	background: var(--ink); color: var(--lime);
	display: flex; align-items: flex-start; justify-content: center;
	padding-top: 36px;
	font-size: 18px; font-weight: 900; letter-spacing: 1px;
}
.pl-ovk-block-body { padding: 30px 36px; }
@media (max-width: 700px) { .pl-ovk-block-body { padding: 24px; } }
.pl-ovk-block-body h2 {
	font-size: clamp(20px, 2.8vw, 26px); font-weight: 800;
	letter-spacing: -0.02em; color: var(--ink); line-height: 1.25;
	margin-bottom: 16px;
}
.pl-ovk-block-body p {
	font-size: 15px; color: #3A3733; line-height: 1.65;
	margin-bottom: 12px; max-width: 800px;
}
.pl-ovk-block-body ul {
	list-style: none; padding: 0; max-width: 800px;
}
.pl-ovk-block-body ul li {
	padding: 8px 0 8px 22px; position: relative;
	font-size: 14.5px; color: #3A3733; line-height: 1.6;
}
.pl-ovk-block-body ul li::before {
	content: '→'; position: absolute; left: 0; top: 8px;
	color: var(--lime-soft, #7AAD22); font-weight: 800;
}
.pl-ovk-block-body code {
	background: var(--paper, #FAFAF6); padding: 2px 6px;
	font-size: 13px; font-family: 'SF Mono', monospace;
	color: var(--ink);
}
.pl-ovk-block-body strong { color: var(--ink); font-weight: 700; }
.pl-ovk-block-body a { color: var(--lime-soft, #7AAD22); text-decoration: underline; text-underline-offset: 2px; }

.pl-ovk-foot {
	margin-top: 32px;
	background: white; padding: 30px 36px;
	border-left: 3px solid var(--lime);
}
.pl-ovk-foot p { font-size: 14px; margin-bottom: 14px; }
.pl-ovk-foot p:last-child { margin-bottom: 0; }
