/* =============================================================
   AEDCENTER — SITE CHROME (Header + Footer)
   Corporate / Hero archetype / Conversion-first
   Brand: Pulse Red #DA291C · Deep Focus #300037
   Fonts: Neue Power (display) · Forma DJR Micro (body)
   ============================================================= */

/* Site-wide horizontale overflow guard
   Voorkomt dat één ongelukkige inline-grid of vaste-pixel breedte
   de hele pagina horizontaal laat scrollen op mobiel.
   Root cause moet alsnog opgelost worden — dit is een vangnet. */
html,body{overflow-x:clip;max-width:100%}

:root{
  --chrome-bg:#FFFFFF;
  --chrome-ink:#1C1420;
  --chrome-mute:rgba(28,20,32,.62);
  --chrome-line:rgba(28,20,32,.10);
  --chrome-red:#DA291C;
  --chrome-red-deep:#300037;
  --chrome-deep:#300037;
  --chrome-paper:#FFFFFF;
  --chrome-mist:#D7D2CB;
  --chrome-topbar-h:38px;
  --chrome-main-h:76px;
}

/* ============ TOPBAR (38px, donker, trust + contact) ============ */
.site-topbar{
  background:var(--chrome-deep);
  color:rgba(255,255,255,.86);
  font-size:13px;
  height:var(--chrome-topbar-h);
  display:flex;align-items:center;
  border-bottom:1px solid rgba(255,255,255,.06);
  font-family:var(--font-body,'Forma DJR Micro',Inter,system-ui,sans-serif);
}
.site-topbar .wrap{
  max-width:var(--maxw,1200px);margin:0 auto;padding:0 24px;
  display:flex;justify-content:space-between;align-items:center;width:100%;gap:24px;
}
.topbar-trust{display:flex;gap:24px;list-style:none;margin:0;padding:0}
.topbar-trust li{display:flex;align-items:center;gap:8px;letter-spacing:.01em}
.topbar-trust li svg{flex:0 0 14px;color:#D7D2CB;opacity:.9}
.topbar-meta{display:flex;align-items:center;gap:22px}
.topbar-meta a{color:rgba(255,255,255,.92);text-decoration:none;font-weight:600;display:inline-flex;align-items:center;gap:7px}
.topbar-meta a:hover{color:#fff}
.topbar-meta .sep{color:rgba(255,255,255,.2);font-weight:400}
.topbar-tel{font-weight:700}
.topbar-tel b{color:#fff}
.topbar-portal{display:inline-flex;align-items:center;gap:7px}
.topbar-portal svg{width:13px;height:13px}
.topbar-tel svg{width:13px;height:13px;flex:0 0 13px}
.topbar-trust li svg{width:14px;height:14px}
.topbar-meta{flex:0 0 auto;white-space:nowrap}

/* ============ MAIN HEADER (76px, logo + nav + CTA) ============ */
.site-header{
  position:sticky;top:0;z-index:80;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--chrome-line);
  font-family:var(--font-body,'Forma DJR Micro',Inter,system-ui,sans-serif);
}
.site-header.is-scrolled{box-shadow:0 6px 24px rgba(20,8,24,.07)}
.site-header .wrap{
  max-width:var(--maxw,1200px);margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;
  height:var(--chrome-main-h);gap:32px;
}
.site-header .brand{display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0}
.site-header .brand img{height:22px;width:auto;max-width:none;flex-shrink:0;display:block;align-self:center}

.site-nav{flex:1;display:flex;justify-content:center}
.site-nav > ul{display:flex;gap:6px;list-style:none;margin:0;padding:0}
.site-nav > ul > li{position:relative}
.site-nav > ul > li > a{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 14px;
  text-decoration:none;color:var(--chrome-ink);
  font-weight:600;font-size:15px;letter-spacing:-.005em;
  border-radius:8px;transition:background .15s,color .15s;
  white-space:nowrap;
}
.site-nav > ul > li > a:hover{background:var(--chrome-mist);color:var(--chrome-red)}
.site-nav > ul > li.has-mega > a::after{
  content:"";display:inline-block;width:6px;height:6px;
  border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;
  transform:rotate(45deg) translateY(-2px);margin-left:4px;opacity:.55;
}
.site-nav > ul > li > a[aria-current="page"]{color:var(--chrome-red)}
.site-nav > ul > li > a[aria-current="page"]::before{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;background:var(--chrome-red);border-radius:2px;
}

.header-actions{display:flex;align-items:center;gap:14px}
.header-tel{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--chrome-ink);text-decoration:none;font-weight:700;font-size:15px;
  padding:8px 6px;white-space:nowrap;
}
.header-tel svg{width:18px;height:18px;color:var(--chrome-red)}
.header-tel small{display:block;font-size:10px;font-weight:600;color:var(--chrome-mute);letter-spacing:.04em;text-transform:uppercase;line-height:1}
.header-tel-text{display:flex;flex-direction:column;line-height:1;gap:3px;transform:translateY(-7px)}
.header-tel-text b{font-size:15px;line-height:1}
.header-tel{align-items:center}
.header-cta-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--chrome-red);color:#fff;text-decoration:none;
  padding:11px 20px;border-radius:999px;font-weight:700;font-size:14px;letter-spacing:-.005em;
  border:1px solid var(--chrome-red);transition:background .15s,transform .15s,border-color .15s;
  white-space:nowrap;line-height:1;
}
.header-cta-btn:hover{background:var(--chrome-red-deep);border-color:var(--chrome-red-deep);transform:translateY(-1px)}
.header-cta-btn svg{width:14px;height:14px}

