/* ============================================================================
   AFO Limburg — Design system v2
   Premium, betrouwbaar, lokaal vakmanschap. Huisstijl: rood + antraciet + wit.
   --primary (rood) en --secondary (antraciet) komen uit het CMS (instellingen).
   ============================================================================ */

:root{
  /* Merkkleuren (overschreven door CMS via inline style in de header) */
  --primary:#D8261E;          /* AFO rood */
  --secondary:#2f2d31;        /* antraciet */

  /* Afgeleide tinten */
  --red:var(--primary);
  --red-dark:color-mix(in srgb, var(--primary) 82%, #000);
  --red-soft:color-mix(in srgb, var(--primary) 10%, #fff);
  --ink:var(--secondary);
  --ink-soft:color-mix(in srgb, var(--secondary) 88%, #fff);

  /* Neutralen (warm) */
  --bg:#ffffff;
  --bg-soft:#f6f5f4;
  --bg-tint:#faf9f8;
  --text:#26242a;
  --muted:#6f6c75;
  --line:#e8e6e6;
  --white:#fff;

  --radius:16px;
  --radius-sm:10px;
  --radius-lg:26px;
  --maxw:1180px;
  --shadow-sm:0 2px 8px rgba(31,29,33,.06);
  --shadow:0 16px 40px rgba(31,29,33,.10);
  --shadow-lg:0 30px 70px rgba(31,29,33,.16);
  --ring:0 0 0 4px color-mix(in srgb, var(--primary) 22%, transparent);

  --font-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-head:"Sora","Inter",system-ui,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip}
img{max-width:100%;display:block}
a{color:var(--red);text-decoration:none;transition:color .15s}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--ink);line-height:1.12;margin:0 0 .4em;letter-spacing:-.02em;font-weight:700}
h1{font-size:clamp(2.3rem,5.2vw,3.9rem);font-weight:800}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem)}
h3{font-size:1.2rem}
p{margin:0 0 1rem}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:88px 0}
.section-sm{padding:56px 0}
.section-alt{background:var(--bg-soft)}
.section-dark{background:var(--ink);color:#e9e7ea}
.section-dark h2,.section-dark h3{color:#fff}
.ta-center{text-align:center}
.lead{font-size:1.18rem;color:var(--muted);max-width:680px}
.section-head{max-width:720px;margin:0 auto 52px;text-align:center}
.section-head.left{margin-left:0;text-align:left}
.eyebrow{display:inline-block;font-family:var(--font-head);font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.eyebrow::before{content:"";display:inline-block;width:22px;height:2px;background:var(--red);vertical-align:middle;margin-right:10px;margin-bottom:4px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 28px;border-radius:999px;font-family:var(--font-head);font-weight:600;font-size:.98rem;cursor:pointer;border:2px solid transparent;transition:transform .15s,box-shadow .15s,background .15s;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 10px 24px color-mix(in srgb,var(--primary) 32%,transparent)}
.btn-primary:hover{background:var(--red-dark);color:#fff}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.btn-ghost-dark{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-ghost-dark:hover{border-color:var(--ink)}
.btn-lg{padding:17px 34px;font-size:1.05rem}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--ink);color:#cfcdd3;font-size:.85rem;border-bottom:1px solid rgba(255,255,255,.06)}
.topbar-inner{position:relative;display:flex;justify-content:space-between;align-items:center;gap:16px;height:44px}
.topbar a{color:#e9e7ea;font-weight:500}
.topbar a:hover{color:#fff}
.topbar .tb-contact{display:flex;gap:22px;align-items:center}
.topbar .tb-contact span{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.topbar .tb-right{display:flex;gap:18px;align-items:center}
.topbar .tb-right a{display:inline-flex;align-items:center;gap:6px;font-weight:600;white-space:nowrap}
.topbar svg{width:14px;height:14px;opacity:.8;flex-shrink:0}

/* Roterende USP-band — flex-item tussen contact en CTA; space-between verdeelt de ruimte. */
.tb-ticker{position:relative;flex:0 0 auto;height:44px;min-width:260px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.tb-ticker span{position:absolute;white-space:nowrap;opacity:0;color:#fff;font-weight:500;letter-spacing:.01em;padding-left:18px;
  animation:tbRotate 18s infinite}
.tb-ticker span::before{content:"";position:absolute;left:0;top:50%;width:7px;height:7px;border-radius:50%;background:var(--primary);transform:translateY(-50%)}
.tb-ticker span:nth-child(1){animation-delay:0s}
.tb-ticker span:nth-child(2){animation-delay:4.5s}
.tb-ticker span:nth-child(3){animation-delay:9s}
.tb-ticker span:nth-child(4){animation-delay:13.5s}
@keyframes tbRotate{
  0%{opacity:0;transform:translateY(7px)}
  3%,22%{opacity:1;transform:translateY(0)}
  25%,100%{opacity:0;transform:translateY(-7px)}
}
@media(prefers-reduced-motion:reduce){
  .tb-ticker span{animation:none}
  .tb-ticker span:nth-child(1){opacity:1}
  .tb-ticker span:nth-child(n+2){display:none}
}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .2s}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:76px;gap:20px}
.brand{font-family:var(--font-head);font-weight:800;font-size:1.3rem;color:var(--ink);letter-spacing:-.02em;white-space:nowrap;flex-shrink:0}
.brand-logo{max-height:50px;width:auto}
.main-nav .nav-links{list-style:none;display:flex;gap:2px;margin:0;padding:0;align-items:center}
.main-nav .nav-links>li>a{display:block;color:var(--ink);font-family:var(--font-head);font-weight:500;font-size:.93rem;padding:8px 12px;border-radius:8px;white-space:nowrap;transition:background .15s,color .15s}
.main-nav .nav-links>li>a:hover{background:var(--bg-soft);color:var(--red)}
.nav-cta{margin-left:6px;background:var(--red)!important;color:#fff!important;padding:10px 18px!important;border-radius:999px!important;white-space:nowrap;box-shadow:0 8px 20px color-mix(in srgb,var(--primary) 30%,transparent)}
.nav-cta:hover{background:var(--red-dark)!important}
.nav-toggle{display:none;background:none;border:0;font-size:1.7rem;cursor:pointer;color:var(--ink);line-height:1}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(150deg,#26242a 0%,var(--ink) 48%,#3a373d 100%);color:#fff;overflow:hidden;padding:104px 0 108px}
.hero::after{content:"";position:absolute;right:-12%;top:-20%;width:60%;height:140%;background:radial-gradient(circle at center,color-mix(in srgb,var(--primary) 28%,transparent),transparent 62%);pointer-events:none}
/* Foto-achtergrond (zodra een hero-afbeelding is ingesteld) */
.hero.has-photo{background-size:cover;background-position:center}
.hero.has-photo::before{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(28,26,30,.92) 0%,rgba(28,26,30,.78) 46%,rgba(28,26,30,.32) 100%);z-index:1}
.hero.has-photo::after{opacity:.5}
.hero-art{position:absolute;right:-2%;bottom:-4%;width:min(52%,680px);opacity:.2;color:#fff;pointer-events:none;z-index:1}
.hero-inner{position:relative;z-index:2;max-width:700px}
.hero h1{color:#fff;margin-bottom:18px}
.hero h1 .accent{color:#fff;white-space:nowrap;border-bottom:6px solid var(--primary);padding-bottom:2px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:600;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);padding:7px 16px;border-radius:999px;margin-bottom:24px}
.hero-eyebrow b{color:var(--primary);filter:brightness(1.5)}
.hero-sub{font-size:1.22rem;color:rgba(255,255,255,.86);margin-bottom:32px;max-width:560px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{display:flex;gap:28px;flex-wrap:wrap;margin-top:40px;padding-top:28px;border-top:1px solid rgba(255,255,255,.14)}
.hero-trust .ht{display:flex;flex-direction:column}
.hero-trust .ht b{font-family:var(--font-head);font-size:1.5rem;color:#fff;line-height:1}
.hero-trust .ht span{font-size:.82rem;color:rgba(255,255,255,.7);margin-top:4px}

.page-hero{background:var(--ink);color:#fff;padding:72px 0 60px;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-8%;top:-30%;width:46%;height:160%;background:radial-gradient(circle,color-mix(in srgb,var(--primary) 26%,transparent),transparent 60%)}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff}
.page-hero .hero-sub{color:rgba(255,255,255,.82);margin-bottom:0}

/* ---------- Trust strip ---------- */
.trust-strip{background:var(--white);border-bottom:1px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:26px 0}
.trust-item{display:flex;align-items:center;gap:12px;font-weight:600;color:var(--ink);font-size:.95rem}
.trust-item svg{width:26px;height:26px;color:var(--red);flex-shrink:0}

/* ---------- Feature / USP cards ---------- */
.feature-grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:transform .18s,box-shadow .18s,border-color .18s}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.feature .ic{width:54px;height:54px;border-radius:14px;background:var(--red-soft);color:var(--red);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.feature .ic svg{width:28px;height:28px}
.feature h3{margin-bottom:8px}
.feature p{color:var(--muted);margin:0;font-size:.96rem}

/* ---------- Service cards ---------- */
.service-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .18s,box-shadow .18s}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.service-card .sc-media{height:230px;background:linear-gradient(135deg,var(--ink),#46434a);position:relative;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.9);overflow:hidden}
.service-card .sc-media img{width:100%;height:100%;object-fit:cover;display:block}
.service-card .sc-media .sc-icon{width:48px;height:48px;opacity:.9}
.service-card .sc-body{padding:24px;display:flex;flex-direction:column;flex:1}
.service-card h3{margin-bottom:6px}
.service-card p{color:var(--muted);font-size:.95rem;flex:1}
.service-card .sc-link{margin-top:14px;font-family:var(--font-head);font-weight:600;color:var(--red);display:inline-flex;align-items:center;gap:6px}
.service-card:hover .sc-link{gap:10px}

.card-grid{display:grid;gap:26px;grid-template-columns:repeat(auto-fit,minmax(270px,1fr))}

/* ---------- Stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat b{display:block;font-family:var(--font-head);font-size:2.6rem;font-weight:800;color:#fff;line-height:1}
.stat span{color:rgba(255,255,255,.72);font-size:.95rem;margin-top:8px;display:block}

/* ---------- Project cards ---------- */
.project-card,.blog-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .18s,box-shadow .18s}
.project-card:hover,.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.project-thumb{aspect-ratio:4/3;background:linear-gradient(135deg,#46434a,var(--ink));background-size:cover;background-position:center;position:relative}
.project-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.35),transparent 55%)}

/* ---------- Subtiele hover-zoom op beelden (premium, niet afleidend) ---------- */
.service-card .sc-media img,
.price-card .price-media{transition:transform .55s ease}
.service-card:hover .sc-media img,
.price-card:hover .price-media{transform:scale(1.06)}
.project-card .project-thumb{transition:transform .55s ease}
.project-card:hover .project-thumb{transform:scale(1.06)}
@media(prefers-reduced-motion:reduce){
  .service-card .sc-media img,.price-card .price-media,.project-card .project-thumb{transition:none}
  .service-card:hover .sc-media img,.price-card:hover .price-media,.project-card:hover .project-thumb{transform:none}
}
.project-body{padding:20px}
.project-body h3{margin:.35em 0 .2em;font-size:1.12rem}
.project-body p{color:var(--muted);margin:0;font-size:.92rem}
.tag{display:inline-block;background:var(--red-soft);color:var(--red);font-family:var(--font-head);font-size:.72rem;font-weight:700;padding:4px 11px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}

/* ---------- Process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.step{position:relative;padding:34px 24px 28px;background:#fff;border:1px solid var(--line);border-radius:var(--radius)}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-18px;left:24px;width:42px;height:42px;border-radius:50%;background:var(--red);color:#fff;font-family:var(--font-head);font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px color-mix(in srgb,var(--primary) 35%,transparent)}
.step h3{margin:6px 0 8px;font-size:1.08rem}
.step p{color:var(--muted);font-size:.93rem;margin:0}

/* ---------- Reviews ---------- */
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.review-card .stars{color:#f5a623;font-size:1.05rem;letter-spacing:2px;margin-bottom:14px}
.review-card .quote{font-size:1.02rem;color:var(--text);font-style:italic;margin-bottom:16px}
.review-card .who{font-family:var(--font-head);font-weight:700;color:var(--ink)}

/* ---------- FAQ ---------- */
.faq-list{max-width:840px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:var(--radius-sm);padding:4px 22px;margin-bottom:12px;background:#fff;transition:box-shadow .15s}
.faq-item[open]{box-shadow:var(--shadow-sm)}
.faq-item summary{cursor:pointer;font-family:var(--font-head);font-weight:600;color:var(--ink);padding:16px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--red);font-size:1.5rem;font-weight:300;line-height:1}
.faq-item[open] summary::after{content:"–"}
.faq-item>div{padding:0 0 18px;color:var(--muted)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;border-radius:var(--radius-lg);padding:64px 48px;text-align:center;overflow:hidden;box-shadow:0 30px 60px color-mix(in srgb,var(--primary) 30%,transparent)}
/* decoratieve overkapping-lijntekening op de achtergrond */
.cta-band::before{content:"";position:absolute;right:-40px;bottom:-40px;width:360px;height:240px;opacity:.12;background-repeat:no-repeat;background-size:contain;background-position:bottom right;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 360' fill='none' stroke='%23fff' stroke-width='6'%3E%3Cpath d='M40 120 320 60 560 120'/%3E%3Cpath d='M40 120v200M320 60v240M560 120v200M40 150h520M40 320h520'/%3E%3Cpath d='M120 150v170M200 150v170M400 150v170M480 150v170'/%3E%3C/svg%3E")}
.cta-band::after{content:"";position:absolute;left:-10%;top:-60%;width:50%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 60%);pointer-events:none}
.cta-band>*{position:relative;z-index:1}
.cta-band .eyebrow{color:#fff}
.cta-band .eyebrow::before{background:#fff}
.cta-band h2{color:#fff;margin-bottom:10px;font-size:clamp(1.7rem,3vw,2.5rem)}
.cta-band p{color:rgba(255,255,255,.92);max-width:540px;margin:0 auto 28px;font-size:1.08rem}
.cta-band .btn-primary{background:#fff;color:var(--red)}
.cta-band .btn-primary:hover{background:#fff;color:var(--red-dark);box-shadow:0 12px 28px rgba(0,0,0,.18)}
.cta-band .btn-ghost{border-color:rgba(255,255,255,.7);color:#fff}
.cta-band-meta{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;margin-top:24px;font-size:.9rem;color:rgba(255,255,255,.92)}
.cta-band-meta span{display:inline-flex;align-items:center;gap:8px}
.cta-band-meta svg{width:18px;height:18px}

/* ---------- Detail / content ---------- */
.breadcrumbs{font-size:.85rem;color:rgba(255,255,255,.7)}
.breadcrumbs a{color:rgba(255,255,255,.9)}
.page-content{max-width:760px;font-size:1.05rem}
.page-content h2{margin-top:1.4em}
.detail-image{border-radius:var(--radius);margin-bottom:24px;width:100%;max-height:460px;object-fit:cover}
.gallery{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));margin-top:24px}
.gallery img{border-radius:var(--radius-sm);width:100%;aspect-ratio:4/3;object-fit:cover}

/* ---------- Split feature (beeld + tekst) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split + .split{margin-top:72px}
.split-media{position:relative}
.split-media img{border-radius:var(--radius-lg);width:100%;aspect-ratio:5/4;object-fit:cover;box-shadow:var(--shadow)}
.split-media .badge-float{position:absolute;left:-18px;bottom:-18px;background:var(--red);color:#fff;font-family:var(--font-head);font-weight:700;padding:16px 22px;border-radius:var(--radius);box-shadow:var(--shadow);line-height:1.2}
.split-media .badge-float span{display:block;font-size:.78rem;font-weight:500;opacity:.85}
.split.reverse .split-media{order:2}
.split-body h2{margin-bottom:14px}
.split-body p{color:var(--muted);font-size:1.05rem}
.split-body .btn{margin-top:8px}
@media(max-width:860px){.split,.split.reverse{grid-template-columns:1fr;gap:30px}.split.reverse .split-media{order:0}.split + .split{margin-top:48px}.split-media .badge-float{left:14px;bottom:14px}}

/* ---------- Detail layout (dienst) ---------- */
.detail-layout{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.detail-aside{position:sticky;top:104px}
.offer-card{background:var(--ink);color:#e9e7ea;border-radius:var(--radius);padding:28px}
.offer-card h3{color:#fff;margin-bottom:8px}
.offer-card p{color:rgba(255,255,255,.78);font-size:.95rem}
.offer-card .btn{margin-top:10px}
.btn-block{display:flex;width:100%;justify-content:center}
.offer-card .btn-ghost-dark{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.offer-card .btn-ghost-dark:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.offer-phone{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.15);font-size:.9rem;color:rgba(255,255,255,.75)}
.offer-phone a{color:#fff;font-family:var(--font-head);font-weight:700;font-size:1.15rem}
.check-list{list-style:none;padding:0;margin:0}
.check-list li{position:relative;padding:8px 0 8px 34px;border-bottom:1px solid var(--line)}
.check-list li::before{content:"";position:absolute;left:0;top:11px;width:20px;height:20px;border-radius:50%;background:var(--red-soft);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23D8261E' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:13px}
@media(max-width:860px){.detail-layout{grid-template-columns:1fr}.detail-aside{position:static}}

/* ---------- Filter chips ---------- */
.filter-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px}
.chip{padding:9px 18px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--ink);font-family:var(--font-head);font-weight:500;font-size:.9rem;transition:.15s}
.chip:hover{border-color:var(--red);color:var(--red)}
.chip-active{background:var(--red);color:#fff;border-color:var(--red)}

/* ---------- Contact ---------- */
.contact-grid{display:grid;gap:48px;grid-template-columns:0.9fr 1.1fr;align-items:start}
.contact-info{background:var(--ink);color:#e9e7ea;border-radius:var(--radius-lg);padding:36px}
.contact-info h2{color:#fff;font-size:1.5rem;margin-bottom:22px}
.contact-list{list-style:none;padding:0;margin:0 0 24px}
.contact-list li{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.contact-list .ci-ic{flex-shrink:0;width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:var(--primary)}
.contact-list .ci-ic svg{width:20px;height:20px}
.contact-list b{display:block;font-family:var(--font-head);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.55);margin-bottom:3px;font-weight:600}
.contact-list div{font-size:.97rem}
.contact-list a{color:#fff}
.wa-btn{background:#25d366!important;color:#fff!important;box-shadow:none}
.wa-btn:hover{background:#1da851!important}
.contact-vat{font-size:.78rem;color:rgba(255,255,255,.45);margin:16px 0 0}
.contact-form-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-sm)}
.contact-form-wrap h2{font-size:1.5rem;margin-bottom:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{color:var(--muted);font-size:.88rem;margin:14px 0 0}
.map-section{line-height:0;border-top:1px solid var(--line)}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}}

/* ---------- Filter chips (legacy anchor) ---------- */
.contact-form label,.contact-form .lbl{display:block;margin-bottom:16px;font-family:var(--font-head);font-weight:600;font-size:.92rem}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;margin-top:6px;padding:13px 15px;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;font-weight:400;background:#fff;transition:border-color .15s,box-shadow .15s}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--red);box-shadow:var(--ring)}
.error-text{color:var(--red-dark);font-weight:600;font-size:.85rem}
.alert-box{padding:18px 20px;border-radius:var(--radius-sm);margin-bottom:20px}
.alert-box.success{background:#e8f6ec;color:#1c7a3d;border:1px solid #b8e6c6}
.alert-box.error{background:var(--red-soft);color:var(--red-dark)}
.note{background:var(--bg-soft);border:1px solid var(--line);padding:18px;border-radius:var(--radius-sm);color:var(--muted)}
.hp{position:absolute;left:-9999px;height:0;overflow:hidden}

/* ---------- Facebook embed ---------- */
.fb-section{background:var(--bg-soft)}
.fb-wrap{display:flex;justify-content:center}
.fb-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);max-width:560px;width:100%}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#b7b4bd;padding:0 0 26px;border-top:3px solid var(--red)}
.site-footer h3,.site-footer h4{color:#fff}
.site-footer h4{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:#fff;margin-bottom:18px}
.footer-grid{display:grid;gap:40px;grid-template-columns:1.5fr 1fr 1fr 1.2fr;padding:64px 0 0}
.site-footer a{color:#cfcdd3;transition:color .15s}.site-footer a:hover{color:#fff}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:11px}
.footer-links a{display:inline-flex;align-items:center;gap:8px}
.footer-links a::before{content:"›";color:var(--red);font-weight:700}
.footer-brand-logo{max-height:56px;margin-bottom:16px}
.footer-about{font-size:.95rem;line-height:1.7}
.footer-meta{font-size:.8rem;opacity:.6;margin-top:14px;letter-spacing:.02em}
/* contact met iconen — vast grid zodat alle tekst links uitlijnt */
.footer-contact{list-style:none;padding:0;margin:0}
.footer-contact li{display:grid;grid-template-columns:20px 1fr;column-gap:13px;align-items:start;margin-bottom:15px;font-size:.95rem;line-height:1.5}
.footer-contact svg{width:18px;height:18px;color:var(--red);margin-top:3px}
.footer-contact li>span{min-width:0}
.footer-contact b{color:#fff;font-weight:600}
/* social */
.footer-social{display:flex;gap:10px;margin-top:20px}
.footer-social a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:#fff}
.footer-social a:hover{background:var(--red)}
.footer-social svg{width:19px;height:19px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:48px;padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:#8d8a94;font-size:.85rem}
.footer-bottom a{color:#a7a4ad}

/* ---------- Reveal-on-scroll ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr);gap:36px 20px}
  .steps{grid-template-columns:repeat(2,1fr);row-gap:40px}
  .contact-grid{grid-template-columns:1fr}
}
/* Nav klapt naar hamburger vanaf tablet-breedte (ruimer door extra menu-item) */
@media(max-width:1140px){
  .nav-toggle{display:block}
  .nav-links{position:fixed;inset:122px 14px auto 14px;flex-direction:column!important;background:#fff;padding:14px;border-radius:var(--radius);box-shadow:var(--shadow-lg);display:none!important;align-items:stretch!important;gap:4px}
  body.nav-open .nav-links{display:flex!important}
  .main-nav .nav-links>li>a{display:block;padding:13px 16px;font-size:1rem}
  .nav-cta{margin-left:0;text-align:center}
}
@media(max-width:1180px){
  .tb-ticker{display:none}
}
@media(max-width:780px){
  .section{padding:64px 0}
  .topbar-inner{flex-direction:column;justify-content:center;height:auto;padding:8px 0;gap:4px}
  .topbar .tb-contact{justify-content:center}
  .topbar .tb-contact span:not(:first-child){display:none}
  .cta-band{padding:40px 24px}
  .footer-bottom{justify-content:center;text-align:center;gap:8px}
  .cta-band-meta{gap:12px}
}
@media(max-width:620px){
  .footer-grid{grid-template-columns:1fr;gap:32px}
}
@media(max-width:560px){
  .trust-grid,.stats{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
}

/* ---------- Sticky mobiele actiebalk ---------- */
.mobile-bar{display:none}
@media(max-width:780px){
  .mobile-bar{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;position:fixed;left:0;right:0;bottom:0;z-index:80;background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(31,29,33,.12)}
  .mobile-bar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:9px 6px;font-family:var(--font-head);font-weight:600;font-size:.72rem;color:var(--ink)}
  .mobile-bar a svg{width:21px;height:21px}
  .mobile-bar a+a{border-left:1px solid var(--line)}
  .mobile-bar .mb-wa{color:#1da851}
  .mobile-bar .mb-cta{background:var(--red);color:#fff}
  body{padding-bottom:60px}
}

/* ---------- Snelle prijsindicatie-widget ---------- */
.qe-card{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;background:var(--ink);color:#e9e7ea;border-radius:var(--radius-lg);padding:44px;overflow:hidden;position:relative}
.qe-card .eyebrow{color:#fff}.qe-card .eyebrow::before{background:var(--red)}
.qe-card h2{color:#fff;margin-bottom:12px}
.qe-intro p{color:rgba(255,255,255,.8)}
.qe-tool{display:flex;flex-direction:column;gap:20px}
.qe-slider{display:block;font-family:var(--font-head);font-weight:600;font-size:.95rem;color:#fff}
.qe-slider output{float:right;color:var(--primary);filter:brightness(1.4)}
.qe-slider input[type=range]{width:100%;margin-top:10px;accent-color:var(--red)}
.qe-result{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:20px;text-align:center;margin-top:4px}
.qe-label{display:block;font-size:.82rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.06em}
.qe-price{display:block;font-family:var(--font-head);font-weight:800;font-size:1.9rem;color:#fff;margin:6px 0}
.qe-note{display:block;font-size:.76rem;color:rgba(255,255,255,.5)}
@media(max-width:780px){.qe-card{grid-template-columns:1fr;gap:28px;padding:32px}}

/* ---------- Specificatie-tabel (dienst) ---------- */
.spec-table{width:100%;border-collapse:collapse;margin:0 0 8px;font-size:.96rem}
.spec-table th,.spec-table td{text-align:left;padding:12px 4px;border-bottom:1px solid var(--line);vertical-align:top}
.spec-table th{width:42%;font-family:var(--font-head);font-weight:600;color:var(--ink)}
.spec-table td{color:var(--muted)}

/* ---------- Regio-overzicht ---------- */
.region-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.region-card{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;font-family:var(--font-head);font-weight:600;color:var(--ink);transition:transform .15s,box-shadow .15s,border-color .15s}
.region-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:transparent}
.region-card svg{width:24px;height:24px;color:var(--red);flex-shrink:0}
.region-card em{margin-left:auto;color:var(--red);font-style:normal;font-size:1.2rem}

/* ---------- Toegankelijkheid: zichtbare focus voor toetsenbordgebruikers ---------- */
:focus-visible{outline:3px solid var(--primary);outline-offset:2px;border-radius:4px}
.btn:focus-visible{outline:3px solid var(--primary);outline-offset:3px}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--primary);outline-offset:2px}

/* ---------- GDPR-cookiebanner ---------- */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:120;background:var(--ink);color:#e9e7ea;box-shadow:0 -8px 28px rgba(31,29,33,.28);border-top:2px solid var(--primary);animation:cookieUp .3s ease}
.cookie-banner[hidden]{display:none}
@keyframes cookieUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.cookie-inner{display:flex;align-items:center;gap:22px;padding:16px 0;flex-wrap:wrap}
.cookie-text{margin:0;font-size:.9rem;line-height:1.5;flex:1 1 360px;color:rgba(255,255,255,.85)}
.cookie-text a{color:#fff;text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex-shrink:0}
@media(max-width:560px){
  .cookie-inner{padding:14px 0}
  .cookie-actions{width:100%}
  .cookie-actions .btn{flex:1}
}

/* ---------- Regio: interne links naar andere werkgebieden ---------- */
.container.narrow{max-width:860px}
.region-links{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.region-links a{display:inline-block;padding:9px 16px;background:#fff;border:1px solid var(--line);border-radius:999px;font-size:.9rem;font-weight:600;color:var(--ink);transition:border-color .15s,color .15s,transform .15s}
.region-links a:hover{border-color:var(--red);color:var(--red);transform:translateY(-2px)}
.region-links .region-links-all{background:var(--red);color:#fff;border-color:var(--red)}
.region-links .region-links-all:hover{color:#fff;filter:brightness(1.05)}

/* ---------- Prijspagina ---------- */
.price-grid{display:grid;gap:22px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.price-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s}
.price-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.price-card.is-popular{border-color:var(--red)}
.price-badge{position:absolute;top:12px;right:12px;z-index:1;background:var(--red);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:5px 11px;border-radius:999px;box-shadow:0 2px 8px rgba(0,0,0,.18)}
.price-media{height:170px;background:#e7e5e4 center/cover no-repeat}
.price-body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.price-body h3{margin:0}
.price-desc{color:var(--muted);font-size:.9rem;margin:0;flex:1}
.price-from{display:flex;align-items:baseline;gap:8px;margin:4px 0 2px}
.price-from span{font-size:.85rem;color:var(--muted)}
.price-from strong{font-family:var(--font-head);font-size:1.7rem;color:var(--red);line-height:1}
.price-from small{font-size:.75rem;color:var(--muted)}
.btn-block{display:block;width:100%;text-align:center}
.price-factors{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.price-factors li{position:relative;padding:14px 16px 14px 48px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--muted)}
.price-factors li::before{content:"";position:absolute;left:16px;top:16px;width:18px;height:18px;border-radius:50%;background:var(--red);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/13px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/13px no-repeat}
.price-factors li strong{color:var(--ink)}

/* ---------- Team (Over ons) ---------- */
.team-grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.team-card{text-align:center}
.team-photo{width:140px;height:140px;border-radius:50%;margin:0 auto 16px;background:#e7e5e4 center/cover no-repeat;box-shadow:var(--shadow-sm)}
.team-photo--ph{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--secondary),#46434a)}
.team-photo--ph span{font-family:var(--font-head);font-weight:800;font-size:2.4rem;color:#fff;letter-spacing:.02em}
.team-card h3{margin:0 0 2px}
.team-role{display:block;color:var(--red);font-family:var(--font-head);font-weight:600;font-size:.92rem}
.team-bio{color:var(--muted);font-size:.9rem;margin:8px 0 0}

/* ---------- Garanties & zekerheden ---------- */
.guarantees{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}
.guarantee{display:flex;gap:15px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 20px;transition:transform .15s,box-shadow .15s,border-color .15s}
.guarantee:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:transparent}
.g-ic{flex-shrink:0;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--red) 12%,#fff);color:var(--red)}
.g-ic svg{width:22px;height:22px}
.guarantee b{display:block;font-family:var(--font-head);color:var(--ink);font-size:1.02rem;line-height:1.2}
.guarantee span{display:block;color:var(--muted);font-size:.85rem;margin-top:2px}

/* ---------- Merken / partners-balk ---------- */
.brand-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:34px 48px}
.brand-bar img{height:46px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.7;transition:filter .2s,opacity .2s}
.brand-bar img:hover{filter:grayscale(0);opacity:1}
.brand-groups{display:flex;flex-direction:column;gap:22px;max-width:920px;margin:0 auto;text-align:center}
.brand-group h3{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 12px}
.brand-group .brand-bar{gap:10px}
.brand-chip{display:inline-block;padding:8px 16px;background:#fff;border:1px solid var(--line);border-radius:999px;font-family:var(--font-head);font-weight:600;font-size:.9rem;color:var(--ink);transition:border-color .15s,color .15s}
a.brand-chip:hover{border-color:var(--red);color:var(--red)}

/* ---------- Trust-rij bij formulieren (risico-omkeer) ---------- */
.form-trust{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:8px 20px}
.form-trust li{position:relative;padding-left:23px;font-size:.86rem;font-weight:600;color:var(--ink)}
.form-trust li::before{content:"";position:absolute;left:0;top:0;width:16px;height:16px;border-radius:50%;background:var(--red);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/12px no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/12px no-repeat}

/* ===== Toegankelijkheid: skip-link ===================================== */
.skip-link{position:absolute;left:-9999px;top:0;z-index:1000;background:var(--primary,#D8261E);color:#fff;
  padding:12px 20px;border-radius:0 0 8px 0;font-weight:700;text-decoration:none}
.skip-link:focus{left:0}
