/* TBGS Site CSS — shared across every generated page.
   Mirrors brand-card.html design system 1:1. */

:root {
  --bg:#0A0E1A; --bg-soft:#0F1424; --card:#131828; --card-hover:#171D31;
  --text:#F5F6FA; --muted:#A8AFC3; --label:#8B92A8;
  --border:rgba(255,255,255,.08); --border-strong:rgba(255,255,255,.14);
  --wa:#25D366; --heritage:#D4A94E;
  --tds:#D71F36; --tds-dim:rgba(215,31,54,.14); --tds-glow:rgba(215,31,54,.35);
  --tss:#0064A8; --tss-dim:rgba(0,100,168,.18); --tss-glow:rgba(0,100,168,.40);
  --tos:#85BA3F; --tos-dim:rgba(133,186,63,.16); --tos-glow:rgba(133,186,63,.35);
  --tbs:#F9C22F; --tbs-dim:rgba(249,194,47,.18); --tbs-glow:rgba(249,194,47,.35);
  --brand:#1E99EE; --brand-dim:rgba(30,153,238,.12); --brand-glow:rgba(30,153,238,.35);
  --ease:cubic-bezier(.16,1,.3,1); --ease-snap:cubic-bezier(.2,.8,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:clip}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

/* Brand bindings */
[data-brand="tds"]{--brand:var(--tds);--brand-dim:var(--tds-dim);--brand-glow:var(--tds-glow)}
[data-brand="tss"]{--brand:var(--tss);--brand-dim:var(--tss-dim);--brand-glow:var(--tss-glow)}
[data-brand="tos"]{--brand:var(--tos);--brand-dim:var(--tos-dim);--brand-glow:var(--tos-glow)}
[data-brand="tbs"]{--brand:var(--tbs);--brand-dim:var(--tbs-dim);--brand-glow:var(--tbs-glow)}

/* === NAV — clean rewrite (Mr R msg #360, .th- namespace) ===
   - Mobile-first: floating pill bar, slide-in panel from right with backdrop
   - Desktop ≥1025: pill bar with hover-dropdowns, no panel
   - Hub-rows have TWO controls: link to /hub + button to toggle sub-menu
   - All toggles are <button> (no :focus-within trap from <a>)
   - Single source of truth — same on every page (except /qr) */

.th{
  position:fixed;top:8px;left:8px;right:8px;z-index:120;
  font-family:'Inter',sans-serif;
}
.th-bar{
  position:relative;display:flex;align-items:center;gap:10px;
  padding:8px 14px;min-height:54px;
  background:linear-gradient(180deg,rgba(15,20,36,.92) 0%,rgba(10,14,26,.86) 100%);
  backdrop-filter:blur(22px) saturate(160%);-webkit-backdrop-filter:blur(22px) saturate(160%);
  border:1px solid var(--border-strong);border-radius:18px;
  box-shadow:0 10px 40px -12px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.04) inset;
  transition:background .35s ease,box-shadow .35s ease;
}
.th.is-scrolled .th-bar{
  background:linear-gradient(180deg,rgba(15,20,36,.96) 0%,rgba(10,14,26,.92) 100%);
  box-shadow:0 16px 50px -12px rgba(0,0,0,.75);
}
.th-bar::before{
  content:'';position:absolute;left:18px;right:18px;top:1px;height:1px;border-radius:2px;
  background:linear-gradient(90deg,transparent 0%,var(--brand,#1E99EE) 50%,transparent 100%);
  opacity:.5;
}

/* Brand-link (logo + naam) */
.th-brand-link{display:inline-flex;align-items:center;gap:10px;text-decoration:none;flex:0 0 auto}
.th-logo{display:block;width:36px;height:auto;filter:drop-shadow(0 4px 10px rgba(0,0,0,.5))}
.th-brand{font-family:'Outfit',sans-serif;font-weight:800;font-size:18px;letter-spacing:-.025em;color:#fff;line-height:1}
.th-brand i{color:var(--brand,#1E99EE);font-style:normal}

/* Burger (mobile) */
.th-burger{
  display:none;width:44px;height:44px;border-radius:12px;flex:0 0 auto;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  align-items:center;justify-content:center;flex-direction:column;gap:5px;
  transition:all .25s var(--ease);position:relative;z-index:2;
}
.th-burger:hover{background:rgba(255,255,255,.08);border-color:var(--border-strong)}
.th-burger span{display:block;width:18px;height:2px;background:#fff;border-radius:2px;transition:transform .35s var(--ease),opacity .2s ease}
.th .is-open .th-burger span:nth-child(1),
.th.is-open .th-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.th.is-open .th-burger span:nth-child(2){opacity:0;transform:scaleX(0)}
.th.is-open .th-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* CTA in bar (Offerte button) */
.th-cta{
  display:inline-flex;align-items:center;gap:6px;flex:0 0 auto;
  padding:10px 18px;border-radius:999px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:13px;color:#fff;text-decoration:none;
  background:var(--brand,#1E99EE);
  box-shadow:0 6px 20px var(--brand-glow,rgba(30,153,238,.35));
  transition:transform .25s ease,box-shadow .25s ease,filter .25s ease;
}
.th-cta:hover{transform:translateY(-1px);filter:brightness(1.08);box-shadow:0 10px 28px var(--brand-glow,rgba(30,153,238,.45))}
.th-cta svg{width:13px;height:13px;transition:transform .25s ease}
.th-cta:hover svg{transform:translateX(2px)}

/* Panel (mobile drawer) */
.th-panel{
  position:fixed;top:70px;right:8px;bottom:88px;width:min(calc(100vw - 16px),420px);
  background:linear-gradient(160deg,rgba(15,20,36,.98) 0%,rgba(10,14,26,.98) 100%);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid var(--border-strong);border-radius:20px;
  box-shadow:0 24px 60px -12px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.04) inset;
  display:flex;flex-direction:column;gap:0;padding:14px 14px 10px;
  transform:translateX(calc(100% + 18px));opacity:0;pointer-events:none;
  transition:transform .45s cubic-bezier(.2,.8,.2,1),opacity .3s ease;
  z-index:119;overflow-y:auto;overscroll-behavior:contain;
}
.th.is-open .th-panel{transform:translateX(0);opacity:1;pointer-events:auto}

.th-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px;flex:1 1 auto}

/* Single link row (Home, Kennisbank) */
.th-link{
  display:flex;align-items:center;gap:10px;
  padding:14px 14px;font-size:15px;font-weight:600;color:rgba(245,246,250,.92);
  border-radius:12px;text-decoration:none;transition:background .2s ease,color .2s ease;
  position:relative;
}
.th-link:hover,.th-link:focus-visible{background:rgba(255,255,255,.04);color:#fff;outline:none}
.th-link.is-active{color:#fff;background:var(--brand-dim,rgba(30,153,238,.14))}

/* Hub group (with sub-menu) */
.th-group{position:relative}
.th-group[data-brand="tds"]{--brand:var(--tds);--brand-dim:var(--tds-dim);--brand-glow:var(--tds-glow)}
.th-group[data-brand="tss"]{--brand:var(--tss);--brand-dim:var(--tss-dim);--brand-glow:var(--tss-glow)}
.th-group[data-brand="tos"]{--brand:var(--tos);--brand-dim:var(--tos-dim);--brand-glow:var(--tos-glow)}
.th-group[data-brand="tbs"]{--brand:var(--tbs);--brand-dim:var(--tbs-dim);--brand-glow:var(--tbs-glow)}

.th-row{display:flex;align-items:stretch;gap:0;border-radius:12px;transition:background .2s ease}
.th-row:hover{background:rgba(255,255,255,.03)}
.th-row .th-link{flex:1 1 auto;border-radius:12px 0 0 12px}
.th-group.is-active .th-row .th-link{color:var(--brand);background:var(--brand-dim)}

.th-dot{
  width:8px;height:8px;border-radius:50%;background:var(--brand);
  box-shadow:0 0 8px var(--brand-glow);flex:none;
}

.th-toggle{
  width:64px;flex:0 0 64px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.03);color:rgba(255,255,255,.55);border-radius:0 12px 12px 0;
  border-left:1px solid rgba(255,255,255,.06);
  transition:background .2s ease,color .2s ease;
  -webkit-tap-highlight-color:transparent;min-height:48px;
}
.th-toggle:hover,.th-toggle:active{background:rgba(255,255,255,.08);color:#fff}
.th-toggle svg{width:18px;height:18px;transition:transform .35s var(--ease)}
.th-group.is-expanded .th-toggle svg{transform:rotate(180deg)}
.th-group.is-expanded .th-toggle{color:var(--brand)}

/* Sub-menu (collapsed → expanded via .is-expanded class) */
.th-drop{
  display:flex;flex-direction:column;gap:2px;
  margin:0 4px;padding-left:18px;
  border-left:2px solid var(--brand,var(--border-strong));
  max-height:0;overflow:hidden;
  transition:max-height .35s cubic-bezier(.2,.8,.2,1),margin .25s ease;
}
.th-group.is-expanded .th-drop{max-height:600px;margin:6px 4px 10px;padding-block:6px}
.th-drop-head{
  display:flex;flex-direction:row;align-items:center;gap:12px;
  padding:12px 14px;margin-bottom:6px;
  border:1.5px solid var(--brand);border-radius:10px;
  background:var(--brand-dim);text-decoration:none;
  position:relative;
}
.th-drop-head::after{
  content:'→';position:absolute;right:14px;top:50%;transform:translateY(-50%);
  font-size:18px;color:var(--brand);font-weight:bold;
}
.th-drop-shield{flex:none;width:32px;height:auto;filter:drop-shadow(0 4px 10px rgba(0,0,0,.5))}
.th-drop-head-text{display:flex;flex-direction:column;gap:2px;flex:1 1 auto;padding-right:18px}
.th-drop-head strong{font-family:'Outfit',sans-serif;font-weight:700;font-size:14.5px;color:#fff;line-height:1.15}
.th-drop-head span{font-family:'JetBrains Mono',monospace;font-size:9.5px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase}
.th-drop-link{
  display:block;padding:10px 14px;font-size:14px;font-weight:500;
  color:rgba(245,246,250,.78);border-radius:8px;text-decoration:none;
  transition:background .2s ease,color .2s ease,padding .25s ease;
}
.th-drop-link:hover{background:rgba(255,255,255,.05);color:#fff;padding-left:18px}

/* Foot (panel bottom: phone + offerte) */
.th-foot{
  display:flex;gap:10px;flex:0 0 auto;
  padding:12px 0 calc(env(safe-area-inset-bottom,0) + 4px);margin-top:6px;
  border-top:1px solid rgba(255,255,255,.06);
}
.th-foot-tel,.th-foot-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  flex:1 1 0;padding:13px 14px;border-radius:12px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:13.5px;text-decoration:none;
}
.th-foot-tel{background:rgba(255,255,255,.06);border:1px solid var(--border-strong);color:#fff}
.th-foot-tel:hover{background:rgba(255,255,255,.1)}
.th-foot-tel svg{width:14px;height:14px}
.th-foot-cta{background:var(--brand,#1E99EE);color:#fff;box-shadow:0 6px 18px var(--brand-glow,rgba(30,153,238,.35))}
.th-foot-cta:hover{filter:brightness(1.08)}
.th-foot-cta svg{width:13px;height:13px;transition:transform .25s ease}
.th-foot-cta:hover svg{transform:translateX(2px)}

/* Backdrop (mobile drawer, dim everything behind) */
.th-backdrop{
  position:fixed;inset:0;z-index:118;
  background:rgba(5,8,14,.55);backdrop-filter:blur(2px);
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
  border-radius:0;
}
.th.is-open ~ * .th-backdrop,
.th.is-open .th-backdrop{opacity:1;pointer-events:auto}

/* Body lock when panel open */
body.th-open{overflow:hidden}

/* === DESKTOP (≥1025px) — pill bar with inline nav + hover-dropdowns === */
@media (min-width:1025px){
  .th{top:14px;left:14px;right:14px}
  .th-bar{padding:8px 18px;min-height:62px;gap:24px}
  .th-burger{display:none !important}
  .th-backdrop{display:none}

  /* CTA pinned right (logo left, nav centered, CTA right) */
  .th-cta{margin-left:auto}

  /* th-panel overlays th-bar (centered) instead of stacking below it.
     Sibling-of-th-bar in DOM, but absolutely positioned within .th
     (which spans the same rect as the pill). pointer-events:none lets
     clicks pass through to logo + CTA underneath; .th-list re-enables
     them for the nav links themselves. */
  .th-panel{
    position:absolute;inset:0;
    background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;
    border:0;border-radius:0;box-shadow:none;padding:0;margin:0;
    width:auto;display:flex;align-items:center;justify-content:center;
    transform:none;opacity:1;pointer-events:none;overflow:visible;
    z-index:1;height:auto;
  }
  .th-list{pointer-events:auto}
  .th-panel[aria-hidden]{aria-hidden:false}

  .th-list{flex-direction:row;align-items:center;gap:4px}
  .th-list > li{position:relative}

  .th-link{
    padding:10px 16px;font-size:14px;font-weight:500;color:rgba(245,246,250,.72);
    border-radius:10px;line-height:1;white-space:nowrap;
  }
  .th-link:hover{color:#fff;background:rgba(255,255,255,.04)}
  .th-link.is-active{color:var(--brand);background:var(--brand-dim)}

  .th-row{background:transparent}
  .th-row:hover{background:transparent}
  .th-row .th-link{border-radius:10px 0 0 10px;padding-right:8px}
  .th-toggle{
    width:auto;flex:0 0 auto;padding:0 10px 0 4px;border-left:0;
    border-radius:0 10px 10px 0;color:rgba(255,255,255,.55);
  }
  .th-toggle svg{width:11px;height:11px}
  .th-group:hover .th-toggle svg{transform:rotate(180deg)}
  .th-group:hover .th-link{color:#fff;background:rgba(255,255,255,.04)}
  .th-group:hover .th-row{background:rgba(255,255,255,.04);border-radius:10px}

  /* Desktop dropdown — appears on hover, position absolute */
  .th-drop{
    position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(-8px);
    min-width:300px;padding:10px;margin:0;
    background:linear-gradient(160deg,rgba(20,26,44,.98) 0%,rgba(12,16,28,.98) 100%);
    backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);
    border:1px solid var(--border-strong);border-left:1px solid var(--border-strong);border-radius:18px;
    box-shadow:0 32px 80px -20px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.03) inset,0 -1px 0 var(--brand-glow) inset;
    max-height:none;overflow:visible;opacity:0;pointer-events:none;visibility:hidden;
    transition:opacity .25s ease,transform .35s var(--ease),visibility 0s .25s;
  }
  .th-group:hover .th-drop,
  .th-group:focus-within .th-drop{
    opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);visibility:visible;
    transition:opacity .25s ease,transform .35s var(--ease),visibility 0s;
  }
  /* Hover-bridge so cursor doesn't lose dropdown crossing the gap */
  .th-drop::before{content:'';position:absolute;top:-16px;left:0;right:0;height:16px}

  .th-drop-link{padding:9px 14px;border-radius:8px}
  .th-drop-link:hover{background:var(--brand-dim);color:#fff}

  /* Foot hidden on desktop (CTA sits in the bar instead) */
  .th-foot{display:none}
}
@media (max-width:1024px){
  /* Mobile bar: logo links, burger ABSOLUUT-gecentreerd in viewport, CTA rechts (msg #373) */
  .th-bar{gap:8px;justify-content:space-between;position:relative}
  .th-burger{
    display:flex;position:absolute;left:50%;top:50%;
    transform:translate(-50%,-50%);z-index:2;
  }
  .th-burger:hover{transform:translate(-50%,-50%) scale(1.05)}
  .th .is-open .th-burger,
  .th.is-open .th-burger{transform:translate(-50%,-50%)}
  .th-cta{padding:9px 14px;font-size:12.5px}
  .th-cta svg{display:none}
  .th-brand-link{z-index:1}
  .th-cta{z-index:1}
  .th-brand{font-size:16px}
  .th-logo{width:32px}
}
@media (max-width:480px){
  /* Compact bar — TBGS B.V. text + CTA blijven zichtbaar (Mr R msg #382: full brand consistent overal) */
  .th-bar{padding:6px 10px;min-height:48px;gap:6px}
  .th-cta{padding:8px 11px;font-size:11.5px;border-radius:999px}
  .th-brand{font-size:14.5px}
  .th-logo{width:28px}
}
@media (max-width:380px){
  /* Hele kleine phones (iPhone SE 1st gen): nog compacter, tekst behouden */
  .th-cta{padding:7px 10px;font-size:11px}
  .th-brand{font-size:13.5px;letter-spacing:-.03em}
  .th-bar{padding:5px 8px;gap:4px}
}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:8px;font:600 14px 'Inter';padding:12px 22px;border-radius:999px;transition:all .35s var(--ease);white-space:nowrap}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 8px 28px var(--brand-glow)}
.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 12px 36px var(--brand-glow)}
.btn-ghost{background:rgba(255,255,255,.06);color:#fff;border:1px solid var(--border-strong);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-wa{background:var(--wa);color:#fff;box-shadow:0 8px 28px rgba(37,211,102,.35)}
.btn-wa:hover{filter:brightness(1.08);transform:translateY(-1px)}

/* === BREADCRUMBS === */
.bc{max-width:1240px;margin:0 auto;padding:18px 32px 0;display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em}
.bc a{color:var(--label);transition:color .15s}
.bc a:hover{color:var(--brand)}
.bc .home{color:var(--brand)}
.bc .sep{color:rgba(255,255,255,.18)}
.bc .current{color:var(--brand)}

/* === HERO === */
/* overflow:clip (not hidden) so position:sticky descendants on the homepage canvas hero still work. */
.hero{position:relative;padding:80px 32px 64px;overflow:clip}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,var(--brand-dim),transparent 50%),radial-gradient(circle at 80% 70%,var(--brand-glow),transparent 55%);opacity:.4;pointer-events:none;filter:blur(40px)}
.hero-inner{max-width:1240px;margin:0 auto;position:relative;z-index:1;display:grid;grid-template-columns:1.4fr .9fr;gap:48px;align-items:center}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.22em;color:var(--brand);margin-bottom:18px;display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:'';width:24px;height:1px;background:currentColor}
h1.hero-h1{font-family:'Outfit',sans-serif;font-weight:800;font-size:clamp(38px,5.5vw,72px);letter-spacing:-.03em;line-height:1.05;margin-bottom:18px}
h1.hero-h1 .hl{color:var(--brand)}
.hero-sub{font-size:18px;color:var(--muted);max-width:640px;line-height:1.6;margin-bottom:26px}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}
.hero-pill{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border-radius:999px;background:rgba(12,14,22,.55);border:1px solid var(--border);font-size:12.5px;color:var(--muted);font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.14em}

/* === FORM ABANDONMENT RECOVERY notice (FSM) === */
.fsm-restore-notice{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;border-radius:10px;background:linear-gradient(135deg,var(--brand-dim),rgba(255,255,255,.03));border:1px solid var(--brand);font-size:12.5px;color:var(--text);margin-bottom:6px;animation:fsm-fadein .35s ease}
.fsm-restore-notice .fsm-restore-clear{background:transparent;border:1px solid var(--border-strong);color:var(--muted);padding:5px 11px;border-radius:999px;cursor:pointer;font-size:11px;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.12em;transition:.2s}
.fsm-restore-notice .fsm-restore-clear:hover{color:var(--brand);border-color:var(--brand)}
@keyframes fsm-fadein{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

/* === AFTER-HOURS DYNAMIC ISLAND — compact pill morphs into rich panel on tap.
   Bottom-LEFT clear van FSM bubble (bottom-right). Per-brand color via
   var(--brand): TDS rood, TSS blauw, TOS groen, TBS goud, TBGS blauw default.
   Pattern: cinematic-sites kit Module 22. === */
.ah-island{position:fixed;bottom:14px;left:14px;z-index:91;font-family:'Inter',sans-serif}
.ah-island[hidden]{display:none}
.ah-island-pill{display:inline-flex;align-items:center;gap:9px;min-width:188px;background:rgba(15,17,22,.94);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--brand);border-radius:999px;padding:9px 16px 9px 13px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 8px 22px rgba(0,0,0,.35),0 0 0 1px var(--brand-dim) inset;transition:all .45s cubic-bezier(.16,1,.3,1);font-family:inherit;animation:ah-island-in .35s cubic-bezier(.16,1,.3,1)}
.ah-island-pill:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(0,0,0,.4),0 0 0 1px var(--brand) inset}
.ah-island-pill .ah-dot{width:8px;height:8px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 3px var(--brand-dim);animation:ah-pulse 2s ease-in-out infinite;flex:none}
.ah-island-pill .ah-chev{font-size:14px;opacity:.55;line-height:1;margin-left:auto;transition:transform .25s ease}
.ah-island.open .ah-island-pill{display:none}
.ah-island-panel{display:none;width:340px;max-width:calc(100vw - 28px);background:linear-gradient(180deg,#131828 0%,#0F1424 100%);border:1px solid var(--brand);border-radius:18px;padding:18px 18px 14px;box-shadow:0 30px 60px rgba(0,0,0,.55),0 0 0 1px var(--brand-dim) inset;color:#fff;flex-direction:column;gap:13px;animation:ah-island-in .35s cubic-bezier(.16,1,.3,1);transform-origin:bottom left}
.ah-island.open .ah-island-panel{display:flex}
.ah-panel-head{display:flex;align-items:center;gap:11px;font-size:15px;font-weight:700;letter-spacing:-.005em}
.ah-panel-head .ah-dot{width:10px;height:10px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 4px var(--brand-dim);animation:ah-pulse 2s ease-in-out infinite;flex:none}
.ah-panel-sub{margin:0;font-size:13px;color:rgba(255,255,255,.74);line-height:1.55}
.ah-island .ah-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 14px;border-radius:10px;background:#22C55E;color:#fff;font-weight:600;font-size:13.5px;text-decoration:none;transition:background .2s}
.ah-island .ah-cta:hover{background:#16a34a}
.ah-island .ah-tel{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:10px;background:var(--brand-dim);color:#fff;font-weight:600;font-size:13.5px;text-decoration:none;border:1px solid var(--brand)}
.ah-island .ah-tel:hover{background:var(--brand-glow)}
.ah-island .ah-close{margin-top:2px;background:none;border:0;color:rgba(255,255,255,.55);font-size:12px;font-family:inherit;cursor:pointer;padding:4px;align-self:center}
.ah-island .ah-close:hover{color:#fff}
@keyframes ah-pulse{0%,100%{box-shadow:0 0 0 3px var(--brand-dim)}50%{box-shadow:0 0 0 5px var(--brand-glow)}}
@keyframes ah-island-in{from{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
@media (max-width:640px){
  .ah-island{bottom:12px;left:12px}
  .ah-island-pill{min-width:0}
  .ah-island-panel{width:calc(100vw - 24px);max-width:340px}
}
/* After-hours: hide ALLEEN de sticky CTA pill (.lp-sticky) — die overlapt
   visueel met de ah-island op bottom-left. FSM trigger (rechter chat-bubble)
   blijft ALTIJD zichtbaar — gebruikers moeten 24/7 een vaste contact-route
   zien (Mr R msg #261). ah-island toggled body.is-after-hours via JS. */
body.is-after-hours .lp-sticky{display:none !important}

/* Premium pillar-card pattern voor pageLanding sections.cards — geinspireerd
   op brand-card.html .svc-card (Mr R msg #281: "improve learn from brand-card").
   Hover-effecten + brand-stripe + clickable variant met CTA-arrow. */
.lp-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:16px}
.lp-card{position:relative;padding:24px;background:var(--card);border:1px solid var(--border);border-radius:14px;display:flex;flex-direction:column;overflow:hidden;text-decoration:none;color:var(--text);transition:.3s var(--ease)}
.lp-card__stripe{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brand);opacity:.45;transition:.3s var(--ease)}
.lp-card--link{cursor:pointer}
.lp-card--link:hover{transform:translateY(-3px);border-color:var(--brand);background:var(--card-hover);box-shadow:0 24px 60px -30px var(--brand-glow)}
.lp-card--link:hover .lp-card__stripe{opacity:1;width:4px}
.lp-card__h{font-family:'Outfit',sans-serif;font-weight:700;margin:0 0 8px;font-size:17px;letter-spacing:-.005em}
.lp-card__p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.5;flex:1}
.lp-card__cta{margin-top:14px;display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--brand);transition:.25s}
.lp-card--link:hover .lp-card__cta{transform:translateX(4px)}

/* Mobile nav open: hide FSM trigger en sticky CTA — overlappen met het
   uitgeklapte mobile menu (Mr R msg #266). body.nav-open wordt gezet door
   het mobiele burger-script. */
body.nav-open .fsm-trigger,
body.nav-open .fsm-badge,
body.nav-open .lp-sticky,
body.nav-open .ah-island{display:none !important}

/* === TDS BE CALLOUT — cross-domain authority transfer naar zusterbedrijf TDS.
   In-content placement (niet alleen footer) zodat de link contextueel signaal
   geeft. Brand TDS-rood (consistent met BE-data-brand="tds"). === */
.sec-tds{padding:24px 0}
.tds-callout{position:relative;background:linear-gradient(180deg,rgba(215,31,54,.08) 0%,rgba(15,20,36,.4) 60%,rgba(12,14,22,.6) 100%);border:1px solid rgba(215,31,54,.4);border-radius:22px;padding:28px 28px 22px;box-shadow:0 18px 40px rgba(215,31,54,.12),0 0 0 1px rgba(255,255,255,.03) inset;overflow:hidden}
.tds-callout::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 100% 0%,rgba(215,31,54,.18),transparent 60%);pointer-events:none}
.tds-callout__head{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px;position:relative}
.tds-callout__flag{display:inline-flex;align-items:center;border-radius:4px;overflow:hidden;border:1px solid rgba(255,255,255,.15);flex:none;margin-top:4px}
.tds-callout__lab{display:inline-block;font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#D71F36;font-family:'JetBrains Mono',monospace;margin-bottom:6px}
.tds-callout__h2{font-size:clamp(22px,3vw,30px);font-weight:700;line-height:1.18;letter-spacing:-.01em;color:var(--text);margin:0}
.tds-callout__h2 .hl{background:linear-gradient(135deg,#D71F36,#F25C75);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.tds-callout__lead{font-size:15px;color:var(--muted);line-height:1.6;margin:0 0 22px;max-width:62ch;position:relative}
.tds-callout__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;position:relative}
.tds-callout__card{display:flex;flex-direction:column;gap:6px;padding:16px;background:rgba(15,17,22,.55);border:1px solid rgba(255,255,255,.08);border-radius:14px;text-decoration:none;color:var(--text);transition:border-color .25s,transform .25s,background .25s}
.tds-callout__card:hover{border-color:rgba(215,31,54,.55);transform:translateY(-2px);background:rgba(20,18,22,.7)}
.tds-callout__ico{width:34px;height:34px;border-radius:10px;background:rgba(215,31,54,.15);color:#F25C75;display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.tds-callout__cardlab{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-family:'JetBrains Mono',monospace}
.tds-callout__cardname{font-size:15px;font-weight:600;color:var(--text);line-height:1.3}
.tds-callout__cardarr{font-size:12.5px;color:#F25C75;display:inline-flex;align-items:center;gap:4px;margin-top:auto;padding-top:8px}
.tds-callout__foot{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding-top:18px;border-top:1px solid rgba(255,255,255,.06);position:relative}
.tds-callout__meta{font-size:12px;color:var(--muted);font-family:'JetBrains Mono',monospace;letter-spacing:.06em;margin-left:auto}
@media (max-width:760px){
  .tds-callout{padding:22px 18px 18px;border-radius:18px}
  .tds-callout__grid{grid-template-columns:1fr;gap:10px}
  .tds-callout__foot{flex-direction:column;align-items:stretch}
  .tds-callout__foot .btn{justify-content:center}
  .tds-callout__meta{margin-left:0;text-align:center}
}

/* Lichtere variant voor service-pages — minder prominent dan de city-callout */
.tds-strip{background:rgba(15,17,22,.6);border:1px solid rgba(215,31,54,.3);border-left:3px solid #D71F36;border-radius:14px;padding:20px 22px}
.tds-strip__head{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}
.tds-strip__flag{display:inline-flex;align-items:center;border-radius:3px;overflow:hidden;border:1px solid rgba(255,255,255,.15);flex:none;margin-top:3px}
.tds-strip__lab{display:inline-block;font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#D71F36;font-family:'JetBrains Mono',monospace;margin-bottom:4px}
.tds-strip__title{display:block;font-size:17px;font-weight:600;line-height:1.35;color:var(--text)}
.tds-strip__lead{font-size:14px;color:var(--muted);line-height:1.6;margin:0 0 14px}
.tds-strip__cta{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.tds-strip__tel{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text);text-decoration:none;font-weight:600;font-family:'JetBrains Mono',monospace;margin-left:auto}
.tds-strip__tel:hover{color:#F25C75}
@media (max-width:560px){
  .tds-strip{padding:18px 16px}
  .tds-strip__cta{flex-direction:column;align-items:stretch}
  .tds-strip__cta .btn{justify-content:center}
  .tds-strip__tel{margin-left:0;justify-content:center;padding-top:6px}
}

/* Footer BE-card — cinematic premium card style (matcht .tds-callout vibe).
   Whole card is een link → hover-tilt + accent-glow. Mobile-first sizing. */
.foot-be-card{position:relative;display:block;margin-top:22px;padding:18px 18px 16px;background:linear-gradient(135deg,rgba(215,31,54,.14) 0%,rgba(20,12,16,.5) 55%,rgba(12,14,22,.6) 100%);border:1px solid rgba(215,31,54,.4);border-radius:16px;text-decoration:none;color:var(--text);overflow:hidden;transition:border-color .35s var(--ease),transform .35s var(--ease),box-shadow .35s var(--ease);box-shadow:0 8px 24px rgba(215,31,54,.08)}
.foot-be-card::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 90% at 100% 0%,rgba(215,31,54,.22),transparent 60%);pointer-events:none;transition:opacity .35s var(--ease)}
.foot-be-card::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#D71F36,#F25C75);border-radius:16px 0 0 16px}
.foot-be-card:hover{border-color:rgba(215,31,54,.65);transform:translateY(-2px);box-shadow:0 14px 32px rgba(215,31,54,.18)}
.foot-be-card:hover::before{opacity:1.2}
.foot-be-card__head{display:flex;align-items:center;gap:9px;margin-bottom:10px;position:relative}
.foot-be-card__flag{display:inline-flex;align-items:center;border-radius:3px;overflow:hidden;border:1px solid rgba(255,255,255,.18);flex:none;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.foot-be-card__lab{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#F25C75;font-family:'JetBrains Mono',monospace}
.foot-be-card__h{font-size:14.5px;font-weight:700;color:var(--text);margin:0 0 7px;line-height:1.3;position:relative;letter-spacing:-.005em}
.foot-be-card__p{font-size:11.5px;color:var(--muted);line-height:1.55;margin:0 0 14px;position:relative}
.foot-be-card__cta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;position:relative}
.foot-be-card__btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:8px;background:rgba(215,31,54,.22);color:#fff;font-size:12px;font-weight:600;border:1px solid rgba(215,31,54,.45);transition:background .2s,gap .2s}
.foot-be-card__btn svg{transition:transform .25s var(--ease)}
.foot-be-card:hover .foot-be-card__btn{background:rgba(215,31,54,.34)}
.foot-be-card:hover .foot-be-card__btn svg{transform:translateX(3px)}
.foot-be-card__tel{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:rgba(255,255,255,.85);font-family:'JetBrains Mono',monospace;margin-left:auto}
.foot-be-card__tel svg{width:13px;height:13px;opacity:.7}

/* === TRUST TICKER — thin band under nav with rotating proof points === */
.trust-tick{position:fixed;top:88px;left:14px;right:14px;z-index:90;border-radius:12px;background:linear-gradient(90deg,rgba(15,20,36,.85),rgba(15,20,36,.65));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);padding:6px 14px;display:flex;align-items:center;gap:10px;overflow:hidden;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);box-shadow:0 4px 12px rgba(0,0,0,.3);transition:opacity .35s ease;pointer-events:none}
.trust-tick.scrolled-out{opacity:0;transform:translateY(-6px)}
.trust-tick .tt-dot{width:6px;height:6px;border-radius:50%;background:#22C55E;box-shadow:0 0 8px #22C55E;flex:none;animation:vp-pulse 2s ease-out infinite}
.trust-tick .tt-track{flex:1;min-width:0;position:relative;height:18px}
.trust-tick .tt-item{position:absolute;inset:0;display:flex;align-items:center;gap:6px;opacity:0;transition:opacity .5s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trust-tick .tt-item.active{opacity:1}
.trust-tick .tt-item b{color:var(--text);font-weight:700}
.trust-tick .tt-item .tt-accent{color:#FFB800}
body.solid-nav{padding-top:124px}
@media (max-width:1024px){
  .trust-tick{top:74px;font-size:10px;padding:5px 12px;left:14px;right:14px}
  body.solid-nav{padding-top:108px}
}
@media (max-width:480px){
  .trust-tick{font-size:9.5px;letter-spacing:.12em;padding:5px 10px}
}

/* === LIVE VAKMAN STATUS PILL — replaces generic star rating in hero === */
.vakman-pill{display:inline-flex;align-items:center;gap:14px;padding:10px 14px 10px 10px;border-radius:18px;background:rgba(12,14,22,.65);border:1px solid var(--border-strong);text-decoration:none;color:inherit;transition:all .3s var(--ease);box-shadow:0 4px 16px rgba(0,0,0,.3);max-width:560px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.vakman-pill:hover{border-color:var(--brand);background:rgba(12,14,22,.78);transform:translateY(-1px);box-shadow:0 10px 28px var(--brand-glow)}
.vp-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-dim));color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:800;font-size:18px;flex:none;position:relative;border:2px solid rgba(255,255,255,.12);box-shadow:0 4px 12px var(--brand-glow)}
.vp-dot{position:absolute;right:-2px;bottom:-2px;width:14px;height:14px;border-radius:50%;background:#22C55E;border:2.5px solid #0A0E1A;box-shadow:0 0 0 0 rgba(34,197,94,.55);animation:vp-pulse 2s ease-out infinite}
@keyframes vp-pulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.55)}70%{box-shadow:0 0 0 10px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.vp-initials{position:relative;z-index:1}
.vp-info{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.vp-name{font-family:'Outfit',sans-serif;font-weight:700;font-size:14px;color:var(--text);line-height:1.2;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.vp-status{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:500;color:#22C55E;text-transform:uppercase;letter-spacing:.12em;display:inline-flex;align-items:center;gap:4px}
.vp-meta{font-size:11.5px;color:var(--muted);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.vp-meta b{color:#FFB800;font-weight:700;font-family:'Outfit',sans-serif;font-size:13px}
.vp-stars{display:inline-flex;gap:1px}
.vp-stars svg{fill:#FFB800;width:11px;height:11px}
.vp-cta{display:none;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;background:#25D366;color:#fff;font-size:12.5px;font-weight:600;flex:none;box-shadow:0 4px 14px rgba(37,211,102,.4)}
.vp-cta svg{width:12px;height:12px}
@media (min-width:880px){.vp-cta{display:inline-flex}}
@media (max-width:640px){
  .vakman-pill{padding:8px 12px 8px 8px;gap:10px;width:100%;max-width:none}
  .vp-avatar{width:42px;height:42px;font-size:16px}
  .vp-name{font-size:13px}
  .vp-meta{font-size:11px}
}

.hero-pill .stars{display:inline-flex;gap:1px}
.hero-pill .stars svg{fill:#FFB800;width:12px;height:12px}
.hero-pill b{color:#FFB800;font-family:'Outfit',sans-serif;font-size:14px}

/* Hero side card */
.hero-side{padding:24px;border-radius:18px;background:linear-gradient(160deg,var(--card-hover),var(--bg));border:1px solid var(--border-strong);box-shadow:0 30px 80px -40px var(--brand-glow)}
.hero-side .lab{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.2em;color:var(--brand);margin-bottom:8px}
.hero-side h3{font-family:'Outfit',sans-serif;font-weight:700;font-size:18px;margin-bottom:6px}
.hero-side p{color:var(--muted);font-size:13px;line-height:1.45;margin-bottom:14px}
.hero-side .row{display:flex;align-items:center;gap:12px;padding:10px 0;border-top:1px solid var(--border)}
.hero-side .row .ic{width:32px;height:32px;border-radius:8px;background:var(--brand-dim);color:var(--brand);display:flex;align-items:center;justify-content:center;flex:none}
.hero-side .row .l{font-family:'JetBrains Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.18em;color:var(--label);display:block;margin-bottom:2px}
.hero-side .row .v{font-family:'Outfit',sans-serif;font-weight:600;font-size:14px}

/* === SECTIONS === */
.sec{padding:80px 32px}
.sec-inner{max-width:1240px;margin:0 auto}
.sec-head{margin-bottom:48px;max-width:880px}
.sec-label{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.22em;color:var(--brand);margin-bottom:16px;display:inline-flex;align-items:center;gap:12px}
.sec-label::before{content:'';width:24px;height:1px;background:currentColor}
.sec h2{font-family:'Outfit',sans-serif;font-weight:700;font-size:clamp(28px,4vw,46px);letter-spacing:-.025em;line-height:1.05;margin-bottom:14px}
.sec h2 .hl{color:var(--brand)}
.sec p.lead{font-size:16px;color:var(--muted);line-height:1.65;max-width:720px}

/* Stat cards */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{position:relative;padding:24px;border-radius:14px;background:var(--card);border:1px solid var(--border)}
.stat::before{content:'';position:absolute;left:0;top:0;width:34px;height:3px;background:var(--brand);border-radius:0 0 4px 0}
.stat-ico{width:38px;height:38px;border-radius:10px;background:var(--brand-dim);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.stat .big{font-family:'Outfit',sans-serif;font-weight:800;font-size:36px;line-height:1;letter-spacing:-.025em;color:var(--brand);margin-bottom:6px}
.stat .big .suffix{font-size:14px;color:var(--text);margin-left:4px;opacity:.85}
.stat .label{font-size:13px;color:var(--muted);line-height:1.4}

/* Service cards grid */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.svc-card{position:relative;padding:26px;border-radius:14px;background:var(--card);border:1px solid var(--border);transition:.3s var(--ease);overflow:hidden;display:flex;flex-direction:column}
.svc-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brand);opacity:0;transition:.25s}
.svc-card:hover{transform:translateY(-4px);border-color:var(--brand);background:var(--card-hover);box-shadow:0 24px 60px -30px var(--brand-glow)}
.svc-card:hover::before{opacity:1}
.svc-card .ico{width:42px;height:42px;border-radius:10px;background:var(--brand-dim);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.svc-card h3{font-family:'Outfit',sans-serif;font-weight:700;font-size:17px;margin-bottom:8px;line-height:1.2}
.svc-card p{font-size:13.5px;color:var(--muted);line-height:1.5;flex:1}
.svc-card .arr{margin-top:14px;font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--brand);transition:.25s}
.svc-card:hover .arr{transform:translateX(4px)}

/* Content blocks */
.prose{max-width:780px}
.prose h2{font-family:'Outfit',sans-serif;font-weight:700;font-size:30px;margin:48px 0 14px;letter-spacing:-.02em}
.prose h3{font-family:'Outfit',sans-serif;font-weight:700;font-size:22px;margin:36px 0 10px;letter-spacing:-.015em}
.prose p{color:var(--muted);font-size:16px;line-height:1.75;margin-bottom:16px}
.prose p strong{color:var(--text);font-weight:600}
.prose ul,.prose ol{margin:0 0 16px 22px;color:var(--muted)}
.prose ul li,.prose ol li{margin-bottom:6px;line-height:1.6}

/* FAQ — improved typography + breathing room + better contrast */
.faq-list{display:flex;flex-direction:column;gap:12px;max-width:880px;margin:0 auto}
.faq-item{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:border-color .2s, box-shadow .2s, background .2s}
.faq-item:hover{border-color:rgba(215,31,54,.25);background:rgba(255,255,255,.015)}
.faq-item[open]{border-color:var(--brand);background:rgba(215,31,54,.04);box-shadow:0 0 0 1px var(--brand-glow),0 8px 24px -10px rgba(215,31,54,.18)}
.faq-item summary{padding:22px 26px;cursor:pointer;display:flex;align-items:center;gap:16px;font-family:'Outfit',sans-serif;font-weight:600;font-size:17px;line-height:1.4;list-style:none;color:var(--text)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary span:first-child{flex:1}
.faq-ico{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:transform .25s, background .25s, color .25s;flex-shrink:0}
.faq-item[open] .faq-ico{background:var(--brand);color:#fff;transform:rotate(180deg)}
.faq-a, .faq-item > p{padding:0 26px 24px 26px;color:var(--text);font-size:16px;line-height:1.7;opacity:.92;font-family:'Inter',sans-serif}
.faq-item > p{margin:0;padding-top:0}
.faq-item > p:first-of-type{padding-top:8px}
/* When detail summary is followed by a p directly (my pageLanding pattern), style identically */
.faq-item summary + p{padding:0 26px 24px;color:var(--text);font-size:16px;line-height:1.7;opacity:.92;font-family:'Inter',sans-serif;margin:0}

/* Reviews — pill + grid (matches brand-card) */
.reviews-pill{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border-radius:999px;background:rgba(12,14,22,.55);border:1px solid var(--border-strong);font-size:13px;color:var(--muted);margin-bottom:32px;flex-wrap:wrap}
.reviews-pill .rev-stars{display:inline-flex;gap:1px}
.reviews-pill .rev-stars svg{fill:#FFB800;width:13px;height:13px}
.reviews-pill .rev-rating{color:#FFB800;font-size:15px;font-weight:700;font-family:'Outfit',sans-serif}
.reviews-pill .rev-sep{color:rgba(255,255,255,.18)}
.reviews-pill .rev-link{margin-left:6px;padding-left:12px;border-left:1px solid var(--border);font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:var(--brand)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.testi{position:relative;padding:28px;border-radius:16px;background:var(--card);border:1px solid var(--border);overflow:hidden;transition:.3s var(--ease)}
.testi::before{content:'';position:absolute;left:0;top:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand),transparent)}
.testi:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:0 24px 60px -30px var(--brand-glow)}
.testi .src{position:absolute;right:18px;top:18px;font-family:'JetBrains Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.2em;color:var(--label);background:rgba(255,255,255,.03);padding:4px 8px;border-radius:999px;border:1px solid var(--border)}
.testi .stars{display:flex;gap:2px;margin-bottom:12px}
.testi .stars svg{fill:#FFB800}
.testi q{display:block;font-family:'Outfit',sans-serif;font-weight:500;font-size:16px;line-height:1.5;letter-spacing:-.005em;color:var(--text);margin-bottom:18px;quotes:"" ""}
.testi .who{display:flex;align-items:center;gap:12px;padding-top:14px;border-top:1px solid var(--border)}
.testi .avatar{width:40px;height:40px;border-radius:50%;background:var(--brand-dim);color:var(--brand);display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:700;font-size:13px}
.testi .who b{display:block;font-size:14px}
.testi .who span{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--label)}
.testi-skel{background:linear-gradient(110deg,var(--card) 8%,var(--card-hover) 18%,var(--card) 33%);background-size:200% 100%;animation:shimmer 1.6s linear infinite;height:200px;border-radius:16px;border:1px solid var(--border)}
@keyframes shimmer{to{background-position:-200% 0}}

/* Region spotlight (reused from brand-card) */
.region-spot{position:relative;padding:36px;border-radius:20px;overflow:hidden;background:linear-gradient(140deg,var(--card) 0%,var(--bg) 100%);border:1px solid var(--border-strong);display:grid;grid-template-columns:1.1fr .9fr;gap:36px}
.region-spot::before{content:'';position:absolute;right:-100px;top:-100px;width:380px;height:380px;background:radial-gradient(circle,var(--brand-glow),transparent 60%);filter:blur(40px);pointer-events:none}
.region-spot .body{position:relative}
.region-spot h3{font-family:'Outfit',sans-serif;font-weight:800;font-size:28px;line-height:1.05;letter-spacing:-.025em;margin-bottom:14px}
.region-spot h3 .hl{color:var(--brand)}
.region-spot .lead{color:var(--muted);font-size:15px;line-height:1.6;margin-bottom:22px}
.region-spot .facts{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.region-spot .fact{padding:16px;border-radius:12px;background:rgba(255,255,255,.025);border:1px solid var(--border)}
.region-spot .fact .lab{font-family:'JetBrains Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.18em;color:var(--label);margin-bottom:8px}
.region-spot .fact .val{font-family:'Outfit',sans-serif;font-weight:700;font-size:18px;color:var(--text)}
.region-spot .fact .val .accent{color:var(--brand)}
.region-spot .visual{position:relative;border-radius:14px;background:rgba(255,255,255,.02);border:1px solid var(--border);padding:24px}
.region-spot .visual h4{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.2em;color:var(--brand);margin-bottom:14px}
.region-spot .roof-bar{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.region-spot .roof-bar .rb-head{display:flex;justify-content:space-between;font-size:12px}
.region-spot .roof-bar .rb-name{font-family:'Outfit',sans-serif;font-weight:600}
.region-spot .roof-bar .rb-val{font-family:'JetBrains Mono',monospace;color:var(--brand);font-weight:600}
.region-spot .roof-bar .rb-track{height:6px;background:var(--bg);border-radius:3px;overflow:hidden}
.region-spot .roof-bar .rb-fill{height:100%;background:var(--brand);border-radius:3px;box-shadow:0 0 8px var(--brand-glow)}

/* Neighbourhoods chips */
.nbh{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 0}
.nbh span{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.16em;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.04);color:var(--muted);border:1px solid var(--border)}

/* CTA banner */
.cta{position:relative;padding:48px;border-radius:24px;overflow:hidden;background:radial-gradient(circle at 18% 10%,var(--brand-dim),transparent 50%),radial-gradient(circle at 85% 85%,var(--brand-glow),transparent 55%),linear-gradient(135deg,var(--card) 0%,var(--bg) 100%);border:1px solid var(--border-strong)}
.cta-inner{position:relative;display:grid;grid-template-columns:1.4fr 1fr;gap:36px;align-items:center}
.cta .lab{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.22em;color:var(--brand);margin-bottom:12px;display:inline-flex;align-items:center;gap:10px}
.cta .lab::before{content:'';width:24px;height:1px;background:currentColor}
.cta h3{font-family:'Outfit',sans-serif;font-weight:800;font-size:36px;line-height:1.05;letter-spacing:-.025em;margin-bottom:12px}
.cta h3 .hl{color:var(--brand)}
.cta p{color:var(--muted);font-size:15px;line-height:1.6;max-width:480px;margin-bottom:22px}
.cta-actions{display:flex;gap:10px;flex-wrap:wrap}
.cta-side{padding:22px;border-radius:14px;background:rgba(12,14,22,.5);border:1px solid var(--border-strong);backdrop-filter:blur(8px)}
.cta-side .row{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--border)}
.cta-side .row:last-child{border-bottom:0}
.cta-side .ic{width:34px;height:34px;flex:none;border-radius:10px;background:var(--brand-dim);color:var(--brand);display:flex;align-items:center;justify-content:center}
.cta-side .l{font-family:'JetBrains Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.18em;color:var(--label);display:block;margin-bottom:2px}
.cta-side .v{font-family:'Outfit',sans-serif;font-weight:600;font-size:14px}

/* === SOURCES / REFERENCES === */
.sources-list{display:grid;grid-template-columns:1fr;gap:8px}
.src-row{display:grid;grid-template-columns:32px 1fr auto;gap:14px;align-items:center;padding:14px 18px;border-radius:12px;background:var(--card);border:1px solid var(--border);font-size:13px;transition:background .15s,border-color .15s}
.src-row:hover{background:var(--card-hover);border-color:var(--brand)}
.src-row .num{font-family:'JetBrains Mono',monospace;font-weight:700;color:var(--brand);font-size:11px}
.src-row .body b{display:block;font-family:'Outfit',sans-serif;font-weight:600;font-size:14px;margin-bottom:2px;color:var(--text)}
.src-row .body span{color:var(--muted);font-size:12.5px;line-height:1.45}
.src-row .out{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:var(--brand);white-space:nowrap}

/* === LOCATION CARDS (homepage + regio sections) === */
.location-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.loc-card{position:relative;padding:22px;border-radius:14px;background:var(--card);border:1px solid var(--border);transition:transform .35s var(--ease),border-color .25s,background .25s;display:flex;flex-direction:column;gap:6px;overflow:hidden}
.loc-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brand);opacity:0;transition:opacity .25s}
.loc-card:hover{transform:translateY(-3px);border-color:var(--brand);background:var(--card-hover)}
.loc-card:hover::before{opacity:1}
.loc-card .meta{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--label)}
.loc-card .name{font-family:'Outfit',sans-serif;font-weight:700;font-size:16px}
.loc-card .arr{color:var(--brand);font-size:12px;margin-top:8px;opacity:0;transform:translateX(-4px);transition:.25s var(--ease)}
.loc-card:hover .arr{opacity:1;transform:translateX(0)}

/* === COST FACTORS (homepage component 23) === */
.cost-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cost-card{position:relative;padding:22px;border-radius:14px;background:var(--card);border:1px solid var(--border);transition:.25s var(--ease)}
.cost-card:hover{border-color:var(--brand);transform:translateY(-2px)}
.cost-card .ic{width:38px;height:38px;border-radius:10px;background:var(--brand-dim);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.cost-card h4{font-family:'Outfit',sans-serif;font-weight:700;font-size:15px;margin-bottom:6px}
.cost-card p{font-size:12.5px;color:var(--muted);line-height:1.5;margin-bottom:10px}
.cost-card .impact{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:rgba(255,255,255,.04);font-family:'JetBrains Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.16em;color:var(--label)}
.cost-card .impact .dot{width:6px;height:6px;border-radius:50%}
.cost-card .impact.high .dot{background:#D71F36}
.cost-card .impact.med .dot{background:#F9C22F}
.cost-card .impact.low .dot{background:#85BA3F}

/* === COMPARISON TABLE === */
.compare{border:1px solid var(--border-strong);border-radius:16px;overflow:hidden;background:var(--card)}
.compare table{width:100%;border-collapse:collapse;font-size:13.5px}
.compare th,.compare td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border);vertical-align:top}
.compare thead th{background:rgba(255,255,255,.025);font-family:'JetBrains Mono',monospace;font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--label)}
.compare thead th.featured{color:var(--brand)}
.compare thead th.featured::after{content:'★ AANBEVOLEN';display:block;font-size:8px;margin-top:4px;opacity:.7}
.compare tbody th{font-family:'Outfit',sans-serif;font-weight:600;color:var(--text);width:200px;font-size:13.5px;text-transform:none;letter-spacing:0}
.compare td{color:var(--muted)}
.compare td.col-featured{background:var(--brand-dim);color:var(--text);border-left:1px solid var(--brand);border-right:1px solid var(--brand)}
.compare tr:last-child td,.compare tr:last-child th{border-bottom:0}
.compare .pill{display:inline-flex;padding:2px 8px;border-radius:999px;font-family:'JetBrains Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.16em}
.compare .pill-good{background:rgba(133,186,63,.15);color:#85BA3F}
.compare .pill-mid{background:rgba(249,194,47,.15);color:#F9C22F}
.compare .pill-low{background:rgba(215,31,54,.15);color:#D71F36}

/* === INTERACTIVE CHECKLIST === */
.check-card{padding:32px;border-radius:18px;background:linear-gradient(160deg,var(--card),var(--bg));border:1px solid var(--border-strong)}
.check-q{display:flex;align-items:center;gap:14px;padding:16px 18px;margin-bottom:8px;border-radius:10px;background:var(--bg);border:1px solid var(--border);cursor:pointer;user-select:none;transition:.2s}
.check-q:hover{border-color:var(--brand)}
.check-q input{display:none}
.check-q .box{width:22px;height:22px;flex:none;border-radius:6px;border:2px solid var(--border-strong);background:rgba(255,255,255,.02);display:flex;align-items:center;justify-content:center;color:transparent;transition:.15s}
.check-q input:checked ~ .box{background:var(--brand);border-color:var(--brand);color:#fff}
.check-q input:checked ~ .box svg{display:block}
.check-q .box svg{display:none}
.check-q .qtxt{font-size:14.5px;line-height:1.4}
.check-q input:checked ~ .qtxt{color:var(--text)}
.check-result{margin-top:20px;padding:18px 22px;border-radius:12px;background:var(--brand-dim);border:1px solid var(--brand);display:flex;align-items:center;gap:14px}
.check-result .score{font-family:'Outfit',sans-serif;font-weight:800;font-size:32px;color:var(--brand);line-height:1}
.check-result .smal{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--label)}
.check-result .verdict{font-size:14px;line-height:1.4}

/* === EXPERT QUOTE === */
.expert{position:relative;padding:40px 48px;border-radius:22px;overflow:hidden;background:radial-gradient(circle at 0% 100%,var(--brand-dim),transparent 50%),var(--card);border:1px solid var(--border-strong);display:grid;grid-template-columns:140px 1fr;gap:32px;align-items:center}
.expert::before{content:'"';position:absolute;top:-30px;right:24px;font-family:'Outfit',serif;font-size:220px;line-height:1;color:var(--brand);opacity:.12}
.expert-photo{width:140px;height:140px;border-radius:50%;overflow:hidden;background:var(--brand-dim);border:3px solid var(--brand);display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:800;color:var(--brand);font-size:48px;box-shadow:0 14px 40px var(--brand-glow)}
.expert q{display:block;font-family:'Outfit',sans-serif;font-weight:600;font-size:22px;line-height:1.4;letter-spacing:-.015em;color:var(--text);margin-bottom:18px;quotes:"" ""}
.expert .by{display:flex;align-items:center;gap:12px;padding-top:14px;border-top:1px solid var(--border)}
.expert .by .name{font-family:'Outfit',sans-serif;font-weight:700;font-size:15px}
.expert .by .role{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--label)}
.expert .creds{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.expert .creds span{font-family:'JetBrains Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.16em;padding:3px 8px;border-radius:999px;background:rgba(255,255,255,.04);color:var(--label);border:1px solid var(--border)}
.cost-note{margin-top:22px;padding:18px 22px;border-radius:12px;background:linear-gradient(135deg,var(--brand-dim),transparent);border-left:3px solid var(--brand);font-size:13.5px;color:var(--text);line-height:1.6}
.cost-note b{color:var(--brand);font-family:'Outfit',sans-serif;font-weight:700}

@media (max-width:1024px){
  .location-grid,.cost-grid{grid-template-columns:repeat(3,1fr)}
  .compare table{font-size:12px}
  .compare th,.compare td{padding:10px 12px}
  .expert{grid-template-columns:1fr;padding:32px;text-align:left}
  .expert-photo{margin:0 0 12px}
}
@media (max-width:640px){
  .location-grid,.cost-grid{grid-template-columns:repeat(2,1fr)}
  .compare{overflow-x:auto}
  .compare table{min-width:560px}
}

/* Internal-link cluster (siblings) */
.cluster{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:14px}
.cluster a{padding:14px 16px;border-radius:10px;background:var(--card);border:1px solid var(--border);display:flex;flex-direction:column;gap:4px;transition:.2s}
.cluster a:hover{border-color:var(--brand);background:var(--card-hover);transform:translateY(-2px)}
.cluster .meta{font-family:'JetBrains Mono',monospace;font-size:9px;text-transform:uppercase;letter-spacing:.18em;color:var(--label)}
.cluster .name{font-family:'Outfit',sans-serif;font-weight:700;font-size:14px}

/* === FOOTER — matches homepage exactly (SEO-rich) === */
.foot{position:relative;padding:90px 40px 32px;margin-top:80px;background:linear-gradient(180deg,var(--bg) 0%,#070A13 100%);border-top:1px solid var(--border);color:var(--muted);overflow:hidden}
.foot::before{content:'';position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,var(--brand),transparent);opacity:.35}
.foot::after{content:'';position:absolute;bottom:-280px;left:50%;transform:translateX(-50%);width:900px;height:500px;background:radial-gradient(ellipse,var(--brand-dim),transparent 60%);pointer-events:none;opacity:.5}
.foot-top{position:relative;max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:56px;padding-bottom:56px;border-bottom:1px solid var(--border)}
.foot-brand{max-width:340px}
.foot-logo{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.foot-logo img{filter:drop-shadow(0 4px 12px rgba(30,153,238,.2))}
.foot-logo-name{font-family:'Outfit',sans-serif;font-weight:800;font-size:24px;color:var(--text);letter-spacing:-.02em;line-height:1}
.foot-logo-name span{color:var(--brand)}
.foot-logo-sub{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--label);letter-spacing:.12em;text-transform:uppercase;margin-top:4px}
.foot-tag{font-size:14px;line-height:1.65;color:var(--muted);margin-bottom:22px}
.foot-trust{display:flex;flex-wrap:wrap;gap:8px}
.foot-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:30px;background:var(--card);border:1px solid var(--border);font-size:11px;font-family:'JetBrains Mono',monospace;letter-spacing:.08em;text-transform:uppercase;color:var(--text)}
.foot-chip svg{color:var(--brand)}
.foot-h{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--brand);margin-bottom:22px;display:flex;align-items:center;gap:10px}
.foot-h::after{content:'';flex:1;height:1px;background:var(--border)}
.foot-list,.foot-contact,.foot-cities{list-style:none;padding:0;margin:0}
.foot-list li{margin-bottom:12px}
.foot-list a{display:inline-flex;align-items:center;gap:10px;font-size:14px;color:var(--muted);transition:color .25s var(--ease),transform .25s var(--ease);text-decoration:none}
.foot-list a em{font-style:normal;font-size:11px;color:var(--label);font-family:'JetBrains Mono',monospace;letter-spacing:.08em}
.foot-list a:hover{color:var(--text);transform:translateX(3px)}
.foot-dot{width:6px;height:6px;border-radius:50%;display:inline-block;box-shadow:0 0 10px currentColor;flex-shrink:0}
.foot-contact li{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px;padding-bottom:16px;border-bottom:1px dashed var(--border)}
.foot-contact li:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}
.foot-contact li > svg{color:var(--brand);margin-top:4px;flex-shrink:0}
.foot-contact strong{display:block;font-family:'Outfit',sans-serif;font-weight:600;font-size:14px;color:var(--text);margin-bottom:2px}
.foot-contact span{display:block;font-size:12px;color:var(--label)}
.foot-contact a{text-decoration:none}
.foot-contact a:hover strong{color:var(--brand)}
.foot-cities{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:22px}
.foot-cities li{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.foot-cities li::before{content:'';width:3px;height:3px;border-radius:50%;background:var(--brand);opacity:.6}
.foot-cities li small{font-size:9px;font-family:'JetBrains Mono',monospace;padding:2px 5px;border:1px solid var(--border);border-radius:4px;color:var(--label);letter-spacing:.1em}
.foot-cities a{color:inherit;text-decoration:none;transition:color .2s}
.foot-cities a:hover{color:var(--brand)}
.foot-cta{display:inline-flex;align-items:center;gap:8px;padding:11px 16px;border-radius:12px;background:var(--brand-dim);border:1px solid var(--brand);color:var(--brand);font-size:13px;font-weight:600;transition:all .3s var(--ease);text-decoration:none}
.foot-cta:hover{background:var(--brand);color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px var(--brand-glow)}
.foot-cta:hover svg{transform:translateX(3px)}
.foot-cta svg{transition:transform .3s var(--ease)}
aside.foot-seo{display:block;max-width:1240px;margin:0 auto;padding:32px 32px 48px;background:rgba(0,0,0,.18);border-top:1px solid var(--border)}
.foot-seo-inner{display:flex;flex-direction:column;gap:18px}
@media (max-width:768px){aside.foot-seo{padding:24px 16px 36px}}
.foot-seo-legacy{max-width:1240px;margin:32px auto 0;padding:24px 0 0;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:18px}
/* details-row collapsed by default — Mr R msg #344 (SEO veilig, Google leest <details> volledig) */
details.foot-seo-row{display:block;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.02);overflow:hidden;transition:.25s var(--ease)}
details.foot-seo-row[open]{border-color:var(--border-strong);background:rgba(255,255,255,.04)}
details.foot-seo-row summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px;padding:14px 18px;-webkit-tap-highlight-color:transparent}
details.foot-seo-row summary::-webkit-details-marker{display:none}
details.foot-seo-row summary::after{content:'';margin-left:auto;width:8px;height:8px;border-right:1.5px solid var(--muted);border-bottom:1.5px solid var(--muted);transform:rotate(45deg) translate(-2px,-2px);transition:transform .25s var(--ease)}
details.foot-seo-row[open] summary::after{transform:rotate(-135deg) translate(-2px,-2px)}
details.foot-seo-row .foot-seo-links{padding:0 18px 16px}
.foot-seo-row{display:grid;grid-template-columns:200px 1fr;gap:18px;align-items:start}
.foot-seo-h{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--text);font-weight:700;display:flex;align-items:center;gap:10px;padding-top:6px}
.foot-seo-dot{width:8px;height:8px;border-radius:50%;flex:none;box-shadow:0 0 0 2px rgba(255,255,255,.04)}
.foot-seo-links{display:flex;flex-wrap:wrap;gap:6px}
.foot-seo-links a{display:inline-flex;align-items:center;padding:6px 11px;border-radius:8px;background:rgba(255,255,255,.03);border:1px solid var(--border);color:var(--muted);font-size:12.5px;text-decoration:none;transition:.2s var(--ease);white-space:nowrap}
.foot-seo-links a:hover{background:var(--brand-dim);border-color:var(--brand);color:var(--brand);transform:translateY(-1px)}
@media (max-width:768px){
  .foot-seo-row{grid-template-columns:1fr;gap:8px}
  .foot-seo-h{padding-top:4px;font-size:10.5px}
  .foot-seo-links a{font-size:11.5px;padding:5px 9px}
}
.foot-bottom{position:relative;max-width:1240px;margin:0 auto;padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.foot-legal{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;color:var(--label)}
.foot-legal strong{color:var(--text);font-weight:600}
.foot-legal a{color:var(--label);transition:color .2s var(--ease);text-decoration:none}
.foot-legal a:hover{color:var(--brand)}
.foot-sep{color:var(--border-strong)}
.foot-version{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--label);letter-spacing:.2em;text-transform:uppercase;padding:5px 10px;border:1px solid var(--border);border-radius:6px}
@media (max-width:960px){
  .foot{padding:70px 24px 28px}
  .foot-top{grid-template-columns:1fr 1fr;gap:40px;padding-bottom:40px}
  .foot-brand{max-width:none;grid-column:1 / -1}
  .foot-bottom{flex-direction:column;align-items:flex-start}
}
@media (max-width:560px){
  .foot-top{grid-template-columns:1fr;gap:36px}
  .foot-cities{grid-template-columns:1fr 1fr 1fr}
}

/* WhatsApp float */
.wa-float{position:fixed;right:24px;bottom:24px;width:60px;height:60px;border-radius:50%;background:var(--wa);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 40px rgba(37,211,102,.45);z-index:80;animation:waPulse 2.6s ease-out infinite}
.wa-float:hover{transform:scale(1.08) translateY(-2px)}
@keyframes waPulse{0%{box-shadow:0 14px 40px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,.4)}70%{box-shadow:0 14px 40px rgba(37,211,102,.45),0 0 0 18px rgba(37,211,102,0)}100%{box-shadow:0 14px 40px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,0)}}

/* Responsive */
@media (max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:32px}
  .stats,.svc-grid{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:1fr}
  .region-spot{grid-template-columns:1fr}
  .cta-inner{grid-template-columns:1fr;gap:28px}
  .cta{padding:32px}
  .foot-inner{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .cluster{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  .hero{padding:60px 20px 48px}
  .sec{padding:60px 20px}
  .stats,.svc-grid{grid-template-columns:1fr}
  .cluster{grid-template-columns:1fr}
  .foot-inner{grid-template-columns:1fr}
  .bc{padding:14px 20px 0}
  .nav-inner{padding:12px 20px}
}

/* ═══════════════════════════════════════════════════════════════════════════
   TBGS-blue brand binding (master/non-specialism pages — e.g. /offerte, /contact)
   ═══════════════════════════════════════════════════════════════════════════ */
[data-brand="tbgs"]{--brand:#1E99EE;--brand-dim:rgba(30,153,238,.12);--brand-glow:rgba(30,153,238,.35)}

/* ═══════════════════════════════════════════════════════════════════════════
   OFFERTE FORM — conversion-grade, dark glassmorphism, TBGS-blue accent
   ═══════════════════════════════════════════════════════════════════════════ */
.of-shell{max-width:920px;margin:0 auto;display:grid;grid-template-columns:1fr 280px;gap:32px;align-items:start}
@media(max-width:880px){.of-shell{grid-template-columns:1fr;gap:24px}}
.of-form{background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.01));border:1px solid var(--border-strong);border-radius:24px;padding:36px 32px;display:flex;flex-direction:column;gap:18px;box-shadow:0 30px 80px -40px var(--brand-glow)}
@media(max-width:640px){.of-form{padding:24px 20px;border-radius:18px;gap:14px}}
.of-row{display:grid;gap:14px}
.of-row-2{grid-template-columns:1fr 1fr}
.of-row-3{grid-template-columns:1fr 2fr}
@media(max-width:640px){.of-row-2,.of-row-3{grid-template-columns:1fr}}
.of-field{display:flex;flex-direction:column;gap:7px;position:relative}
.of-field>span{font-family:'Inter',sans-serif;font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.02em;display:flex;align-items:center;gap:6px}
.of-field>span em{color:var(--brand);font-style:normal}
.of-field>span .of-opt{color:var(--label);font-weight:500;font-size:11px;text-transform:none;letter-spacing:0}
.of-field input[type=text],.of-field input[type=email],.of-field input[type=tel],.of-field select,.of-field textarea{
  /* font-size MUST be >=16px or iOS Safari auto-zooms the page on focus */
  font:500 16px 'Inter',sans-serif;color:var(--text);background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:14px 16px;
  width:100%;outline:none;transition:border-color .25s,background .25s,box-shadow .25s;
  -webkit-appearance:none;appearance:none;
}
.of-field input::placeholder,.of-field textarea::placeholder{color:rgba(168,175,195,.55)}
.of-field input:focus,.of-field select:focus,.of-field textarea:focus{
  border-color:var(--brand);background:rgba(30,153,238,.06);box-shadow:0 0 0 3px var(--brand-dim);
}
.of-field textarea{resize:vertical;min-height:120px;line-height:1.5;font-family:'Inter',sans-serif}
.of-field select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%23A8AFC3' stroke-width='2'><path d='M1 1l5 5 5-5'/></svg>");background-repeat:no-repeat;background-position:right 18px center;padding-right:42px;cursor:pointer}
.of-spoed{justify-content:flex-end;cursor:pointer}
.of-spoed input{position:absolute;opacity:0;pointer-events:none}
.of-spoed-box{display:flex;align-items:center;gap:14px;padding:14px 18px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:12px;transition:all .25s;font-size:13px;color:var(--text)}
.of-spoed-box strong{display:block;font-weight:700;color:var(--text);font-size:14px}
.of-spoed-box em{display:block;font-style:normal;color:var(--muted);font-size:11px;margin-top:2px}
.of-spoed-dot{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.3);flex-shrink:0;transition:all .25s;position:relative}
.of-spoed input:checked + .of-spoed-box{background:rgba(248,113,113,.08);border-color:rgba(248,113,113,.45)}
.of-spoed input:checked + .of-spoed-box .of-spoed-dot{background:#F87171;border-color:#F87171;box-shadow:0 0 14px rgba(248,113,113,.6)}
.of-spoed input:checked + .of-spoed-box .of-spoed-dot::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;border-radius:50%;background:#fff}
.of-files-drop{display:block;cursor:pointer;border:1.5px dashed rgba(255,255,255,.18);border-radius:14px;padding:24px;text-align:center;transition:all .25s;background:rgba(255,255,255,.02);position:relative}
.of-files-drop:hover{border-color:var(--brand);background:var(--brand-dim)}
.of-files-drop.dragover{border-color:var(--brand);background:var(--brand-dim);box-shadow:0 0 0 3px var(--brand-dim)}
.of-files-drop input[type=file]{position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.of-files-cta{display:inline-flex;align-items:center;gap:10px;color:var(--muted);font-weight:600;font-size:14px}
.of-files-list{margin-top:14px;display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.of-files-list:empty{display:none}
.of-thumb{position:relative;width:84px;height:84px;border-radius:12px;overflow:hidden;background:#1a1a1a;border:1px solid rgba(255,255,255,.08)}
.of-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.of-thumb-x{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.7);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;cursor:pointer;border:0;font-family:inherit;transition:background .2s}
.of-thumb-x:hover{background:#F87171}
.of-actions{display:flex;flex-direction:column;align-items:flex-start;gap:14px;margin-top:8px}
@media(max-width:640px){.of-actions{align-items:stretch}}
.of-submit{padding:16px 28px;font-size:15px;min-width:240px;justify-content:center}
.of-submit:disabled{opacity:.6;cursor:wait}
.of-trust{font-size:12px;color:var(--label);margin:0;display:flex;align-items:center;gap:8px}
.of-trust svg{flex-shrink:0;color:var(--brand)}
.of-error{display:none;padding:14px 18px;background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.35);border-radius:12px;color:#FCA5A5;font-size:14px}
.of-error.show{display:block}
.of-success{max-width:580px;margin:0 auto;text-align:center;padding:48px 32px;background:linear-gradient(135deg,var(--brand-dim),rgba(30,46,114,.04));border:1px solid var(--brand);border-radius:20px;box-shadow:0 30px 80px -40px var(--brand-glow)}
.of-success-ico{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#1E2E72);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 12px 32px var(--brand-glow)}
.of-success h3{color:var(--text);font-family:'Outfit',sans-serif;font-size:24px;font-weight:700;margin:0 0 10px}
.of-success p{color:var(--muted);font-size:15px;margin:0 0 24px;line-height:1.55}
.of-success-cta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
/* Trust rail (sidebar on desktop, stacked on mobile) */
.of-rail{display:flex;flex-direction:column;gap:14px;position:sticky;top:100px}
@media(max-width:880px){.of-rail{position:static}}
.of-rail-card{padding:20px;background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:16px}
.of-rail-card h4{font-family:'Outfit',sans-serif;font-weight:700;font-size:15px;margin:0 0 4px;color:var(--text)}
.of-rail-card p{font-size:13px;color:var(--muted);margin:0;line-height:1.5}
.of-rail-card .lab{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--brand);margin:0 0 8px;display:flex;align-items:center;gap:8px}
.of-rail-card .lab svg{color:var(--brand)}
.of-rail-list{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.of-rail-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text)}
.of-rail-item svg{color:var(--brand);flex-shrink:0}

/* Trust strip — under hero */
.trust-strip{max-width:1240px;margin:-16px auto 0;padding:0 32px;display:flex;flex-wrap:wrap;justify-content:center;gap:8px 18px;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em}
.trust-strip span{display:inline-flex;align-items:center;gap:8px}
.trust-strip span b{color:var(--text);font-family:'Outfit',sans-serif;font-size:13px;font-weight:700;letter-spacing:0;text-transform:none}
.trust-strip svg{color:var(--brand)}
.trust-strip .sep{width:4px;height:4px;border-radius:50%;background:var(--border-strong);align-self:center}

/* Process steps */
.proc-steps{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:18px;counter-reset:proc}
@media(max-width:880px){.proc-steps{grid-template-columns:1fr;gap:14px}}
.proc-step{position:relative;padding:32px 28px;background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:18px;counter-increment:proc;transition:all .35s var(--ease)}
.proc-step:hover{border-color:var(--brand);background:var(--brand-dim);transform:translateY(-3px)}
.proc-step::before{content:'0' counter(proc);position:absolute;top:18px;right:22px;font-family:'Outfit',sans-serif;font-weight:800;font-size:48px;letter-spacing:-.04em;color:var(--brand);opacity:.18;line-height:1}
.proc-step .ico{width:42px;height:42px;border-radius:12px;background:var(--brand-dim);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.proc-step h3{font-family:'Outfit',sans-serif;font-weight:700;font-size:17px;color:var(--text);margin:0 0 6px;letter-spacing:-.01em}
.proc-step p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.55}

/* ═══════════════════════════════════════════════════════════════════════════
   FLOATING SERVICE MENU (FSM) — replaces wa-float, opens to wide service card
   ═══════════════════════════════════════════════════════════════════════════ */
.fsm{position:fixed;bottom:24px;right:24px;z-index:130;font-family:'Inter',sans-serif}
/* Hide site nav while FSM is open so the panel has full vertical breathing room */
body:has(.fsm.open) .th{opacity:0;pointer-events:none;transition:opacity .25s ease}
@media(max-width:640px){.fsm{bottom:16px;right:16px}}
/* Full-viewport dim + blur backdrop (subtle, click-to-close, scroll-locks page) */
.fsm-backdrop{position:fixed;inset:0;background:rgba(5,8,16,0);backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0);transition:background .35s var(--ease),backdrop-filter .35s var(--ease),-webkit-backdrop-filter .35s var(--ease);pointer-events:none;z-index:1}
.fsm.open .fsm-backdrop{background:rgba(5,8,16,.6);backdrop-filter:blur(8px) saturate(1.05);-webkit-backdrop-filter:blur(8px) saturate(1.05);pointer-events:auto;cursor:pointer}
/* Lock body scroll while FSM panel is open (bulletproof on iOS — top:-scrollY preserves visual position) */
body.fsm-active{position:fixed;left:0;right:0;width:100%;overflow:hidden}
html.fsm-active{overflow:hidden}
.fsm-trigger{position:relative;z-index:3;width:60px;height:60px;border-radius:50%;background:var(--brand);color:#fff;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 36px var(--brand-glow),0 0 0 1px rgba(255,255,255,.1) inset;transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.fsm-trigger::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--brand);opacity:.4;animation:fsm-pulse 2.4s ease-out infinite}
.fsm-trigger:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 16px 44px var(--brand-glow)}
.fsm-trigger svg{width:26px;height:26px;transition:width .25s var(--ease),height .25s var(--ease)}
.fsm-trigger .fsm-ico-close{display:none}
/* When panel open, the trigger button hides — close-X lives inside panel header instead */
.fsm.open .fsm-trigger{opacity:0;pointer-events:none;transform:scale(.6);transition:opacity .25s,transform .25s}
.fsm.open .fsm-trigger::after{display:none}

/* Close X inside panel header (top right) */
.fsm-head-close{
  position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:12px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
  color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  padding:0;transition:all .25s var(--ease);z-index:5;
}
.fsm-head-close:hover{background:rgba(255,255,255,.22);transform:rotate(90deg) scale(1.05)}
.fsm-head-close svg{display:block}
@keyframes fsm-pulse{0%{opacity:.5;transform:scale(1)}80%{opacity:0;transform:scale(1.6)}100%{opacity:0}}

/* Tooltip badge */
.fsm-badge{position:absolute;right:74px;top:50%;transform:translate(8px,-50%);background:#0F1424;color:var(--text);font-size:12px;font-weight:600;padding:9px 14px;border-radius:12px;border:1px solid var(--border-strong);white-space:nowrap;opacity:0;pointer-events:none;transition:all .35s var(--ease);box-shadow:0 8px 22px rgba(0,0,0,.4)}
.fsm-badge::after{content:'';position:absolute;left:100%;top:50%;transform:translateY(-50%);border:6px solid transparent;border-left-color:#0F1424}
.fsm:not(.open) .fsm-trigger:hover ~ .fsm-badge,.fsm:not(.open) .fsm-badge.show{opacity:1;transform:translate(0,-50%)}
@media(max-width:640px){.fsm-badge{display:none}}

/* Panel — expanded card */
/* Panel anchors to viewport bottom-right and ENDS where the trigger sits (no gap; trigger overlays the panel's bottom-right corner) */
.fsm-panel{position:absolute;z-index:2;bottom:0;right:0;width:380px;max-width:calc(100vw - 32px);background:linear-gradient(180deg,#131828 0%,#0F1424 100%);border:1px solid var(--border-strong);border-radius:22px;box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 0 1px var(--brand-dim) inset;padding:0;overflow:hidden;opacity:0;transform:translateY(20px) scale(.96);pointer-events:none;transition:opacity .35s var(--ease),transform .35s var(--ease);transform-origin:bottom right;max-height:calc(100vh - 48px);display:flex;flex-direction:column}
@media(max-width:640px){
  /* trigger stays right-anchored; panel breaks out to full width via fixed positioning */
  .fsm{bottom:16px;right:16px}
  .fsm-panel{position:fixed;left:16px;right:16px;bottom:16px;width:auto;max-height:calc(100vh - 32px);max-height:calc(100dvh - 32px);border-radius:18px}
  .fsm-head{padding:18px 56px 16px 18px}
  .fsm-head h3{font-size:18px}
  .fsm-head p{font-size:12.5px}
  .fsm-head-close{top:12px;right:12px;width:34px;height:34px;border-radius:10px}
  .fsm-body{padding:16px 18px 18px;gap:8px}
  .fsm-foot{padding:12px 18px;font-size:10px;padding-right:18px}
  .fsm-addr-row{gap:10px}
  .fsm-be-chip__opt{padding:5px 10px;gap:5px}
  .fsm-addr{font-size:11.5px}
}
@media(max-width:380px){
  .fsm{bottom:12px;right:12px}
  .fsm-panel{left:12px;right:12px;bottom:12px;max-height:calc(100vh - 24px);max-height:calc(100dvh - 24px)}
  .fsm-head h3{font-size:16px}
  .fsm-trigger{width:54px;height:54px}
}
.fsm.open .fsm-panel{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}

.fsm-head{padding:22px 24px 18px;background:linear-gradient(135deg,var(--brand) 0%,#0A0E1A 100%);color:#fff;position:relative}
.fsm-head .lab{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.18em;opacity:.85;margin-bottom:6px}
.fsm-head h3{font-family:'Outfit',sans-serif;font-weight:800;font-size:20px;margin:0;letter-spacing:-.02em;line-height:1.2}
.fsm-head p{font-size:13px;margin:6px 0 0;opacity:.85;line-height:1.45}

.fsm-body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;flex:1;min-height:0}
.fsm-foot{padding-right:64px}

/* Path buttons (step 1) */
.fsm-path{display:flex;align-items:center;gap:14px;padding:16px 18px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:14px;cursor:pointer;text-decoration:none;color:var(--text);transition:all .25s var(--ease);text-align:left;font-family:inherit;font-size:inherit;width:100%}
.fsm-path:hover{background:var(--brand-dim);border-color:var(--brand);transform:translateX(2px)}
.fsm-path .ico{width:42px;height:42px;border-radius:12px;background:var(--brand-dim);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .25s}
.fsm-path:hover .ico{background:var(--brand);color:#fff}
.fsm-path.fsm-path-wa .ico{background:rgba(37,211,102,.12);color:var(--wa)}
.fsm-path.fsm-path-wa:hover{background:rgba(37,211,102,.08);border-color:var(--wa)}
.fsm-path.fsm-path-wa:hover .ico{background:var(--wa);color:#fff}
.fsm-path .txt{flex:1;min-width:0}
.fsm-path .txt strong{display:block;font-size:14px;font-weight:700;color:var(--text);margin-bottom:2px}
.fsm-path .txt em{display:block;font-style:normal;font-size:12px;color:var(--muted);font-weight:500;line-height:1.4}
.fsm-path .arr{color:var(--label);transition:transform .25s,color .25s;flex-shrink:0}
.fsm-path:hover .arr{color:var(--brand);transform:translateX(3px)}

/* Compact form (step 2) */
.fsm-form{display:none;flex-direction:column;gap:12px}
.fsm.fsm-step-form .fsm-paths{display:none}
.fsm.fsm-step-form .fsm-form{display:flex}
/* font-size 16px MUST stay 16px or iOS Safari zooms in on focus inside the floating panel */
/* font-size:16px !important is critical to prevent iOS Safari from zooming on focus */
.fsm-form input,.fsm-form select,.fsm-form textarea{font-family:'Inter',sans-serif;font-weight:500;font-size:16px !important;line-height:1.4;color:var(--text);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:13px 14px;width:100%;outline:none;-webkit-appearance:none;appearance:none;transition:all .25s;-webkit-text-size-adjust:100%;text-size-adjust:100%}
.fsm-form input::placeholder,.fsm-form textarea::placeholder{color:rgba(168,175,195,.5)}
.fsm-form input:focus,.fsm-form select:focus,.fsm-form textarea:focus{border-color:var(--brand);background:var(--brand-dim);box-shadow:0 0 0 2px var(--brand-dim)}
.fsm-form select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 12 8' fill='none' stroke='%23A8AFC3' stroke-width='2'><path d='M1 1l5 5 5-5'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}
.fsm-form textarea{resize:vertical;min-height:80px}
.fsm-form .row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fsm-form-files{padding:14px;border:1.5px dashed rgba(255,255,255,.18);border-radius:10px;text-align:center;cursor:pointer;transition:all .25s;font-size:12px;color:var(--muted);font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;position:relative}
.fsm-form-files input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.fsm-form-files:hover{border-color:var(--brand);background:var(--brand-dim);color:var(--brand)}
.fsm-form-files.has-files{border-style:solid;border-color:var(--brand);color:var(--brand);background:var(--brand-dim)}
.fsm-back{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--label);cursor:pointer;background:transparent;border:0;font-family:inherit;padding:0;align-self:flex-start;font-weight:600;transition:color .2s}
.fsm-back:hover{color:var(--text)}
.fsm-submit{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--brand);color:#fff;border:0;padding:13px 18px;border-radius:10px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 6px 20px var(--brand-glow);transition:all .25s}
.fsm-submit:hover:not(:disabled){background:#3FAEFF;transform:translateY(-1px);box-shadow:0 10px 28px var(--brand-glow)}
.fsm-submit:disabled{opacity:.6;cursor:wait}
.fsm-err{padding:10px 12px;background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.3);border-radius:8px;color:#FCA5A5;font-size:12px;display:none}
.fsm-err.show{display:block}
/* === Address block: NL/BE chip toggle + fields + helper text === */
.fsm-addr-wrap{display:flex;flex-direction:column;gap:10px}

/* Helper line + BE chip share one row — chip aligns flush right of helper text */
.fsm-addr-row{display:flex;align-items:center;gap:12px;flex-wrap:nowrap;min-width:0;padding:2px 2px}
.fsm-addr{font-size:12px;font-family:'Inter',sans-serif;font-weight:500;color:var(--muted);display:flex;align-items:center;gap:7px;line-height:1.35;flex:1;min-width:0}
.fsm-addr > svg{flex:none}
.fsm-addr.loading{color:var(--muted)}
.fsm-addr.ok{color:var(--brand)}
.fsm-addr.err{color:#FCA5A5}
.fsm-addr.loading::before{content:'';width:10px;height:10px;border-radius:50%;border:2px solid var(--muted);border-top-color:transparent;animation:fsm-spin .7s linear infinite;flex:none}
@keyframes fsm-spin{to{transform:rotate(360deg)}}

/* NL/BE compact toggle — outlined pill split in two halves, both options visible */
.fsm-be-chip{display:inline-flex;align-items:stretch;padding:0;border-radius:999px;background:transparent;border:1.5px solid var(--border-strong);cursor:pointer;user-select:none;flex:0 0 auto;position:relative;overflow:hidden;margin-top:3px;transition:border-color .25s var(--ease)}
.fsm-be-chip:hover{border-color:rgba(255,255,255,.32)}
.fsm-be-chip__opt{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;cursor:pointer;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.16em;line-height:1;color:var(--muted);transition:background .25s var(--ease),color .25s var(--ease),box-shadow .25s var(--ease);position:relative}
.fsm-be-chip__opt:hover:not(:has(input:checked)){color:var(--text);background:rgba(255,255,255,.04)}
.fsm-be-chip__opt input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.fsm-be-chip__opt .fsm-be-flag{flex:none;border-radius:2px;overflow:hidden;border:1px solid rgba(255,255,255,.22);display:block;transition:border-color .25s}
.fsm-be-chip__opt:has(input:checked){background:var(--brand);color:#fff;box-shadow:inset 0 0 0 1px var(--brand),0 4px 12px var(--brand-glow)}
.fsm-be-chip__opt:has(input:checked) .fsm-be-flag{border-color:rgba(255,255,255,.6)}

/* Country swap — toggled via data-country attr on .fsm-addr-wrap */
.fsm-addr-wrap[data-country="BE"] .fsm-nl-fields{display:none}
.fsm-addr-wrap[data-country="BE"] .fsm-be-fields{display:grid !important}
.fsm-be-fields[hidden]{display:none}

/* Success state (step 3) */
.fsm-done{display:none;flex-direction:column;align-items:center;text-align:center;padding:8px 0 4px}
.fsm.fsm-step-done .fsm-paths,.fsm.fsm-step-done .fsm-form{display:none}
.fsm.fsm-step-done .fsm-done{display:flex}
.fsm-done-ico{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#1E2E72);display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:14px;box-shadow:0 10px 28px var(--brand-glow)}
.fsm-done h4{font-family:'Outfit',sans-serif;font-weight:700;font-size:18px;color:var(--text);margin:0 0 6px}
.fsm-done p{font-size:13px;color:var(--muted);margin:0;line-height:1.45}

.fsm-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--label);font-family:'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase}
.fsm-foot a{color:var(--label);text-decoration:none;transition:color .2s}
.fsm-foot a:hover{color:var(--brand)}

/* ═══════════════════════════════════════════════════════════════════════════
   HUB "Over deze dienst" — wide 2-col layout + sticky CTA rail + feature grid
   Wider than .sec-inner default. Higher SEO/CTR/conversion than plain prose.
   ═══════════════════════════════════════════════════════════════════════════ */
.sec-wide{padding:88px 32px}
.sec-inner-wide{max-width:1280px;margin:0 auto}
.sec-head-wide{max-width:780px;margin-bottom:52px}
.sec-head-wide .lead{font-size:17px;color:var(--muted);line-height:1.65;margin-top:14px}

.hub-intro{display:grid;grid-template-columns:1fr 360px;gap:56px;align-items:start;margin-bottom:64px}
@media(max-width:1024px){.hub-intro{grid-template-columns:1fr;gap:36px}}

.hub-intro__body{font-family:'Inter',sans-serif;font-size:16px;line-height:1.75;color:var(--text)}
.hub-intro__body h3{font-family:'Outfit',sans-serif;font-weight:700;font-size:22px;letter-spacing:-.015em;color:var(--text);margin:36px 0 12px;padding-left:14px;border-left:3px solid var(--brand)}
.hub-intro__body h3:first-child{margin-top:0}
.hub-intro__body p{font-size:16px;line-height:1.75;color:rgba(245,246,250,.82);margin-bottom:18px}
.hub-intro__body p:last-child{margin-bottom:0}

.hub-intro__rail{position:sticky;top:96px;display:flex;flex-direction:column;gap:18px}
@media(max-width:1024px){.hub-intro__rail{position:static}}

.hub-intro__card{background:linear-gradient(160deg,var(--card-hover) 0%,var(--card) 100%);border:1px solid var(--border-strong);border-radius:18px;padding:24px;box-shadow:0 24px 60px -28px var(--brand-glow),0 0 0 1px var(--brand-dim) inset;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}
.hub-intro__card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,var(--brand) 50%,transparent 100%);opacity:.6}
.hub-intro__card .lab{font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--brand);display:flex;align-items:center;gap:8px}
.hub-intro__card .lab .dot{width:7px;height:7px;border-radius:50%;background:var(--brand);box-shadow:0 0 10px var(--brand-glow);animation:hubPulse 2.4s ease-in-out infinite}
@keyframes hubPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.3)}}
.hub-intro__card h4{font-family:'Outfit',sans-serif;font-weight:800;font-size:22px;letter-spacing:-.02em;color:var(--text);line-height:1.15}
.hub-intro__card p{font-size:13.5px;line-height:1.55;color:var(--muted);margin:-4px 0 4px}
.hub-intro__btn{width:100%;justify-content:center;padding:13px 18px}
.hub-intro__phone{display:flex;align-items:center;gap:10px;padding:13px 14px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid var(--border);font-family:'Inter',sans-serif;font-size:14px;font-weight:600;color:var(--text);text-decoration:none;transition:all .25s var(--ease);margin-top:2px}
.hub-intro__phone svg{color:var(--brand);flex:none}
.hub-intro__phone span{flex:1}
.hub-intro__phone em{font-style:normal;font-size:11px;color:var(--label);font-weight:500;font-family:'JetBrains Mono',monospace;letter-spacing:.06em}
.hub-intro__phone:hover{background:var(--brand-dim);border-color:var(--brand);transform:translateY(-1px)}

.hub-intro__trust{list-style:none;padding:18px;margin:0;background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:14px;display:flex;flex-direction:column;gap:11px}
.hub-intro__trust li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:rgba(245,246,250,.85);line-height:1.45}
.hub-intro__trust li svg{color:var(--brand);flex:none;margin-top:1px}

/* Feature grid: 4 strong USPs as bottom row */
.hub-features{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding-top:42px;border-top:1px solid var(--border)}
@media(max-width:1024px){.hub-features{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.hub-features{grid-template-columns:1fr}}
.hub-feature{padding:24px;background:var(--card);border:1px solid var(--border);border-radius:16px;transition:all .35s var(--ease);position:relative;overflow:hidden}
.hub-feature::before{content:'';position:absolute;top:0;left:0;width:48px;height:3px;background:var(--brand);border-radius:0 0 3px 0;opacity:.6;transition:opacity .35s,width .35s var(--ease)}
.hub-feature:hover{transform:translateY(-3px);border-color:var(--brand);background:var(--card-hover);box-shadow:0 24px 60px -32px var(--brand-glow)}
.hub-feature:hover::before{opacity:1;width:72px}
.hub-feature__ico{width:42px;height:42px;border-radius:12px;background:var(--brand-dim);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.hub-feature h4{font-family:'Outfit',sans-serif;font-weight:700;font-size:16px;color:var(--text);margin-bottom:6px;letter-spacing:-.01em;line-height:1.25}
.hub-feature p{font-size:13px;line-height:1.55;color:var(--muted)}

@media(max-width:640px){
  .sec-wide{padding:64px 20px}
  .hub-intro{margin-bottom:42px}
  .hub-intro__body h3{font-size:19px;margin:28px 0 10px}
  .hub-intro__card{padding:20px}
  .hub-intro__card h4{font-size:20px}
}

/* ═══════════════════════════════════════════════════════════════════════════
   KENNISBANK INDEX — sexy filterable card grid, mobile-easy scroll
   ═══════════════════════════════════════════════════════════════════════════ */
.kb-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border);align-items:center}
.kb-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;color:var(--muted);background:transparent;border:1.5px solid var(--border-strong);border-radius:999px;cursor:pointer;transition:all .25s var(--ease);white-space:nowrap}
.kb-chip span{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--label);background:rgba(255,255,255,.06);padding:2px 7px;border-radius:999px;min-width:22px;text-align:center;transition:all .25s}
.kb-chip:hover{color:var(--text);border-color:rgba(255,255,255,.32)}
.kb-chip:hover span{background:rgba(255,255,255,.1)}
.kb-chip.is-active{background:var(--brand-dim);color:var(--brand);border-color:var(--brand);box-shadow:0 0 0 1px var(--brand-dim) inset}
.kb-chip.is-active span{background:var(--brand);color:#fff}
.kb-chip[data-brand="tds"].is-active{--brand:var(--tds);--brand-dim:var(--tds-dim);--brand-glow:var(--tds-glow)}
.kb-chip[data-brand="tss"].is-active{--brand:var(--tss);--brand-dim:var(--tss-dim);--brand-glow:var(--tss-glow)}
.kb-chip[data-brand="tos"].is-active{--brand:var(--tos);--brand-dim:var(--tos-dim);--brand-glow:var(--tos-glow)}
.kb-chip[data-brand="tbs"].is-active{--brand:var(--tbs);--brand-dim:var(--tbs-dim);--brand-glow:var(--tbs-glow)}

.kb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:1024px){.kb-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.kb-grid{grid-template-columns:1fr;gap:14px}}

.kb-card{position:relative;display:flex;flex-direction:column;gap:12px;padding:26px 24px 24px;background:var(--card);border:1px solid var(--border);border-radius:18px;text-decoration:none;color:inherit;overflow:hidden;transition:transform .35s var(--ease),border-color .35s var(--ease),background .35s var(--ease),box-shadow .35s var(--ease)}
.kb-card[data-brand="tds"]{--brand:var(--tds);--brand-dim:var(--tds-dim);--brand-glow:var(--tds-glow)}
.kb-card[data-brand="tss"]{--brand:var(--tss);--brand-dim:var(--tss-dim);--brand-glow:var(--tss-glow)}
.kb-card[data-brand="tos"]{--brand:var(--tos);--brand-dim:var(--tos-dim);--brand-glow:var(--tos-glow)}
.kb-card[data-brand="tbs"]{--brand:var(--tbs);--brand-dim:var(--tbs-dim);--brand-glow:var(--tbs-glow)}
/* Brand-color top stripe */
.kb-card__stripe{position:absolute;top:0;left:0;right:0;height:3px;background:var(--brand);box-shadow:0 0 16px var(--brand-glow);opacity:.7;transition:opacity .35s,height .35s var(--ease)}
/* Cursor spotlight (desktop only) */
.kb-card::after{content:'';position:absolute;inset:-1px;border-radius:18px;background:radial-gradient(circle 220px at var(--mx,50%) var(--my,50%),var(--brand-glow),transparent 55%);opacity:0;transition:opacity .25s;pointer-events:none}
.kb-card:hover{transform:translateY(-4px);border-color:var(--brand);background:var(--card-hover);box-shadow:0 28px 70px -34px var(--brand-glow)}
.kb-card:hover::after{opacity:.7}
.kb-card:hover .kb-card__stripe{opacity:1;height:4px}

.kb-card__top{display:flex;align-items:center;justify-content:space-between;gap:10px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;position:relative;z-index:1}
.kb-card__tag{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:var(--brand-dim);color:var(--brand);font-weight:700;letter-spacing:.16em}
.kb-card__time{display:inline-flex;align-items:center;gap:5px;color:var(--label);font-size:10.5px}
.kb-card__time svg{opacity:.7}

.kb-card__title{font-family:'Outfit',sans-serif;font-weight:700;font-size:19px;letter-spacing:-.015em;line-height:1.25;color:var(--text);position:relative;z-index:1}
.kb-card__snippet{font-family:'Inter',sans-serif;font-size:14px;line-height:1.55;color:var(--muted);flex:1;position:relative;z-index:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

.kb-card__cta{display:inline-flex;align-items:center;gap:7px;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);margin-top:4px;padding-top:14px;border-top:1px solid var(--border);transition:gap .25s var(--ease);position:relative;z-index:1}
.kb-card__cta svg{transition:transform .25s var(--ease)}
.kb-card:hover .kb-card__cta{gap:11px}
.kb-card:hover .kb-card__cta svg{transform:translateX(2px)}

@media(max-width:640px){
  .kb-filter{gap:8px;margin-bottom:24px;padding-bottom:18px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-left:-20px;margin-right:-20px;padding-left:20px;padding-right:20px}
  .kb-filter::-webkit-scrollbar{display:none}
  .kb-chip{padding:9px 14px;font-size:12.5px;flex:0 0 auto}
  .kb-card{padding:22px 20px 20px;border-radius:16px}
  .kb-card__title{font-size:17px}
  .kb-card__snippet{font-size:13.5px;-webkit-line-clamp:2}
}