.header-burger{
  display:none;background:none;border:0;width:44px;height:44px;cursor:pointer;
  align-items:center;justify-content:center;flex-direction:column;gap:5px;border-radius:8px;
}
.header-burger span{display:block;width:22px;height:2px;background:var(--chrome-ink);border-radius:2px;transition:.2s}
.header-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.header-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.header-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============ MEGA MENU ============ */
/* Mega-menu positioneert zich t.o.v. de header .wrap (1200px container)
   zodat hij altijd gecentreerd is in viewport en nooit links of rechts
   uit beeld valt — ongeacht in welke positie de openende <li> staat. */
.site-header .wrap{position:relative}
.site-nav > ul > li.has-mega{position:static}
/* hover-bridge: maakt de hoverable zone van de trigger 14px naar beneden door
   zodat de muis nooit door een gap valt op weg naar het mega-menu */
.site-nav > ul > li.has-mega > a{position:relative}
.site-nav > ul > li.has-mega > a::before{
  content:'';position:absolute;left:-12px;right:-12px;top:100%;height:14px;
  background:transparent;pointer-events:auto;
}
.mega-menu{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(-4px);
  background:#fff;border:1px solid var(--chrome-line);border-radius:14px;
  box-shadow:0 22px 60px rgba(20,8,24,.16);
  /* visuele 4px gap behouden via interne padding; geen positie-gap meer */
  padding:28px 24px 24px 24px;margin-top:0;
  width:min(1100px,calc(100vw - 32px));
  max-width:calc(100vw - 32px);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .18s,transform .18s,visibility .18s;
  /* sluit pas na 150ms zodat muis tijd heeft om naar menu over te steken */
  transition-delay:.15s;
  z-index:90;
}
.site-nav > ul > li.has-mega:hover > .mega-menu,
.site-nav > ul > li.has-mega:focus-within > .mega-menu,
.mega-menu:hover{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0);
  /* open onmiddellijk (geen delay) */
  transition-delay:0s;
}
.mega-menu .mega-eyebrow{
  font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--chrome-red);margin-bottom:12px;
}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.mega-card{
  display:flex;flex-direction:column;gap:6px;
  padding:14px;border-radius:10px;text-decoration:none;color:var(--chrome-ink);
  border:1px solid transparent;transition:background .15s,border-color .15s,transform .15s;
}
.mega-card:hover{background:var(--chrome-mist);border-color:var(--chrome-line);transform:translateY(-2px)}
.mega-card .thumb{
  aspect-ratio:1/1;background:var(--chrome-mist);border-radius:8px;
  display:flex;align-items:center;justify-content:center;margin-bottom:8px;overflow:hidden;
}
.mega-card .thumb img{max-width:78%;max-height:78%;object-fit:contain}
.mega-card .name{font-weight:700;font-size:14.5px;line-height:1.25}
.mega-card .desc{font-size:12.5px;color:var(--chrome-mute);line-height:1.35}
.mega-card .price{font-size:12.5px;font-weight:700;color:var(--chrome-red);margin-top:4px}
.mega-foot{
  margin-top:18px;padding-top:16px;border-top:1px solid var(--chrome-line);
  display:flex;justify-content:space-between;align-items:center;font-size:13.5px;
}
.mega-foot a{color:var(--chrome-red);font-weight:700;text-decoration:none}
.mega-foot a:hover{text-decoration:underline}

