/* ══════════════════════════════════════════
   SLEUTEL24 — Global Stylesheet
   Eén bestand voor alle publieke pagina's
   ══════════════════════════════════════════ */

:root{
  --oranje:#F48432;--oranje2:#d9721e;
  --ink:#141414;--muted:#555;
  --cream:#f4f2ee;--cream2:#eae7e1;
  --rand:#dedad3;--wit:#fff;
  --groen:#22c55e;
  --geel:#f0a500;
}

/* ── RESET ── */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--cream);color:#1c1c1c;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:1280px;margin:0 auto;padding:0 28px}

/* ── FOCUS VISIBLE (accessibility) ── */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.btn-groot:focus-visible,.btn-wa:focus-visible,.btn-bel:focus-visible{outline:2px solid var(--oranje);outline-offset:2px}

/* ── RIBBON ── */
.ribbon{background:var(--oranje);padding:10px 20px;display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;text-align:center}
.ribbon-groen{display:inline-flex;align-items:center;gap:7px;background:#22c55e;color:#fff;font-size:13px;font-weight:700;padding:4px 14px;border-radius:20px}
.ribbon-tekst{font-size:13px;font-weight:600;color:#fff}
.ribbon-tekst strong{font-weight:800}
.ribbon-tel{font-size:13px;font-weight:800;color:#fff;background:rgba(0,0,0,.18);padding:4px 14px;border-radius:20px;white-space:nowrap}
.ribbon-dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:knipoog 1.4s infinite;flex-shrink:0}
@keyframes knipoog{0%,100%{opacity:1}50%{opacity:.2}}

/* ── CHIP (label badge) ── */
.chip{display:inline-block;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:4px 14px;border-radius:20px}
.chip.rood{background:var(--oranje);color:#fff}

/* ── HEADER ── */
header{background:var(--wit);border-bottom:1px solid var(--rand);position:sticky;top:0;z-index:200}
.header-inner{max-width:1280px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:70px;gap:16px}

/* ── LOGO (afbeelding) ── */
.logo{display:flex;align-items:center;flex-shrink:0}
.logo-img{height:52px;width:auto;display:block;transition:opacity .2s}
.logo:hover .logo-img{opacity:.85}

/* ── NAV ── */
nav{display:flex;align-items:center;gap:2px}
nav>a{padding:7px 12px;border-radius:7px;font-size:14px;font-weight:500;color:#444;transition:all .15s}
nav>a:hover,nav>a.active{color:var(--ink);background:var(--cream2)}
.nav-dropdown{position:relative;padding-bottom:8px;margin-bottom:-8px}
.nav-dropdown>a{padding:7px 12px;border-radius:7px;font-size:14px;font-weight:500;color:#444;cursor:pointer;display:block;transition:all .15s}
.nav-dropdown:hover>a{color:var(--ink);background:var(--cream2)}
.ndm{position:absolute;top:calc(100% - 4px);left:0;background:var(--wit);border:1px solid var(--rand);border-radius:12px;min-width:220px;padding:6px;box-shadow:0 12px 40px rgba(0,0,0,.1);opacity:0;pointer-events:none;transform:translateY(-5px);transition:all .18s;z-index:201}
.nav-dropdown:hover .ndm{opacity:1;pointer-events:all;transform:translateY(0)}
.ndm a{display:block;padding:9px 12px;border-radius:7px;font-size:13px;font-weight:500;color:#555;cursor:pointer}
.ndm a:hover{background:var(--cream2);color:var(--ink)}

.header-cta{display:flex;align-items:center;gap:8px;flex-shrink:0}
.btn-wa{display:flex;align-items:center;gap:7px;background:#22c55e;color:#fff;padding:9px 18px;border-radius:9px;font-weight:700;font-size:14px;transition:all .2s}
.btn-wa:hover{background:#16a34a;transform:translateY(-1px)}
.btn-bel{display:flex;align-items:center;gap:7px;background:var(--oranje);color:#fff;padding:9px 20px;border-radius:9px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:15px;letter-spacing:.3px;box-shadow:0 3px 12px rgba(244,132,50,.3);transition:all .2s;white-space:nowrap}
.btn-bel:hover{background:var(--oranje2);transform:translateY(-1px)}

/* Hamburger */
.hamburger{display:none;background:none;border:1px solid var(--rand);border-radius:7px;padding:7px 11px;font-size:20px;cursor:pointer;color:var(--ink);line-height:1;transition:all .15s}
.hamburger:hover{background:var(--cream2)}
.mobile-nav{display:none;flex-direction:column;background:var(--wit);border-top:1px solid var(--rand);padding:6px 16px 20px;max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
.mobile-nav.open{display:flex}
.mobile-nav a{padding:14px 10px;font-size:16px;font-weight:500;color:var(--ink);border-bottom:1px solid var(--rand)}
.mobile-nav a:last-child{border:none}
.mobile-nav a:hover{color:var(--oranje)}
.mob-wa{margin-top:10px;background:#22c55e!important;color:#fff!important;text-align:center;padding:14px!important;border-radius:10px;font-weight:700;font-size:16px;border:none!important}
.mob-cta{margin-top:8px;background:var(--oranje)!important;color:#fff!important;text-align:center;padding:14px!important;border-radius:10px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:17px;border:none!important;letter-spacing:.3px}

/* ── HERO (Homepage) ── */
.hero{display:grid;grid-template-columns:1fr 440px;max-width:1280px;margin:0 auto;padding:48px 28px 40px;gap:48px;align-items:center}
.hero-label{display:inline-flex;align-items:center;gap:7px;background:rgba(244,132,50,.08);border:1px solid rgba(244,132,50,.18);border-radius:25px;padding:5px 14px;font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--oranje);text-transform:uppercase;margin-bottom:20px}
.hero-label .live{width:6px;height:6px;border-radius:50%;background:var(--oranje);animation:knipoog 1.4s infinite}
.hero h1{font-family:'Rajdhani',sans-serif;font-size:clamp(38px,4.2vw,64px);font-weight:700;line-height:1.1;letter-spacing:.5px;color:var(--ink);margin-bottom:18px}
.hero h1 em{font-style:normal;color:var(--oranje)}
.hero h1 .blok{display:inline-block;background:var(--ink);color:#fff;padding:1px 10px;border-radius:5px;font-size:clamp(32px,3.5vw,54px)}
.hero-sub{font-size:16px;color:var(--muted);line-height:1.75;max-width:460px;margin-bottom:30px}
.hero-acties{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:40px}
.btn-groot{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:10px;font-weight:700;font-size:16px;transition:all .2s}
.btn-groot.rood{background:var(--oranje);color:#fff;font-family:'Rajdhani',sans-serif;letter-spacing:.5px;font-size:17px;box-shadow:0 4px 20px rgba(244,132,50,.3)}
.btn-groot.rood:hover{background:var(--oranje2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(244,132,50,.4)}
.btn-groot.rand{border:2px solid var(--rand);color:var(--ink);background:var(--wit);font-family:'Rajdhani',sans-serif;letter-spacing:.3px;font-size:17px}
.btn-groot.rand:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.hero-stats{display:flex;gap:28px;align-items:center;padding-top:24px;border-top:1px solid var(--rand);flex-wrap:wrap}
.hstat .getal{font-family:'Rajdhani',sans-serif;font-size:32px;font-weight:700;line-height:1;color:var(--ink)}
.hstat .getal span{color:var(--oranje)}
.hstat .label{font-size:12px;color:var(--muted);margin-top:2px;font-weight:500}
.hstat-lijn{width:1px;height:32px;background:var(--rand)}

/* SOS Kaart (hero rechts) */
.sos-kaart{background:var(--ink);border-radius:20px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.18)}
.sos-top{background:var(--oranje);padding:20px 24px;display:flex;align-items:center;gap:12px}
.sos-top-icoon{width:36px;height:36px;flex-shrink:0}
.sos-top h2{font-family:'Rajdhani',sans-serif;font-size:19px;font-weight:700;color:#fff;letter-spacing:.5px}
.sos-top p{font-size:12px;color:rgba(255,255,255,.75);margin-top:2px}
.sos-body{padding:20px 24px}
.sv{width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px 14px;color:#fff;font-family:'Inter',sans-serif;font-size:14px;margin-bottom:8px;outline:none;transition:border-color .2s;-webkit-appearance:none;appearance:none}
.sv:focus{border-color:rgba(244,132,50,.6)}
.sv::placeholder{color:rgba(255,255,255,.3)}
textarea.sv{resize:none;height:70px}
.sos-verstuur{width:100%;background:var(--oranje);border:none;color:#fff;padding:13px;border-radius:8px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:15px;letter-spacing:.5px;cursor:pointer;transition:background .2s;-webkit-appearance:none}
.sos-verstuur:hover{background:var(--oranje2)}
.sos-verstuur:disabled{opacity:.5;cursor:default;pointer-events:none}
.sos-ok{display:none;text-align:center;padding:20px;color:#fff}
.sos-ok h3{color:var(--groen);margin-bottom:4px}
.sos-info{display:flex;gap:20px;margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}
.sos-info div{flex:1;text-align:center}
.sos-info .si-label{font-size:10px;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.sos-info .si-val{font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;color:#fff;letter-spacing:.3px}
.sos-info .si-val a{color:var(--oranje)}

/* ── SECTIONS ── */
.sectie{padding:52px 0}
.sectie-alt{background:var(--cream2)}
.display{font-family:'Rajdhani',sans-serif;font-size:clamp(28px,3.2vw,44px);font-weight:700;color:var(--ink);letter-spacing:.3px;margin-bottom:16px;line-height:1.15}
.display em{font-style:normal;color:var(--oranje)}
.tekst{font-size:15px;color:var(--muted);line-height:1.8;margin-bottom:12px}
.twee-kol{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center}

/* Check list */
.clist{list-style:none}
.clist li{display:flex;gap:12px;margin-bottom:18px}
.ccheck{width:28px;height:28px;border-radius:8px;background:rgba(244,132,50,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.ccheck svg{width:16px;height:16px;fill:var(--oranje)}
.clist h4{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:2px}
.clist p{font-size:13px;color:var(--muted)}

/* Diensten grid */
.diensten-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.dienst-card{background:var(--wit);border:1px solid var(--rand);border-radius:14px;padding:24px;display:flex;gap:14px;align-items:flex-start;transition:all .2s}
.dienst-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.06);border-color:var(--oranje)}
.dienst-icoon{font-size:28px;flex-shrink:0}
.dienst-card h3{font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;color:var(--ink);margin-bottom:4px}
.dienst-card p{font-size:13px;color:var(--muted);line-height:1.5}

/* Voordelen grid */
.voordelen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px}
.voordeel{background:var(--wit);border:1px solid var(--rand);border-radius:14px;padding:28px;text-align:center;transition:all .2s}
.voordeel:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.06)}
.voordeel-icoon{font-size:36px;margin-bottom:12px}
.voordeel h3{font-family:'Rajdhani',sans-serif;font-size:17px;font-weight:700;margin-bottom:6px}
.voordeel p{font-size:13px;color:var(--muted)}

/* Stats strip */
.stats-strip{background:var(--ink);padding:48px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat-getal{font-family:'Rajdhani',sans-serif;font-size:42px;font-weight:700;color:var(--oranje);line-height:1}
.stat-label{font-size:15px;font-weight:600;color:#fff;margin-top:6px}
.stat-sub{font-size:12px;color:rgba(255,255,255,.4);margin-top:2px}

/* FAQ */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px;align-items:start}
.faq-item{background:var(--wit);border:1px solid var(--rand);border-radius:10px;overflow:hidden}
.faq-v{padding:14px 18px;font-weight:600;font-size:14px;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-v:hover{background:var(--cream2)}
.faq-pijl{display:inline-block;font-size:12px;color:var(--muted);transition:transform .2s}
.faq-a{display:none;padding:0 18px 14px;font-size:13px;color:var(--muted);line-height:1.7}
.faq-item.open .faq-a{display:block}
.faq-item.open .faq-pijl{transform:rotate(180deg)}

/* CTA banner */
.cta-banner{background:var(--ink);border-radius:18px;padding:40px 48px;display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}
.cta-banner h2{font-family:'Rajdhani',sans-serif;font-size:clamp(24px,2.5vw,36px);font-weight:700;color:#fff;line-height:1.2}
.cta-banner h2 em{font-style:normal;color:var(--oranje)}
.cta-sub{font-size:14px;color:rgba(255,255,255,.5);margin-top:6px}
.cta-acties{display:flex;gap:12px;flex-wrap:wrap}
.btn-wit{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--ink);padding:14px 28px;border-radius:10px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:16px;transition:all .2s}
.btn-wit:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.btn-rand-wit{display:inline-flex;align-items:center;gap:8px;border:2px solid rgba(255,255,255,.2);color:#fff;padding:12px 24px;border-radius:10px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:16px;transition:all .2s}
.btn-rand-wit:hover{border-color:#fff;background:rgba(255,255,255,.05)}

/* ── SUB HERO (subpagina's) ── */
.sub-hero{background:var(--ink);padding:52px 0;text-align:center}
.sub-hero .chip{margin-bottom:8px}
.sub-hero h1{font-family:'Rajdhani',sans-serif;font-size:clamp(32px,4vw,52px);font-weight:700;color:#fff;letter-spacing:.5px;margin-bottom:12px}
.sub-hero p{font-size:16px;color:rgba(255,255,255,.6);max-width:540px;margin:0 auto}

/* ── SUB CONTENT ── */
.sub-content{padding:60px 0}
.sub-content h2{font-family:'Rajdhani',sans-serif;font-size:clamp(26px,3vw,40px);font-weight:700;color:var(--ink);letter-spacing:.3px;margin-bottom:16px}
.sub-content h3{font-family:'Rajdhani',sans-serif;font-size:20px;font-weight:700;color:var(--ink);letter-spacing:.3px;margin-top:28px;margin-bottom:8px}
.sub-content p{font-size:15px;color:var(--muted);line-height:1.8;margin-bottom:12px}
.sub-content .inline-link{color:var(--oranje);font-weight:600}

/* ── TARIEVEN ── */
.tarieven-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tarief-card{background:var(--wit);border:2px solid var(--rand);border-radius:16px;padding:32px 24px;text-align:center}
.tarief-card.featured{border-color:var(--oranje);background:var(--ink);color:#fff;transform:scale(1.03)}
.tarief-card .label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.tarief-card.featured .label{color:rgba(255,255,255,.5)}
.tarief-card .price{font-family:'Rajdhani',sans-serif;font-size:42px;font-weight:700;color:var(--ink);margin-bottom:20px}
.tarief-card.featured .price{color:#fff}
.tarief-card .features{list-style:none;text-align:left;margin-bottom:20px}
.tarief-card .features li{padding:8px 0;border-bottom:1px solid var(--rand);font-size:14px;display:flex;justify-content:space-between}
.tarief-card.featured .features li{border-color:rgba(255,255,255,.1)}
.tarief-card .check-icon{color:var(--oranje);font-weight:700}
.tarief-card .note{font-size:12px;color:var(--muted);margin-bottom:16px}
.tarief-card.featured .note{color:rgba(255,255,255,.5)}
.tarief-btn{display:block;padding:12px;border-radius:10px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:16px;text-align:center;transition:all .2s}
.tarief-btn-rood{background:var(--oranje);color:#fff}
.tarief-btn-wit{background:#fff;color:var(--ink)}
.tarief-btn:hover{transform:scale(1.02)}
.incl-tabel{width:100%;border-collapse:collapse;margin-top:24px;max-width:800px;margin-left:auto;margin-right:auto}
.incl-tabel th{background:var(--ink);color:#fff;padding:14px 20px;text-align:left;font-size:14px}
.incl-tabel td{padding:14px 20px;border-bottom:1px solid var(--rand);font-size:14px}
.incl-tabel .ja{color:var(--oranje);font-weight:700}

/* ── BLOG ── */
.blog-card{background:var(--wit);border:1px solid var(--rand);border-radius:16px;overflow:hidden;display:grid;grid-template-columns:160px 1fr;margin-bottom:16px;transition:all .2s}
.blog-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.06);transform:translateY(-2px)}
.blog-thumb{background:rgba(244,132,50,.06);display:flex;align-items:center;justify-content:center;font-size:42px;min-height:120px}
.blog-body{padding:24px 28px}
.blog-tag{display:inline-block;background:var(--oranje);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:20px;margin-bottom:8px}
.blog-card h3{font-family:'Rajdhani',sans-serif;font-size:18px;font-weight:700;margin-bottom:6px;color:var(--ink)}
.blog-meta{font-size:11px;color:var(--muted)}

/* ── VACATURES ── */
.vacature{background:var(--wit);border:1px solid var(--rand);border-radius:16px;padding:32px;margin-bottom:20px}
.vtag{display:inline-block;padding:3px 11px;border-radius:20px;font-size:11px;font-weight:700;margin-right:6px;margin-bottom:10px}
.vtag-rood{background:var(--oranje);color:#fff}
.vtag-grijs{background:var(--ink);color:#fff}
.vtag-groen{background:#22c55e;color:#fff}

/* ── CONTACT & AFSPRAAK FORMS ── */
.contact-grid{display:grid;grid-template-columns:1fr 380px;gap:52px;align-items:start}
.af-group{margin-bottom:14px}
.af-group label{display:block;font-size:12px;font-weight:700;color:var(--ink);margin-bottom:5px}
.af-group input,.af-group select,.af-group textarea{width:100%;padding:12px 14px;border:1px solid var(--rand);border-radius:8px;font-size:14px;font-family:inherit;background:var(--wit);outline:none;transition:border-color .2s;-webkit-appearance:none;appearance:none}
.af-group input:focus,.af-group select:focus,.af-group textarea:focus{border-color:var(--oranje)}
.af-group textarea{resize:vertical;min-height:100px}
.af-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.af-submit{background:var(--oranje);color:#fff;border:none;padding:14px 32px;border-radius:10px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:16px;cursor:pointer;transition:background .2s;width:100%;-webkit-appearance:none}
.af-submit:hover{background:var(--oranje2)}
.af-submit:disabled{opacity:.5;cursor:default;pointer-events:none}
.af-success{display:none;text-align:center;padding:40px;background:rgba(34,197,94,.06);border:2px solid #22c55e;border-radius:16px}
.af-error{display:none;text-align:center;padding:20px;background:rgba(244,132,50,.06);border:2px solid var(--oranje);border-radius:12px;margin-bottom:16px;color:var(--oranje);font-weight:600}

.contact-info-card{background:var(--cream2);border-radius:14px;padding:24px}
.ci-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--rand)}
.ci-item:last-child{border-bottom:none}
.ci-item h4{font-family:'Rajdhani',sans-serif;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:2px}
.ci-item p{font-size:13px;color:var(--muted);line-height:1.5}
.ci-item a{color:var(--oranje);font-weight:600}

/* Service detail layout */
.svc-layout{display:grid;grid-template-columns:1fr 260px;gap:48px;align-items:start}
.service-detail h3{margin-top:20px!important}
.sidebar-links{list-style:none;background:var(--wit);border:1px solid var(--rand);border-radius:14px;overflow:hidden}
.sidebar-links a{display:block;padding:12px 18px;font-size:14px;font-weight:500;color:var(--muted);border-bottom:1px solid var(--rand);cursor:pointer;transition:all .15s}
.sidebar-links a:last-child{border-bottom:none}
.sidebar-links a:hover,.sidebar-links a.active{color:var(--oranje);background:rgba(244,132,50,.04)}

/* Foto blok (over ons) */
.foto-blok{position:relative}
.foto-blok img{border-radius:16px;width:100%;height:320px;object-fit:cover;background:var(--ink)}
.foto-placeholder{height:320px;background:var(--ink);border-radius:16px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.3);font-size:18px}
.foto-badge{position:absolute;bottom:-16px;right:24px;background:var(--oranje);color:#fff;padding:14px 20px;border-radius:14px;text-align:center}
.foto-badge .groot{font-family:'Rajdhani',sans-serif;font-size:28px;font-weight:700;line-height:1}
.foto-badge .klein{font-size:11px;font-weight:600}

/* ── FLOAT WHATSAPP ── */
.float-wa{position:fixed;bottom:24px;right:24px;width:56px;height:56px;background:#22c55e;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(34,197,94,.4);z-index:900;transition:transform .2s}
.float-wa:hover{transform:scale(1.08)}
.float-wa svg{width:28px;height:28px;fill:#fff}

/* ── BACK TO TOP ── */
.back-top{position:fixed;bottom:90px;right:28px;width:40px;height:40px;border-radius:10px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;opacity:0;pointer-events:none;transition:all .3s;cursor:pointer;z-index:800;border:none}
.back-top.show{opacity:1;pointer-events:all}

/* ── FOOTER ── */
footer{background:var(--ink);padding:56px 0 0;color:#ccc}
.footer-rij{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;max-width:1280px;margin:0 auto;padding:0 28px 40px}
.footer-merk{font-family:'Rajdhani',sans-serif;font-size:22px;font-weight:700;color:#fff;margin-bottom:12px}
.footer-merk span{color:var(--oranje)}
.footer-tekst{font-size:13px;line-height:1.7;color:#888;margin-bottom:16px}
.footer-social{display:flex;gap:10px}
.footer-social a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;transition:background .2s}
.footer-social a:hover{background:var(--oranje)}
.footer-social svg{width:16px;height:16px;fill:rgba(255,255,255,.5)}
footer h4{color:#fff;font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;margin-bottom:16px}
.flinks{list-style:none}
.flinks a{display:block;padding:4px 0;font-size:13px;color:#888;transition:color .2s}
.flinks a:hover{color:var(--oranje)}
.fcontact-item{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-size:13px}
.fcontact-icoon{width:30px;height:30px;border-radius:8px;background:var(--oranje);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fcontact-icoon svg{width:14px;height:14px;fill:#fff}
.fcontact-tekst{color:#ccc}
.fcontact-tekst a{color:var(--oranje);font-weight:600}
.footer-cta-kaart{background:rgba(244,132,50,.08);border-radius:14px;padding:20px}
.footer-cta-kaart h4{color:var(--oranje)!important;margin-bottom:6px}
.footer-cta-kaart p{font-size:12px;color:#888;margin-bottom:12px}
.footer-cta-kaart a{display:inline-block;padding:10px 20px;background:var(--oranje);color:#fff;border-radius:8px;font-size:13px;font-weight:700}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 28px;max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;font-size:12px;color:#666}
.footer-bottom a{color:#888;transition:color .2s}
.footer-bottom a:hover{color:var(--oranje)}

/* ══════════════════════════════════════════
   NIEUWE SECTIES
   ══════════════════════════════════════════ */

/* ── MERKEN STRIP ── */
.merken-strip{background:var(--ink);padding:32px 0}
.merken-label{text-align:center;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:20px}
.merken-logos{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.merk-item{font-family:'Rajdhani',sans-serif;font-size:20px;font-weight:700;color:rgba(255,255,255,.25);letter-spacing:1px;transition:color .3s}
.merk-item:hover{color:rgba(255,255,255,.7)}

/* ── PARTNER LIJST ── */
.partner-lijst{display:flex;flex-direction:column;gap:10px}
.partner-item{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,.7);padding:8px 12px;background:rgba(255,255,255,.05);border-radius:8px}
.partner-check{color:var(--oranje);font-weight:700;font-size:16px}

/* ── REVIEWS ── */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review-card{background:var(--wit);border:1px solid var(--rand);border-radius:14px;padding:28px;text-align:left;transition:all .2s}
.review-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.06)}
.review-sterren{color:#f59e0b;font-size:18px;margin-bottom:12px;letter-spacing:2px}
.review-tekst{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:16px;font-style:italic}
.review-auteur{font-size:13px;color:var(--ink)}
.review-auteur strong{font-weight:700}
.review-auteur span{color:var(--muted)}

/* ── REGIO GRID ── */
.regio-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:28px}
.regio-item{background:var(--wit);border:1px solid var(--rand);border-radius:10px;padding:12px 8px;font-size:13px;font-weight:600;color:var(--ink);transition:all .2s}
.regio-item:hover{border-color:var(--oranje);color:var(--oranje);transform:translateY(-2px)}
.regio-nummers{display:flex;justify-content:center;gap:32px;flex-wrap:wrap;margin-top:8px}
.regio-nr{font-size:14px;color:var(--muted)}
.regio-nr strong{color:var(--ink)}
.regio-nr a{color:var(--oranje);font-weight:700}

/* ══════════════════════════════════════════
   GOOGLE REVIEWS — Live Review Cards
   ══════════════════════════════════════════ */

.review-card--live{display:block;text-decoration:none;color:inherit;cursor:pointer;transition:transform .2s,box-shadow .2s}
.review-card--live:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.12)}
.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.review-datum{font-size:12px;color:rgba(0,0,0,.4)}
.review-star.full{color:#f59e0b}
.review-star.half{color:#f59e0b;opacity:.6}
.review-star.empty{color:#d1d5db}
.review-card--live .review-auteur{display:flex;align-items:center;gap:10px;margin-top:16px}
.review-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}
.review-avatar-placeholder{width:36px;height:36px;border-radius:50%;background:var(--oranje);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0}
.review-google-badge{display:inline-flex;align-items:center;font-size:11px;color:rgba(0,0,0,.4);margin-top:2px}


/* ══════════════════════════════════════════
   RESPONSIVE — VOLLEDIG MOBIEL GESCHIKT
   ══════════════════════════════════════════ */

/* ── TABLET (max 1100px) ── */
@media(max-width:1100px){
  .hero{grid-template-columns:1fr;padding:40px 28px 48px}
  .sos-kaart{max-width:480px}
  .twee-kol,.contact-grid,.svc-layout{grid-template-columns:1fr}
  .voordelen-grid,.tarieven-grid,.diensten-grid{grid-template-columns:1fr 1fr}
  .tarief-card.featured{transform:none}
  .footer-rij{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr 1fr}
  .regio-grid{grid-template-columns:repeat(4,1fr)}
  .hstat-lijn{display:none}
  .hero-stats{gap:20px}
  .contact-grid{gap:32px}
}

/* ── MOBIEL (max 768px) ── */
@media(max-width:768px){
  /* Padding verkleinen */
  .wrap{padding:0 16px}
  .sectie{padding:36px 0}

  /* Header */
  .hamburger{display:block}
  nav,.header-cta{display:none}
  .header-inner{padding:0 16px;height:60px}
  .logo-img{height:38px}

  /* Ribbon */
  .ribbon{padding:8px 12px;gap:8px}
  .ribbon-tekst{font-size:12px}
  .ribbon-groen{font-size:11px;padding:3px 10px}
  .ribbon-tel{font-size:12px;padding:3px 12px}

  /* Hero */
  .hero{padding:28px 16px 36px;gap:28px}
  .hero h1{font-size:32px}
  .hero-sub{font-size:14px;margin-bottom:20px}
  .hero-acties{flex-direction:column;gap:10px}
  .btn-groot{width:100%;justify-content:center;padding:14px 20px}
  .hero-stats{gap:16px;justify-content:center}
  .hstat .getal{font-size:26px}
  .hstat .label{font-size:11px}
  /* Keurmerk in hero stats kleiner */
  .hero-stats img{height:52px!important}

  /* SOS kaart */
  .sos-kaart{max-width:100%}
  .sos-top{padding:16px 18px}
  .sos-top h2{font-size:16px}
  .sos-body{padding:16px 18px}

  /* Display headings */
  .display{font-size:26px;margin-bottom:12px}

  /* Grids naar 1 kolom */
  .voordelen-grid,.tarieven-grid,.diensten-grid,.stats-grid,.faq-grid,.reviews-grid{grid-template-columns:1fr}
  .tarief-card.featured{transform:none}
  .regio-grid{grid-template-columns:repeat(3,1fr)}

  /* Blog */
  .blog-card{grid-template-columns:1fr}
  .blog-thumb{min-height:100px}
  .blog-body{padding:18px 20px}

  /* Forms */
  .af-row{grid-template-columns:1fr}

  /* Twee kolom secties */
  .twee-kol{gap:28px}

  /* Sub hero */
  .sub-hero{padding:32px 0}
  .sub-hero h1{font-size:28px}
  .sub-hero p{font-size:14px;padding:0 16px}
  .sub-content{padding:36px 0}

  /* CTA banner */
  .cta-banner{padding:24px 20px;text-align:center;justify-content:center;flex-direction:column}
  .cta-acties{justify-content:center;width:100%}
  .cta-acties .btn-wit,.cta-acties .btn-rand-wit{width:100%;justify-content:center}

  /* Tarieven */
  .tarief-card{padding:24px 20px}
  .tarief-card .price{font-size:36px}
  .incl-tabel th,.incl-tabel td{padding:10px 12px;font-size:13px}

  /* Merken */
  .merken-strip{padding:24px 0}
  .merken-logos{gap:16px}
  .merk-item{font-size:15px}

  /* Regio */
  .regio-nummers{flex-direction:column;gap:10px;align-items:center}

  /* Vacatures */
  .vacature{padding:22px 18px}

  /* Footer */
  .footer-rij{grid-template-columns:1fr;gap:28px;padding:0 16px 32px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;padding:16px}

  /* Float buttons */
  .float-wa{bottom:16px;right:16px;width:50px;height:50px}
  .float-wa svg{width:24px;height:24px}
  .back-top{bottom:76px;right:18px;width:36px;height:36px;font-size:16px}

  /* Stats strip */
  .stats-strip{padding:32px 0}
  .stats-grid{gap:20px}
  .stat-getal{font-size:34px}
  .stat-label{font-size:13px}

  /* Contact grid */
  .contact-grid{grid-template-columns:1fr;gap:24px}

  /* Service layout */
  .svc-layout{grid-template-columns:1fr;gap:24px}

  /* ── INLINE STYLE OVERRIDES ──
     De homepage heeft inline styles op de servicebus / info kaart
     sectie. Deze overrides zorgen dat het ook op mobiel goed werkt. */

  /* Servicebus afbeelding */
  .twee-kol img[alt="Sleutel24 servicebus"]{height:240px!important}

  /* Info kaart grid (Particulieren, Aannemers etc.) */
  .twee-kol [style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr!important;
    gap:8px!important
  }

  /* Stats in info kaart (5 Monteurs, 20+ Jaar, 24/7) */
  .twee-kol [style*="justify-content:center"][style*="gap:32px"]{
    gap:20px!important;
    flex-wrap:wrap!important
  }
}

/* ── KLEIN MOBIEL (max 480px) ── */
@media(max-width:480px){
  .wrap{padding:0 12px}
  .logo-img{height:30px}
  .header-inner{height:54px;padding:0 12px}

  /* Hero nog compacter */
  .hero{padding:20px 12px 28px;gap:20px}
  .hero h1{font-size:28px}
  .hero-sub{font-size:13px}
  .hero-label{font-size:10px;padding:4px 10px}
  .hero-stats{gap:12px}
  .hstat .getal{font-size:22px}
  .hero-stats img{height:40px!important}

  /* Buttons */
  .btn-groot{font-size:15px;padding:12px 16px}

  /* SOS */
  .sos-top{padding:14px 14px}
  .sos-top h2{font-size:15px}
  .sos-body{padding:14px}
  .sv{padding:10px 12px;font-size:13px}

  /* Sectie titels */
  .display{font-size:22px}
  .chip{font-size:9px;padding:3px 10px}

  /* Dienst cards */
  .dienst-card{padding:18px 14px}
  .dienst-icoon{font-size:24px}
  .dienst-card h3{font-size:15px}

  /* Regio */
  .regio-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .regio-item{font-size:12px;padding:10px 6px}

  /* FAQ */
  .faq-v{padding:12px 14px;font-size:13px}
  .faq-a{padding:0 14px 12px;font-size:12px}

  /* Review cards */
  .review-card{padding:20px}
  .review-tekst{font-size:13px}

  /* CTA banner */
  .cta-banner{padding:20px 16px;border-radius:14px}
  .cta-banner h2{font-size:22px}
  .btn-wit,.btn-rand-wit{font-size:14px;padding:12px 20px}

  /* Tarieven */
  .tarief-card .price{font-size:32px}

  /* Footer */
  .footer-merk{font-size:20px}
  .footer-cta-kaart{padding:16px}

  /* Mobile nav */
  .mobile-nav a{padding:12px 8px;font-size:15px}
  .mob-wa,.mob-cta{font-size:15px;padding:12px!important}

  /* Merken */
  .merk-item{font-size:14px}
  .merken-logos{gap:12px}

  /* Stats */
  .stat-getal{font-size:28px}
  .stat-label{font-size:12px}

  /* Blog */
  .blog-body{padding:14px 16px}
  .blog-card h3{font-size:16px}

  /* Sub hero */
  .sub-hero h1{font-size:24px}
  .sub-hero p{font-size:13px}
  .sub-content h2{font-size:22px}
}

/* ── EXTRA KLEIN (max 360px) ── */
@media(max-width:360px){
  .hero h1{font-size:24px}
  .hero-stats{flex-direction:column;align-items:flex-start;gap:14px}
  .hstat{display:flex;align-items:center;gap:10px}
  .regio-grid{grid-template-columns:1fr 1fr}
  .btn-groot{font-size:14px;padding:11px 14px}
  .cta-banner h2{font-size:20px}
  .stats-grid{grid-template-columns:1fr 1fr;gap:16px}
}

/* ── TOUCH OPTIMIZATION ── */
@media(hover:none) and (pointer:coarse){
  .dienst-card:hover,.voordeel:hover,.review-card:hover,.regio-item:hover,.review-card--live:hover{transform:none;box-shadow:none}
  .btn-groot:hover,.btn-wa:hover,.btn-bel:hover,.btn-wit:hover,.btn-rand-wit:hover{transform:none}
  /* Grotere tap targets */
  .faq-v{min-height:48px}
  .mobile-nav a{min-height:48px;display:flex;align-items:center}
  .flinks a{min-height:44px;display:flex;align-items:center}
}

/* ── REDUCED MOTION (accessibility) ── */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* ── SAFE AREA (notch / home indicator) ── */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .float-wa{bottom:calc(16px + env(safe-area-inset-bottom))}
  .back-top{bottom:calc(76px + env(safe-area-inset-bottom))}
  .mobile-nav{padding-bottom:calc(20px + env(safe-area-inset-bottom))}
  footer .footer-bottom{padding-bottom:calc(20px + env(safe-area-inset-bottom))}
}