/* Slim Bouw B.V. — main stylesheet (brand: navy-zwart #011C2F · rood #8F050F)
   Accent-light (#E74C3C) + warm cream (#FBE8AA) voor contrast op donkere bg — WCAG AA */
:root{
  --primary:#011C2F;--primary-dark:#00111F;
  --secondary:#8F050F;--secondary-dark:#6C0306;
  --accent:#8F050F;--accent-dark:#6C0306;
  --accent-light:#E74C3C;      /* lichter rood — gebruik op donkere bg (4.6:1 op navy) */
  --cream:#FBE8AA;             /* warm cream — accenten op donker (9:1 op navy) */
  --on-dark:#F7F3EB;           /* off-white tekst op donker */
  --dark:#011C2F;--text:#011C2F;--muted:#4A5663;
  --light:#FBFAF8;--border:#E8E4DC;--success:#2F7A3F;
  --radius:10px;--radius-lg:16px;
  --shadow:0 4px 12px rgba(1,28,47,.08);
  --shadow-lg:0 10px 40px rgba(1,28,47,.16);
  --container:1200px;--header-h:96px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text);line-height:1.6;background:#fff;padding-top:var(--header-h)}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none;transition:color .2s}
a:hover{color:var(--primary-dark)}
h1,h2,h3,h4{font-weight:700;line-height:1.25;color:var(--dark);letter-spacing:-.01em}
h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3.5vw,2.5rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.5rem)}
h4{font-size:1.1rem}
p{margin-bottom:1rem}
.container{max-width:var(--container);margin:0 auto;padding:0 1.25rem}