/* Sectoren mega (3 col, 6 cards) */
.mega-sectors .mega-grid{grid-template-columns:repeat(3,1fr)}

/* Abonnementen mega-menu — 3 prijspakketten zonder thumb */
.mega-abos .mega-grid{grid-template-columns:repeat(3,1fr);gap:12px}
.mega-abos .abo-card{position:relative;display:flex;flex-direction:column;gap:6px;padding:16px 18px;border:1px solid var(--chrome-line,rgba(28,20,32,.10));border-radius:10px;background:#fff;text-decoration:none;color:var(--chrome-ink,#1C1420);transition:transform .15s,border-color .15s,box-shadow .15s;min-height:160px}
.mega-abos .abo-card:hover{border-color:var(--chrome-red,#DA291C);transform:translateY(-2px);box-shadow:0 8px 24px -10px rgba(218,41,28,.18)}
.mega-abos .abo-card.featured{border:1.5px solid var(--chrome-red,#DA291C);background:linear-gradient(180deg,rgba(218,41,28,.04),transparent 60%)}
.mega-abos .abo-card .tag{position:absolute;top:-9px;right:14px;background:var(--chrome-red,#DA291C);color:#fff;font-family:var(--chrome-display,inherit);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;padding:3px 8px;border-radius:4px;font-weight:900}
.mega-abos .abo-card .lbl{font-family:var(--chrome-display,inherit);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--chrome-red,#DA291C);font-weight:900}
.mega-abos .abo-card .name{font-weight:700;font-size:15px;line-height:1.2;color:var(--chrome-ink,#1C1420)}
.mega-abos .abo-card .desc{font-size:12px;color:var(--chrome-mute,rgba(28,20,32,.55));line-height:1.35;flex-grow:1}
.mega-abos .abo-card .price{display:flex;align-items:baseline;gap:4px;font-family:var(--chrome-display,inherit);margin-top:auto;padding-top:8px;border-top:1px solid var(--chrome-line,rgba(28,20,32,.08))}
.mega-abos .abo-card .price b{font-size:22px;font-weight:900;color:var(--chrome-ink,#1C1420);line-height:1}
.mega-abos .abo-card .price span{font-size:11px;color:var(--chrome-mute,rgba(28,20,32,.55));font-weight:600}
.sector-card{
  display:flex;flex-direction:column;gap:6px;padding:16px;border-radius:10px;
  text-decoration:none;color:var(--chrome-ink);
  border:1px solid var(--chrome-line);background:#fff;transition:background .15s,border-color .15s,transform .15s;
}
.sector-card:hover{background:var(--chrome-mist);border-color:var(--chrome-red);transform:translateY(-2px)}
.sector-card .ic{width:32px;height:32px;color:var(--chrome-red);margin-bottom:4px}
.sector-card .name{font-weight:700;font-size:15px}
.sector-card .desc{font-size:13px;color:var(--chrome-mute);line-height:1.4}

/* ============ MOBILE NAV PANEL ============ */
.mobile-nav{
  display:none;position:fixed;top:calc(var(--chrome-main-h) + var(--chrome-topbar-h));
  left:0;right:0;bottom:0;background:#fff;z-index:70;
  padding:24px;overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.mobile-nav.is-open{display:block}

/* --- FIX (permanent): menu-open state ---
   Probleem: header is position:sticky. Zodra het menu opent en body op
   overflow:hidden gaat, verliest de sticky-header zijn scroll-context en
   klapt terug naar documentpositie (offscreen bij gescrollde pagina) —
   de burger/sluit-knop verdwijnt dan uit beeld en het menu is niet meer
   te sluiten. Oplossing: tijdens open-state forceren we de header fixed
   bovenaan, zodat de burger (die dan een X wordt) altijd zichtbaar blijft.
   body.menu-open wordt door menu-nav.js gezet samen met .is-open. */
body.menu-open{overflow:hidden}
body.menu-open .site-header{
  position:fixed;top:0;left:0;right:0;z-index:90;
}
/* Sluit-knop in het paneel — vangnet voor het geval de header-burger
   onverhoopt toch buiten beeld raakt (oude browsers / rare viewport).
   Standaard VERBORGEN omdat de header nu fixed blijft en de burger zelf
   al in een X verandert (aria-expanded="true"). Zo voorkomen we twee
   zichtbare X-en boven elkaar. menu-nav.js injecteert hem als vangnet;
   hij wordt alleen getoond als de header daadwerkelijk niet sticky/fixed
   bovenaan staat (fallback-klasse body.menu-open-fallback). */
.mobile-nav .mobile-nav-close{display:none}
body.menu-open-fallback .mobile-nav .mobile-nav-close{
  position:sticky;top:0;margin:-8px -8px 12px auto;display:flex;
  align-items:center;justify-content:center;width:44px;height:44px;
  background:#fff;border:0;border-radius:10px;cursor:pointer;color:var(--chrome-ink);
  z-index:2;
}
.mobile-nav .mobile-nav-close svg{width:24px;height:24px}
.mobile-nav .mobile-nav-close:hover{color:var(--chrome-red)}
.mobile-nav ul{list-style:none;margin:0;padding:0}
.mobile-nav > ul > li{border-bottom:1px solid var(--chrome-line)}
.mobile-nav > ul > li > a{display:block;padding:16px 4px;font-size:18px;font-weight:600;color:var(--chrome-ink);text-decoration:none}
.mobile-nav > ul > li > a:hover{color:var(--chrome-red)}
.mobile-nav .m-cta{margin-top:24px;display:flex;flex-direction:column;gap:12px}
.mobile-nav .m-cta a{display:flex;justify-content:center;align-items:center;gap:8px;padding:14px 20px;border-radius:999px;font-weight:700;text-decoration:none}
.mobile-nav .m-cta .primary{background:var(--chrome-red);color:#fff}
.mobile-nav .m-cta .secondary{border:2px solid var(--chrome-ink);color:var(--chrome-ink)}
.mobile-nav .m-trust{margin-top:24px;display:flex;flex-wrap:wrap;gap:10px;font-size:12px;color:var(--chrome-mute)}
.mobile-nav .m-trust span{background:var(--chrome-mist);padding:6px 10px;border-radius:999px}

@media(max-width:1024px){
  .site-nav,.header-tel{display:none}
  .header-burger{display:flex}
  .site-topbar .topbar-trust li:nth-child(n+2){display:none}
}
/* Mobile: topbar volledig verbergen — telefoon + trust staan al in burger en footer */
@media(max-width:900px){
  .site-topbar{display:none !important}
  :root{--chrome-topbar-h:0px}
}
@media(max-width:640px){
  :root{--chrome-main-h:64px}
  .site-header{height:var(--chrome-main-h)}
  .site-header .wrap{padding:0 16px}
  .site-header .brand img{height:20px}
  .header-actions{gap:8px}
  .header-cta-btn{padding:9px 13px;font-size:12.5px}
  .header-cta-btn .cta-long{display:none}
  .header-cta-btn svg{width:12px;height:12px}
  .header-burger{width:38px;height:38px}
  /* Pre-footer schaling */
  .site-pre-footer{padding:48px 0}
  .pre-footer-grid h2{font-size:clamp(26px,7vw,34px)}
  .pre-footer-grid p{font-size:15px}
  /* Mobile-nav opent onder kleiner header */
  .mobile-nav{top:var(--chrome-main-h)}
}
@media(max-width:400px){
  .header-cta-btn{padding:9px 11px;font-size:12px}
  .header-cta-btn svg{display:none}
}

/* ============ PRE-FOOTER CTA BANNER ============ */
.site-pre-footer{
  background:linear-gradient(135deg,var(--chrome-deep) 0%,#300037 100%);
  color:#fff;padding:80px 0;position:relative;overflow:hidden;
  font-family:var(--font-body,'Forma DJR Micro',Inter,system-ui,sans-serif);
}
.site-pre-footer::before{
  content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;
  background:radial-gradient(circle,rgba(218,41,28,.18) 0%,transparent 70%);
  pointer-events:none;
}
.site-pre-footer .wrap{max-width:var(--maxw,1200px);margin:0 auto;padding:0 24px;position:relative;z-index:2}
.pre-footer-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:center}
.pre-footer-eyebrow{font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#D7D2CB;margin-bottom:14px}
.pre-footer-grid h2{
  font-family:var(--font-display,'Neue Power','Arial Black',sans-serif);
  font-weight:900;font-size:clamp(32px,4.2vw,52px);line-height:1.05;letter-spacing:-.015em;
}
.pre-footer-grid h2 em{color:var(--chrome-red,#DA291C);font-style:italic}
.pre-footer-grid p{font-size:17px;color:rgba(255,255,255,.85);margin-top:18px;max-width:46ch}
.pre-footer-actions{display:flex;flex-direction:column;gap:14px}
.pf-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:18px 28px;border-radius:999px;font-weight:700;font-size:16px;
  text-decoration:none;border:2px solid transparent;transition:background .15s,transform .15s,border-color .15s;
}
.pf-btn.primary{background:var(--chrome-red);color:#fff;border-color:var(--chrome-red)}
.pf-btn.primary:hover{background:var(--chrome-red-deep);border-color:var(--chrome-red-deep);transform:translateY(-2px)}
.pf-btn.secondary{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.pf-btn.secondary:hover{background:rgba(255,255,255,.08);border-color:#fff}
.pf-btn svg{width:18px;height:18px}
.pre-footer-note{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.7);font-size:13.5px;margin-top:8px;justify-content:center}
.pre-footer-note svg{width:14px;height:14px;color:rgba(255,255,255,.85)}

/* ============ FOOTER ============ */
.site-footer{
  background:#300037;color:rgba(255,255,255,.78);
  padding:72px 0 0;font-size:14.5px;
  font-family:var(--font-body,'Forma DJR Micro',Inter,system-ui,sans-serif);
}
.site-footer .wrap{max-width:var(--maxw,1200px);margin:0 auto;padding:0 24px}
.footer-grid{
  display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:48px;margin-bottom:56px;
}
.footer-brand img{height:26px;margin-bottom:18px;display:block}
.footer-brand p{font-size:14.5px;color:rgba(255,255,255,.7);max-width:34ch;line-height:1.55;margin-bottom:22px}
.footer-rating{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.05);padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.08);max-width:280px}
.footer-rating .score{font-family:var(--font-display,'Neue Power','Arial Black',sans-serif);font-weight:900;font-size:24px;color:#fff;line-height:1}
.footer-rating .meta{font-size:12.5px;color:rgba(255,255,255,.65);line-height:1.35}
.footer-rating .meta b{color:#fff}
.footer-rating .stars{color:#DA291C;font-size:13px;letter-spacing:1px}
.footer-meta{margin-top:22px;font-size:13px;color:rgba(255,255,255,.55);line-height:1.6}

.footer-col h4{
  font-size:13px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:#fff;margin-bottom:18px;font-family:var(--font-body,'Forma DJR Micro',Inter,system-ui,sans-serif);
}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:rgba(255,255,255,.72);text-decoration:none;font-size:14.5px;transition:color .15s}
.footer-col a:hover{color:var(--chrome-red);text-decoration:underline;text-underline-offset:3px}

.footer-trust{
  border-top:1px solid rgba(255,255,255,.10);border-bottom:1px solid rgba(255,255,255,.10);
  padding:24px 0;display:flex;flex-wrap:wrap;justify-content:center;gap:42px;align-items:center;
}
.footer-trust-item{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.7);font-size:13px;font-weight:600;letter-spacing:.02em}
.footer-trust-item svg{width:20px;height:20px;color:#D7D2CB;flex-shrink:0}
.footer-trust-item b{color:#fff;font-weight:700}

.footer-bottom{
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:18px;
  padding:26px 0 32px;font-size:13px;color:rgba(255,255,255,.55);
}
.footer-bottom-left{display:flex;gap:20px;flex-wrap:wrap}
.footer-bottom-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-bottom-links a{color:rgba(255,255,255,.62);text-decoration:none}
.footer-bottom-links a:hover{color:#fff}
.footer-social{display:flex;gap:10px;align-items:center}
.footer-social a{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.7);transition:background .15s,color .15s;
}
.footer-social a:hover{background:var(--chrome-red);color:#fff}
.footer-social svg{width:15px;height:15px}

@media(max-width:1024px){
  .pre-footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-grid{grid-template-columns:1fr 1fr 1fr;gap:36px}
  .footer-brand{grid-column:span 3}
  .footer-trust{gap:24px}
}
@media(max-width:640px){
  .site-pre-footer{padding:56px 0}
  .pre-footer-actions{flex-direction:column}
  .pf-btn{width:100%}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand{grid-column:span 2}
  .footer-trust{gap:16px;padding:20px 0}
  .footer-trust-item{font-size:12px;flex:1 1 calc(50% - 8px);justify-content:flex-start}
  .footer-bottom{flex-direction:column;align-items:flex-start;text-align:left}
}

/* ============ OVERRULE oude inline header/footer regels ============ */
header.site,
.utility,
footer:not(.site-footer){display:none !important}

/* =============================================================
   TRUSTPILOT REVIEWS — Styleguide-strict (Pulse Red sterren)
   Trustpilot data, AEDCenter branded presentatie
   ============================================================= */
.tp-section{
  background:#FFFFFF;
  padding:72px 24px;
  border-top:1px solid rgba(28,20,32,.08);
  border-bottom:1px solid rgba(28,20,32,.08);
}
.tp-section .wrap{max-width:var(--maxw,1200px);margin:0 auto}
.tp-eyebrow{
  font-family:var(--font-body,'Forma DJR Micro',Inter,system-ui,sans-serif);
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--chrome-red,#DA291C);font-weight:700;margin:0 0 12px;
}
.tp-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:32px;flex-wrap:wrap;margin-bottom:32px;
}
.tp-head h2{
  font-family:var(--font-display,'Neue Power','Neue Power Bold',Inter,system-ui,sans-serif);
  font-weight:800;font-size:clamp(28px,4vw,40px);line-height:1.05;letter-spacing:-.02em;
  color:#1C1420;margin:0;max-width:640px;
}
.tp-head h2 em{font-style:italic;color:var(--chrome-red,#DA291C);font-weight:800}

/* Trustpilot summary badge */
.tp-badge{
  display:inline-flex;align-items:center;gap:14px;
  background:#FFFFFF;border:1px solid rgba(28,20,32,.12);
  padding:14px 18px;border-radius:8px;
  font-family:var(--font-body,'Forma DJR Micro',Inter,system-ui,sans-serif);
  text-decoration:none;color:#1C1420;
  transition:transform .18s ease, box-shadow .18s ease;
}
.tp-badge:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(28,20,32,.08)}
.tp-badge .tp-stars{display:flex;gap:2px}
.tp-badge .tp-stars svg{width:22px;height:22px;color:var(--chrome-red,#DA291C)}
.tp-badge .tp-meta{display:flex;flex-direction:column;line-height:1.2}
.tp-badge .tp-rating{font-weight:800;font-size:18px;color:#1C1420}
.tp-badge .tp-rating span{color:rgba(28,20,32,.5);font-weight:600}
.tp-badge .tp-count{font-size:12px;color:rgba(28,20,32,.62);letter-spacing:.02em}
.tp-badge .tp-wordmark{
  font-weight:800;font-size:13px;letter-spacing:-.01em;color:#1C1420;
  border-left:1px solid rgba(28,20,32,.12);padding-left:14px;
}
.tp-badge .tp-wordmark::before{
  content:"★";color:var(--chrome-red,#DA291C);margin-right:4px;font-size:14px;
}

/* Grid of review cards */
.tp-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
@media (max-width:960px){.tp-grid{grid-template-columns:1fr;gap:14px}}
.tp-card{
  background:#FFFFFF;
  border:1px solid rgba(28,20,32,.10);
  border-radius:10px;
  padding:24px;
  display:flex;flex-direction:column;gap:12px;
  transition:border-color .18s ease, transform .18s ease;
}
.tp-card:hover{border-color:rgba(218,41,28,.35);transform:translateY(-2px)}
.tp-card .tp-card-stars{display:flex;gap:2px}
.tp-card .tp-card-stars svg{width:18px;height:18px;color:var(--chrome-red,#DA291C)}
.tp-card h3{
  font-family:var(--font-display,'Neue Power','Neue Power Bold',Inter,system-ui,sans-serif);
  font-weight:800;font-size:17px;line-height:1.25;color:#1C1420;margin:0;letter-spacing:-.01em;
}
.tp-card p{
  font-family:var(--font-body,'Forma DJR Micro',Inter,system-ui,sans-serif);
  font-size:14.5px;line-height:1.55;color:rgba(28,20,32,.78);margin:0;flex:1;
}
.tp-card .tp-card-meta{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--font-body,'Forma DJR Micro',Inter,system-ui,sans-serif);
  font-size:12.5px;color:rgba(28,20,32,.55);
  border-top:1px solid rgba(28,20,32,.08);padding-top:12px;margin-top:auto;
}
.tp-card .tp-card-author{font-weight:700;color:#1C1420}
.tp-foot{
  margin-top:28px;text-align:center;
  font-family:var(--font-body,'Forma DJR Micro',Inter,system-ui,sans-serif);
  font-size:13px;color:rgba(28,20,32,.62);
}
.tp-foot a{color:var(--chrome-red,#DA291C);font-weight:700;text-decoration:none}
.tp-foot a:hover{text-decoration:underline}

/* === CLIENT LOGO TICKER === */
.client-ticker{
  position:relative;
  background:#FFFFFF;
  padding:56px 0 64px;
  overflow:hidden;
  border-top:1px solid rgba(28,20,32,.06);
  border-bottom:1px solid rgba(28,20,32,.06);
}
.client-ticker .wrap{position:relative}
.client-ticker-head{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  margin-bottom:36px;text-align:center;
}
.client-ticker-head .eyebrow{
  font-family:var(--font-body,'Forma DJR Micro',Inter,system-ui,sans-serif);
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
  color:rgba(48,0,55,.55);
}
.client-ticker-head h2{
  font-family:var(--font-display,'Neue Power',ui-sans-serif,system-ui,sans-serif);
  font-weight:800;font-size:clamp(22px,3vw,30px);line-height:1.15;
  color:#300037;margin:0;letter-spacing:-.015em;
}
.client-ticker-head h2 em{font-style:italic;color:#DA291C;font-weight:800}
.client-ticker-viewport{
  position:relative;
  width:100%;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
}
.client-ticker-track{
  display:flex;
  align-items:center;
  width:max-content;
  animation:ticker-scroll 56s linear infinite;
  will-change:transform;
}
.client-ticker:hover .client-ticker-track{animation-play-state:paused}
.client-ticker-item{
  display:flex;align-items:center;justify-content:center;
  flex:0 0 auto;
  padding:0 56px;
  height:72px;
}
.client-ticker-item img{
  max-height:56px;
  width:auto;
  opacity:.62;
  transition:opacity .35s ease, transform .35s ease;
  filter:none; /* logos zijn al pre-rendered in Deep Focus */
  user-select:none;-webkit-user-drag:none;
}
.client-ticker-item:hover img{opacity:1;transform:scale(1.04)}
@keyframes ticker-scroll{
  from{transform:translate3d(0,0,0)}
  to  {transform:translate3d(-50%,0,0)}
}
@media (prefers-reduced-motion: reduce){
  .client-ticker-track{animation:none;transform:none}
  .client-ticker-viewport{overflow-x:auto}
}
@media (max-width: 768px){
  .ticker{padding:40px 0 48px}
  .ticker-head{margin-bottom:24px}
  .ticker-item{padding:0 32px;height:56px}
  .ticker-item img{max-height:40px;opacity:.7}
  .ticker-track{animation-duration:38s}
}