#site-header{position:fixed;top:40px;left:0;right:0;width:100%;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 4px 16px rgba(0,0,0,.08);z-index:100;height:var(--header-h);display:flex;align-items:center;padding:0 2rem;overflow:visible}
#site-header .nav-inner{max-width:none;width:100%;margin:0;padding:0;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;overflow:visible}
.logo{display:flex;align-items:center;gap:.5rem;color:var(--dark);flex-shrink:0;z-index:2;position:relative;text-decoration:none;background:transparent;border:0;padding:0;margin:0;overflow:visible;line-height:0}
.logo i{color:var(--secondary);font-size:1.4rem}
.logo img{height:76px;width:auto;display:block;max-width:360px;object-fit:contain;background:transparent;border:0;padding:0;margin:0;image-rendering:auto}
.logo picture{display:block;line-height:0;background:transparent}
.site-nav{display:flex;align-items:center;gap:.25rem}
.site-nav a{padding:.5rem .85rem;color:var(--text);font-weight:500;font-size:.95rem;border-radius:var(--radius);transition:background .2s}
.site-nav a:hover{background:var(--light);color:var(--primary)}
.site-nav a.active{color:var(--primary);background:#FFF5F5}
.site-nav .nav-cta{background:var(--secondary);color:#fff!important;padding:.6rem 1.1rem;margin-left:.5rem}
.site-nav .nav-cta:hover{background:var(--secondary-dark)}
.hamburger{display:none;background:none;border:0;cursor:pointer;padding:.5rem;flex-direction:column;gap:4px}
.hamburger span{display:block;width:24px;height:2px;background:var(--dark)}

.hero{position:relative;padding:5rem 0 4rem;background:linear-gradient(135deg,var(--primary) 0%,var(--dark) 100%);color:#fff;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(143,5,15,.15),transparent 50%);pointer-events:none}
.hero-inner{position:relative;max-width:900px;z-index:1}
.hero .badge{display:inline-block;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:.35rem 1rem;border-radius:999px;font-size:.85rem;font-weight:500;margin-bottom:1.5rem}
.hero h1{color:#fff;margin-bottom:1.25rem}
.hero h1 em{font-style:normal;color:var(--accent-light)}
.hero-sub{font-size:clamp(1rem,1.8vw,1.3rem);opacity:.9;margin-bottom:2rem;max-width:680px;line-height:1.6}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.5rem}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.5rem;border-radius:var(--radius);font-weight:600;font-size:1rem;border:0;cursor:pointer;transition:transform .2s,box-shadow .2s;white-space:nowrap;text-decoration:none}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--secondary);color:#fff!important;box-shadow:0 4px 14px rgba(143,5,15,.25)}
.btn-primary:hover{background:var(--secondary-dark);color:#fff!important}
.btn-outline{background:rgba(255,255,255,.08);color:#fff!important;border:1px solid rgba(255,255,255,.25)}
.btn-outline:hover{background:rgba(255,255,255,.15);color:#fff!important}
.btn-wa{background:#25d366;color:#fff!important}
.btn-wa:hover{background:#1fb355;color:#fff!important}
.btn-secondary{background:var(--primary);color:#fff!important}
.btn-secondary:hover{background:var(--primary-dark);color:#fff!important}
.btn-light{background:#fff;color:var(--primary)!important;border:1px solid var(--border)}
.btn-light:hover{background:var(--light)}
.hero-usps{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-top:1rem}
.hero-usp{display:flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.08);padding:.6rem .9rem;border-radius:var(--radius);font-size:.9rem}
.hero-usp i{color:var(--accent-light);font-size:1.1rem;flex-shrink:0}

section{padding:4rem 0}
section.bg-light{background:var(--light)}
section.bg-dark{background:var(--dark);color:#fff}
section.bg-dark h2,section.bg-dark h3{color:#fff}
.section-head{text-align:center;max-width:720px;margin:0 auto 3rem}
.section-head .eyebrow{display:inline-block;color:var(--secondary);font-weight:600;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.75rem}
.section-head h2{margin-bottom:1rem}
.section-head p{color:var(--muted);font-size:1.1rem}

.usps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.usp-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;text-align:center;transition:transform .2s,box-shadow .2s}
.usp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.usp-card > i{width:56px;height:56px;line-height:56px;border-radius:50%;background:#FFF5F5;color:var(--primary);font-size:1.5rem;margin-bottom:1.25rem;display:inline-block}
.usp-card h3{margin-bottom:.5rem}
.usp-card p{color:var(--muted);margin:0}

.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.service-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;flex-direction:column;color:var(--text)}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary)}
.service-card .icon{width:56px;height:56px;line-height:56px;text-align:center;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-radius:var(--radius);font-size:1.4rem;margin-bottom:1.25rem}
.service-card.featured .icon{background:linear-gradient(135deg,var(--secondary),var(--secondary-dark))}
.service-card h3{margin-bottom:.5rem}
.service-card p{color:var(--muted);flex:1;margin-bottom:0}
.service-card .arrow{color:var(--primary);font-weight:600;margin-top:1rem;display:inline-flex;align-items:center;gap:.4rem}
.service-card:hover .arrow i{transform:translateX(4px)}
.service-card .arrow i{transition:transform .2s}
.service-card .price{display:inline-block;margin-top:.5rem;background:#FFF0F0;color:var(--secondary-dark);padding:.2rem .6rem;border-radius:999px;font-size:.85rem;font-weight:600;border:1px solid #FFD6D6}

.focus-block{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;border-radius:var(--radius-lg);padding:clamp(2rem,5vw,4rem);display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;overflow:hidden;position:relative}
.focus-block::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 50%,rgba(143,5,15,.20),transparent 60%);pointer-events:none}
.focus-block > *{position:relative;z-index:1}
.focus-block h2{color:#fff;margin-bottom:1rem}
.focus-block p{opacity:.9;font-size:1.1rem;margin-bottom:1.5rem}
.focus-bullets{list-style:none;margin-bottom:2rem}
.focus-bullets li{padding:.4rem 0;padding-left:2rem;position:relative}
.focus-bullets li::before{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;left:0;color:var(--cream);font-size:1rem}
.focus-visual{text-align:center;font-size:14rem;opacity:.15}

.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}
.step{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem}
.step-num{width:56px;height:56px;text-align:center;background:var(--primary);color:#fff;border-radius:50%;font-weight:700;font-size:1.3rem;margin-bottom:1rem;display:flex;align-items:center;justify-content:center}
.step-num i{font-size:1.25rem;line-height:1}
.step h4{margin-bottom:.4rem}
.step p{color:var(--muted);font-size:.95rem;margin:0}

.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.project-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.project-img{aspect-ratio:4/3;background:linear-gradient(135deg,#cbd5e1,#94a3b8);display:flex;align-items:center;justify-content:center;color:#fff;font-size:3rem}
.project-card .body{padding:1.25rem}
.project-card h4{margin-bottom:.3rem}
.project-card .loc{color:var(--muted);font-size:.9rem;margin:0}

.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.review{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem}
.review .stars{color:#fbbf24;margin-bottom:.75rem;font-size:1rem}
.review .text{color:var(--text);font-style:italic;margin-bottom:1rem}
.review .author{font-weight:600;font-size:.95rem}
.review .meta{color:var(--muted);font-size:.85rem}

.tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.tool-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;text-align:center;transition:transform .2s,box-shadow .2s}
.tool-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.tool-card > i{width:72px;height:72px;line-height:72px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-radius:50%;font-size:1.8rem;margin-bottom:1.25rem;display:inline-block}
.tool-card .btn i{width:auto;height:auto;background:none;color:inherit;font-size:.9rem;margin:0;padding:0;border-radius:0;display:inline}
.tool-card h3{margin-bottom:.5rem}
.tool-card p{color:var(--muted);margin-bottom:1rem}

.faq-list{max-width:820px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.75rem;overflow:hidden}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:1.1rem 1.25rem;cursor:pointer;font-weight:600;list-style:none}
.faq-q::-webkit-details-marker{display:none}
.faq-q::after{content:'\f078';font-family:'Font Awesome 6 Free';font-weight:900;color:var(--primary);transition:transform .2s}
.faq-item[open] .faq-q::after{transform:rotate(180deg)}
.faq-item .faq-a{padding:0 1.25rem 1.25rem;color:var(--muted);line-height:1.7}

.cta-section{background:linear-gradient(135deg,var(--secondary) 0%,var(--secondary-dark) 100%);color:#fff;text-align:center;padding:4rem 1.25rem;border-radius:var(--radius-lg)}
.cta-section h2{color:#fff;margin-bottom:1rem}
.cta-section p{opacity:.95;font-size:1.15rem;max-width:620px;margin:0 auto 2rem}
.cta-section .btn-primary{background:#fff;color:var(--secondary)!important}
.cta-section .btn-primary:hover{background:var(--light)}
.cta-section .btn-outline{border-color:rgba(255,255,255,.5)}

.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow);max-width:640px;margin:0 auto}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-weight:600;margin-bottom:.4rem;font-size:.95rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius);font:inherit;color:var(--text);transition:border-color .2s,box-shadow .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(30,64,175,.1)}
.form-group textarea{min-height:120px;resize:vertical}
.form-note{color:var(--muted);font-size:.85rem;margin-top:.3rem}
.form-success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;padding:1rem 1.25rem;border-radius:var(--radius);margin-bottom:1rem}
.form-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:1rem 1.25rem;border-radius:var(--radius);margin-bottom:1rem}

.breadcrumbs{padding:1rem 0;background:var(--light);border-bottom:1px solid var(--border);font-size:.9rem;color:var(--muted)}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--primary)}
.breadcrumbs .sep{margin:0 .5rem;opacity:.5}

.page-hero{padding:4rem 0 3rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff}
.page-hero h1{color:#fff;margin-bottom:.75rem}
.page-hero p{font-size:1.15rem;opacity:.9;max-width:720px}
.page-hero .breadcrumbs{background:transparent;color:rgba(255,255,255,.8);border:0;padding:0 0 1rem}
.page-hero .breadcrumbs a{color:rgba(255,255,255,.8)}
.page-hero .breadcrumbs a:hover{color:var(--accent-light)}

.compare-table{width:100%;background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);border-collapse:separate;border-spacing:0}
.compare-table th,.compare-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}
.compare-table th{background:var(--light);font-weight:700}
.compare-table .check{color:var(--success);font-weight:700}
.compare-table .cross{color:#dc2626}
.compare-table tr:last-child td{border-bottom:0}

.calc{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem}
.calc-step{margin-bottom:1.5rem}
.calc-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-top:.75rem}
.calc-option{padding:.75rem 1rem;background:var(--light);border:2px solid transparent;border-radius:var(--radius);cursor:pointer;text-align:center;transition:all .2s;font-weight:500}
.calc-option:hover{background:#FFF5F5}
.calc-option.selected{background:#FFF5F5;border-color:var(--primary);color:var(--primary)}
.calc-result{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;padding:2rem;border-radius:var(--radius-lg);text-align:center;margin-top:2rem;display:none}
.calc-result h3{color:#fff;margin-bottom:.5rem}
.calc-result .price{font-size:2.5rem;font-weight:800;margin:.5rem 0}
.calc-result .range{opacity:.85}

#site-footer{background:var(--dark);color:#cbd5e1;padding:4rem 0 0}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem}
.footer-col h4{color:#fff;margin-bottom:1rem;font-size:1rem}
.footer-col p,.footer-col a{color:#cbd5e1;display:block;margin-bottom:.4rem;font-size:.95rem}
.footer-col a:hover{color:var(--accent-light)}
.footer-col i{color:var(--accent-light);margin-right:.4rem;width:1rem}
.footer-logo{color:#fff;font-weight:700;font-size:1.25rem;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}
.footer-logo i{color:var(--accent-light)}
.social-links{display:flex;gap:.75rem}
.social-links a{width:40px;height:40px;line-height:40px;text-align:center;background:rgba(255,255,255,.08);border-radius:50%;color:#fff;margin:0;display:inline-block}
.social-links a:hover{background:var(--secondary);color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:3rem;padding:1.25rem 0}
.footer-bottom .container{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.9rem;color:var(--muted)}
.footer-bottom a{color:var(--muted);display:inline}
.footer-bottom a:hover{color:var(--accent-light)}

/* .wa-float styles are defined lower in Floating chat + WhatsApp block */

.text-center{text-align:center}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:2rem}

@media(max-width:900px){
  .hamburger{display:flex;order:3;margin-left:auto;background:var(--primary);padding:.6rem;border-radius:6px}
  .hamburger span{background:#fff}
  .logo{order:1;margin-right:auto}
  .logo img{height:52px;max-width:200px}
  #site-header{padding:0 1rem;top:0!important}
  #site-header .nav-inner{gap:.5rem}
  body{padding-top:var(--header-h)}
  #top-bar{display:none}
  .site-nav{display:none;order:4;position:fixed;top:var(--header-h);left:0;right:0;background:#fff;border-bottom:1px solid var(--border);flex-direction:column;padding:1rem;gap:0;box-shadow:var(--shadow-lg);width:100%;z-index:99}
  .site-nav.open{display:flex}
  .site-nav a{width:100%;padding:.85rem 1rem}
  .site-nav .nav-cta,.site-nav .nav-phone{margin:.5rem 0 0;text-align:center;justify-content:center}
  .focus-block{grid-template-columns:1fr}
  .focus-visual{display:none}
  .form-row{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:540px){
  .hero{padding:3rem 0 2.5rem}
  section{padding:3rem 0}
  .footer-inner{grid-template-columns:1fr}
  .footer-bottom .container{flex-direction:column;text-align:center}
}

/* ─── Top bar (fixed boven header, full width) ───────────── */
#top-bar{position:fixed;top:0;left:0;right:0;width:100%;background:var(--primary);color:#fff!important;font-size:.88rem;border-bottom:1px solid rgba(255,255,255,.08);z-index:101;padding:0 2rem}
.top-bar-inner{max-width:none;width:100%;margin:0;padding:0;display:flex;justify-content:space-between;align-items:center;height:40px;gap:1rem;flex-wrap:nowrap;overflow:hidden}
.top-bar-left,.top-bar-right{display:flex;align-items:center;gap:1.5rem}
#top-bar a,#top-bar a:link,#top-bar a:visited,#top-bar a:active,#top-bar span{color:#fff!important;opacity:.92;display:inline-flex;align-items:center;gap:.45rem;transition:opacity .2s;white-space:nowrap;text-decoration:none!important}
#top-bar a:hover{opacity:1;color:#fff!important;text-decoration:none!important}
#top-bar i{color:var(--accent-light);font-size:.85rem}
#top-bar .top-wa{background:rgba(37,211,102,.9);padding:.35rem .85rem;border-radius:6px;font-weight:600;opacity:1}
#top-bar .top-wa:hover{background:#25d366}
#top-bar .top-wa i{color:#fff}
body{padding-top:calc(var(--header-h) + 40px)}

/* Bel direct link in nav */
.site-nav .nav-phone{color:var(--accent)!important;font-weight:600;padding:.5rem .85rem}
.site-nav .nav-phone:hover{background:#FFF0F0}

/* ─── Enriched footer ────────────────────── */
.footer-cta{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:3rem 0;position:relative;overflow:hidden}
.footer-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 85% 50%,rgba(143,5,15,.3),transparent 60%);pointer-events:none}
.footer-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;position:relative;z-index:1}
.footer-cta h2{color:#fff;margin-bottom:.5rem;font-size:clamp(1.4rem,3vw,2rem)}
.footer-cta p{opacity:.9;margin:0;font-size:1.05rem}
.footer-cta-buttons{display:flex;gap:.75rem;flex-wrap:wrap}

.footer-inner{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.5rem;padding:4rem 0 2rem}
.footer-brand .footer-logo-img{filter:none;opacity:1;margin-bottom:1rem;max-width:220px;height:auto;display:block}
.footer-tagline{color:#cbd5e1;font-size:.95rem;margin-bottom:1.5rem;font-style:italic}
.footer-col h4{color:#fff;font-size:1rem;font-weight:700;margin-bottom:1.25rem;letter-spacing:.02em}
.footer-col a,.footer-col p{display:block;color:#cbd5e1;font-size:.95rem;margin-bottom:.55rem;text-decoration:none;transition:color .2s;line-height:1.5}
.footer-col p{margin-bottom:.75rem}
.footer-col a:hover{color:var(--accent-light)}
.footer-col i{color:var(--accent-light);margin-right:.5rem;width:1rem;text-align:center;font-size:.9rem}
.footer-col .footer-muted{color:#94a3b8;font-size:.85rem}
.footer-link-more{color:var(--accent-light)!important;font-weight:600;margin-top:.5rem;font-size:.9rem}

.social-links{display:flex;gap:.6rem;margin-top:.5rem}
.social-links a{width:38px;height:38px;line-height:38px;text-align:center;background:rgba(255,255,255,.08);border-radius:50%;color:#fff!important;margin:0;padding:0;display:inline-flex;align-items:center;justify-content:center;transition:background .2s,transform .2s}
.social-links a:hover{background:var(--secondary);transform:translateY(-2px);color:#fff!important}
.social-links i{margin:0;color:inherit;font-size:1rem}

.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.25rem 0}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.88rem;color:#94a3b8}
.footer-bottom-links{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}
.footer-bottom-links a{color:#cbd5e1;text-decoration:none;transition:color .2s}
.footer-bottom-links a:hover{color:var(--accent-light)}

/* ─── Responsive top-bar + footer ─────── */
@media(max-width:900px){
  .top-bar-inner{font-size:.78rem;gap:.6rem}
  .top-bar-left,.top-bar-right{gap:.75rem}
  .hide-sm{display:none!important}
  body{padding-top:var(--header-h)}
  #site-header{top:0}
  #top-bar{display:none}
  .footer-inner{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-cta-inner{flex-direction:column;text-align:center}
}
@media(max-width:600px){
  .footer-inner{grid-template-columns:1fr}
  .footer-bottom-inner{flex-direction:column;text-align:center}
}

/* ─── Brand SVG icons ─────────────────── */
.brand-icon{display:inline-flex;align-items:center;justify-content:center;line-height:1}
.brand-icon svg{width:100%;height:100%;display:block}
.service-card .icon{display:flex;align-items:center;justify-content:center;padding:10px}
.service-card .icon .brand-icon{width:36px;height:36px;color:#fff}
.focus-visual .brand-icon{width:180px;height:180px;color:#fff;margin:0 auto}
.tool-card > .brand-icon{width:72px;height:72px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-radius:50%;padding:18px;margin-bottom:1.25rem}
.usp-card > .brand-icon{width:56px;height:56px;background:#FFF5F5;color:var(--primary);border-radius:50%;padding:14px;margin-bottom:1.25rem}

/* Service-spotlight op dienst-pagina */
.service-spotlight{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:3rem;border-radius:var(--radius-lg);text-align:center;position:relative;overflow:hidden}
.service-spotlight::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 75% 30%,rgba(143,5,15,.25),transparent 60%);pointer-events:none}
.service-spotlight > *{position:relative;z-index:1}
.service-spotlight-icon{width:140px;height:140px;margin:0 auto 1.5rem;color:var(--accent-light);display:flex;align-items:center;justify-content:center}
.service-spotlight-icon .brand-icon{width:100%;height:100%}
.service-spotlight h3{color:#fff;margin-bottom:.5rem}
.service-spotlight p{opacity:.9}

/* Klant-geleverde PNG icons: toon zonder gradient-backing, eigen kleuren behouden */
.service-card .icon:has(.client-icon){background:transparent!important;padding:0}
.service-card .client-icon img{width:64px;height:64px;object-fit:contain;display:block;margin:0 auto}
.service-card.featured .icon:has(.client-icon){background:transparent!important}
.tool-card > .client-icon{background:transparent!important}
.usp-card > .client-icon{background:transparent!important}
.focus-visual .client-icon img{width:100%;max-width:220px}
.service-spotlight-icon .client-icon img{width:140px;height:140px}

/* ─── Floating chat + WhatsApp ──────────── */
.float-actions{position:fixed;bottom:24px;right:24px;z-index:95;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.wa-float,.chat-float{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;box-shadow:0 6px 20px rgba(0,0,0,.25);transition:transform .2s,box-shadow .2s;cursor:pointer;border:0;position:relative}
.wa-float{background:#25d366;color:#fff}
.wa-float:hover{transform:scale(1.08);color:#fff}
.chat-float{background:var(--secondary);color:#fff;padding:0}
.chat-float:hover{transform:scale(1.08);background:var(--secondary-dark)}
.chat-float i{font-size:1.5rem}
.chat-float-label{position:absolute;right:68px;top:50%;transform:translateY(-50%);background:var(--primary);color:#fff;padding:.4rem .75rem;border-radius:6px;font-size:.85rem;font-weight:600;white-space:nowrap;pointer-events:none;box-shadow:0 4px 10px rgba(0,0,0,.15)}
.chat-float-label::after{content:'';position:absolute;left:100%;top:50%;transform:translateY(-50%);border:6px solid transparent;border-left-color:var(--primary)}
.chat-float.open .chat-float-label{display:none}
.chat-float.open i::before{content:'\f00d'} /* × icon */

/* Chat panel */
#chat-panel{position:fixed;bottom:100px;right:24px;width:380px;max-width:calc(100vw - 48px);max-height:calc(100vh - 160px);background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.25);display:none;flex-direction:column;z-index:96;overflow:hidden;border:1px solid var(--border)}
#chat-panel.open{display:flex;animation:chatSlideUp .25s ease-out}
@keyframes chatSlideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.chat-panel-header{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;padding:1rem 1.1rem;display:flex;justify-content:space-between;align-items:center}
.chat-panel-brand{display:flex;align-items:center;gap:.75rem}
.chat-avatar{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;overflow:hidden}
.chat-avatar .brand-icon,.chat-avatar img{width:28px;height:28px;color:#fff}
.chat-panel-title{font-weight:700;font-size:1rem;color:#fff;line-height:1.1}
.chat-panel-status{font-size:.78rem;opacity:.85;display:flex;align-items:center;gap:.35rem;margin-top:.15rem}
.chat-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;box-shadow:0 0 0 2px rgba(34,197,94,.25)}
.chat-panel-close{background:none;border:0;color:#fff;font-size:1.5rem;cursor:pointer;opacity:.7;transition:opacity .2s;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.chat-panel-close:hover{opacity:1;background:rgba(255,255,255,.1)}

.chat-panel-body{flex:1;overflow-y:auto;padding:1rem;background:#F9FAFB;min-height:240px;max-height:340px}
.chat-msg{margin-bottom:.75rem;display:flex}
.chat-msg-bot{justify-content:flex-start}
.chat-msg-bot p{background:#fff;border:1px solid var(--border);padding:.7rem 1rem;border-radius:4px 16px 16px 16px;max-width:80%;margin:0;font-size:.92rem;line-height:1.5;color:var(--text)}
.chat-msg-bot p a{color:var(--secondary);font-weight:600}
.chat-msg-user{justify-content:flex-end}
.chat-msg-user p{background:var(--primary);color:#fff;padding:.7rem 1rem;border-radius:16px 4px 16px 16px;max-width:80%;margin:0;font-size:.92rem;line-height:1.5}

.chat-quick-replies{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem}
.chat-chip{background:#fff;border:1px solid var(--border);color:var(--primary);padding:.45rem .85rem;border-radius:999px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}
.chat-chip:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

.chat-panel-form{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-top:1px solid var(--border);background:#fff}
.chat-panel-form input{flex:1;padding:.65rem 1rem;border:1px solid var(--border);border-radius:999px;font:inherit;color:var(--text);outline:none;transition:border-color .15s}
.chat-panel-form input:focus{border-color:var(--primary)}
.chat-panel-form button{width:40px;height:40px;border-radius:50%;background:var(--secondary);color:#fff;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:background .15s}
.chat-panel-form button:hover{background:var(--secondary-dark)}

.chat-panel-footer{display:flex;justify-content:space-around;padding:.6rem;background:#F9FAFB;border-top:1px solid var(--border)}
.chat-panel-footer a{color:var(--primary);font-size:.8rem;font-weight:600;display:inline-flex;align-items:center;gap:.35rem;text-decoration:none;padding:.3rem .6rem;border-radius:6px;transition:background .15s}
.chat-panel-footer a:hover{background:var(--border)}

@media(max-width:480px){
  #chat-panel{bottom:84px;right:12px;left:12px;width:auto}
  .float-actions{bottom:16px;right:16px}
  .wa-float,.chat-float{width:52px;height:52px;font-size:1.4rem}
  .chat-float-label{display:none}
}

/* === Media injectie (echte klant-foto's) === */
.focus-img{width:100%;height:auto;max-height:420px;object-fit:cover;border-radius:var(--radius-lg);box-shadow:0 10px 30px rgba(0,0,0,.25);opacity:1}
.service-photo{border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,.12);background:#f1f5f9}
.service-photo img{width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;display:block}
.project-img img{width:100%;height:100%;object-fit:cover;display:block}
.project-img{aspect-ratio:4/3;overflow:hidden}
.service-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}
.service-gallery .gallery-item{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;background:#f1f5f9;box-shadow:0 4px 14px rgba(0,0,0,.08);transition:transform .25s ease, box-shadow .25s ease}
.service-gallery .gallery-item:hover{transform:translateY(-3px);box-shadow:0 10px 22px rgba(0,0,0,.15)}
.service-gallery img{width:100%;height:100%;object-fit:cover;display:block}
.page-hero.page-hero-photo{padding:5rem 0 4rem;position:relative}
.page-hero.page-hero-photo .breadcrumbs a,.page-hero.page-hero-photo .breadcrumbs span{color:rgba(255,255,255,.85)}
.page-hero.page-hero-photo .breadcrumbs .sep{color:rgba(255,255,255,.5)}

/* ─── Hero slider ──────────────────────── */
.hero-slider{padding:6rem 0 5rem;min-height:560px;display:flex;align-items:center;position:relative;overflow:hidden}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1s ease-in-out}
.hero-slide.is-active{opacity:1}
.hero-slider .hero-inner{position:relative;z-index:2}
.hero-slider::before{display:none} /* gradient overlay zit nu in elke slide */
.hero-dots{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);display:flex;gap:.5rem;z-index:3}
.hero-dot{width:10px;height:10px;border-radius:50%;border:2px solid rgba(255,255,255,.55);background:transparent;cursor:pointer;padding:0;transition:all .2s}
.hero-dot.is-active{background:var(--cream);border-color:var(--cream);transform:scale(1.15)}
.hero-dot:hover{border-color:#fff}

/* Betere contrasten op donkere blokken */
.hero-sub{color:rgba(255,255,255,.95)}
.hero .badge{color:var(--cream);border-color:rgba(251,232,170,.4);background:rgba(251,232,170,.08)}
.hero .badge i{color:var(--cream)}
.hero-usp{color:rgba(255,255,255,.95);background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.12)}
.focus-block .eyebrow{color:var(--cream)!important}
.section.bg-dark .eyebrow,section.bg-dark .eyebrow{color:var(--cream)}
.cta-section{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%)}
.cta-section h2,.cta-section p{color:#fff}
.cta-section .btn-primary{background:var(--accent-light);color:#fff!important;box-shadow:0 4px 14px rgba(231,76,60,.35)}
.cta-section .btn-primary:hover{background:var(--secondary)}

/* === Hero triggers (direct action pills) === */
.hero-triggers{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;margin-bottom:1.5rem}
.hero-trigger{display:flex;align-items:center;gap:.75rem;padding:.9rem 1rem;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);border-radius:12px;color:#fff;text-decoration:none;transition:background .2s,transform .2s,border-color .2s}
.hero-trigger:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.32);transform:translateY(-2px);color:#fff}
.hero-trigger .trigger-icon{flex:0 0 44px;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent-light,#8F050F);color:#fff;font-size:1.1rem}
.hero-trigger .trigger-txt{font-size:.92rem;line-height:1.3;color:#fff}
.hero-trigger .trigger-txt strong{display:block;font-weight:700;font-size:1rem;color:#fff}

/* Google review badge in hero usps */
.hero-usp-google{display:flex;align-items:center;gap:.4rem}
.hero-usp-google .google-g{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#fff;color:#4285F4;font-weight:800;font-family:Arial,sans-serif;font-size:.85rem;line-height:1}
.hero-usp-google .stars{color:#FBBC05;letter-spacing:1px;font-size:.85rem}

/* === Mobile sticky CTA bar === */
.mobile-cta-bar{display:none}
@media(max-width:768px){
  .mobile-cta-bar{display:grid;grid-template-columns:1fr 1fr 1fr;position:fixed;left:0;right:0;bottom:0;z-index:90;background:#fff;border-top:1px solid rgba(0,0,0,.08);box-shadow:0 -4px 16px rgba(0,0,0,.10);padding:env(safe-area-inset-bottom) 0 0 0}
  .mobile-cta-bar .mcb-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:.7rem .25rem;text-decoration:none;font-size:.78rem;font-weight:600;color:var(--dark,#011C2F)}
  .mobile-cta-bar .mcb-item i{font-size:1.2rem}
  .mobile-cta-bar .mcb-call{color:var(--primary,#011C2F)}
  .mobile-cta-bar .mcb-wa{color:#128C7E}
  .mobile-cta-bar .mcb-offer{color:#fff;background:var(--accent-light,#8F050F)}
  .mobile-cta-bar .mcb-item:active{opacity:.7}
  /* body padding zodat content niet achter sticky bar wegvalt */
  body{padding-bottom:68px}
  /* float-actions iets hoger zodat ze niet overlappen met mobile-cta-bar */
  .float-actions{bottom:76px!important}
}

/* === Form-more details (collapsible extra fields) === */
.form-more{margin-top:1.25rem;border-top:1px dashed rgba(0,0,0,.12);padding-top:1rem}
.form-more>summary{cursor:pointer;font-weight:600;color:var(--primary,#011C2F);font-size:.95rem;list-style:none;display:inline-flex;align-items:center;gap:.4rem;user-select:none}
.form-more>summary::-webkit-details-marker{display:none}
.form-more>summary::before{content:'›';display:inline-block;transition:transform .2s;font-size:1.1rem}
.form-more[open]>summary::before{transform:rotate(90deg)}
.form-more>summary:hover{color:var(--accent-light,#8F050F)}
.form-more .form-group,.form-more .form-row{margin-top:1rem}

/* === Before/After slider === */
.before-after-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem}
.ba-card{background:#fff;border:1px solid var(--border,rgba(0,0,0,.08));border-radius:var(--radius-lg,14px);overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.06)}
.ba-card h3{padding:1rem 1.25rem 0;margin:0;font-size:1.15rem}
.ba-card .ba-meta{padding:0 1.25rem 1rem;color:var(--muted,#4A5663);font-size:.9rem;margin:.25rem 0 0}
.ba-slider{position:relative;aspect-ratio:4/3;overflow:hidden;user-select:none;touch-action:none;cursor:ew-resize}
.ba-slider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.ba-slider .ba-after{clip-path:inset(0 0 0 50%)}
.ba-slider .ba-handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;box-shadow:0 0 0 1px rgba(0,0,0,.25)}
.ba-slider .ba-handle::after{content:'⇆';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:38px;height:38px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--primary,#011C2F);box-shadow:0 3px 10px rgba(0,0,0,.3);font-size:1.1rem;font-weight:700}
.ba-slider .ba-label{position:absolute;top:12px;padding:4px 10px;border-radius:4px;background:rgba(0,0,0,.7);color:#fff;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;pointer-events:none}
.ba-slider .ba-label.ba-label-before{left:12px}
.ba-slider .ba-label.ba-label-after{right:12px}
