/* =========================================================================
   Uni Schoonmaak — style.css  (v2, premium redesign)
   Display: Sora · Body: Inter. Levendige navy + cyan/lime, glas, bubbels.
   Mobile-first, geen frameworks.
   ====================================================================== */

:root{
  /* Donker fundament */
  --ink-900:#06121f;
  --ink-800:#0a1a2c;
  --ink-700:#0f2740;
  --navy:#0b2238;
  /* Accenten */
  --cyan-600:#0bb6c4;
  --cyan-500:#19d3df;
  --cyan-400:#52e6ef;
  --teal-500:#16c0bd;
  --lime-500:#9ff04a;
  --lime-400:#b6f96a;
  --mint:#c9fbe5;
  /* Neutraal */
  --ink:#0f2336;
  --body:#3c5366;
  --muted:#6c8497;
  --line:#e6edf2;
  --line-2:#eef4f8;
  --bg:#ffffff;
  --bg-soft:#f3f8fb;
  --bg-tint:#eaf6f8;
  --white:#fff;
  /* Effecten */
  --grad-bright:linear-gradient(120deg,var(--cyan-500),var(--teal-500) 55%,var(--lime-500));
  --grad-cool:linear-gradient(135deg,var(--cyan-500),#3aa0e6);
  --grad-dark:radial-gradient(130% 120% at 80% -10%,#143a5c 0%,var(--ink-800) 45%,var(--ink-900) 100%);
  --shadow-sm:0 2px 10px rgba(8,28,46,.06);
  --shadow:0 16px 40px -12px rgba(9,30,52,.22);
  --shadow-lg:0 38px 80px -24px rgba(9,30,52,.34);
  --glow:0 14px 40px -8px rgba(25,211,223,.5);
  --radius:18px;
  --radius-lg:30px;
  --radius-sm:12px;
  --maxw:1200px;
  --space:clamp(3.6rem,7vw,7rem);
  --fdisp:'Sora',system-ui,-apple-system,'Segoe UI',sans-serif;
  --fbody:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --noise:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  margin:0;font-family:var(--fbody);color:var(--body);background:var(--bg);
  font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;width:100%;
}
/* Clip i.p.v. hidden waar ondersteund: voorkomt horizontaal scrollen door het
   off-canvas mobiele menu, zónder de sticky header te breken. */
@supports (overflow:clip){
  html,body{overflow-x:clip}
}
img{max-width:100%;height:auto;display:block}
a{color:var(--cyan-600);text-decoration:none;transition:color .18s var(--ease)}
a:hover{color:var(--teal-500)}
h1,h2,h3,h4{font-family:var(--fdisp);line-height:1.1;color:var(--ink);font-weight:800;letter-spacing:-.02em;margin:0 0 .5em}
h1{font-size:clamp(2.3rem,5.4vw,4rem)}
h2{font-size:clamp(1.75rem,3.4vw,2.7rem)}
h3{font-size:1.22rem;letter-spacing:-.01em}
p{margin:0 0 1rem}
ul,ol{margin:0;padding:0;list-style:none}
strong{font-weight:700;color:var(--ink)}
::selection{background:var(--lime-400);color:var(--ink-900)}
:focus-visible{outline:3px solid var(--cyan-500);outline-offset:3px;border-radius:6px}

.grad-text{background:var(--grad-bright);-webkit-background-clip:text;background-clip:text;color:transparent}

/* Layout */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.1rem,4vw,2.2rem)}
.container--narrow{max-width:840px}
.section{position:relative;padding:var(--space) 0}
.section--center{text-align:center}
.section--trust{background:var(--bg-soft)}
.section--steps{background:var(--grad-dark);color:#c7dcee;overflow:hidden}
.section--regions{background:radial-gradient(120% 80% at 100% 0,var(--bg-tint),var(--bg-soft))}
.section--reviews{background:var(--bg-soft)}
.section--faq{background:var(--bg-soft)}
.section__head{max-width:720px;margin:0 auto 3rem;text-align:center}
.section__title{margin-bottom:.6rem}
.section--steps .section__title{color:#fff}
.section__intro{color:var(--muted);font-size:1.08rem}
.section--steps .section__intro{color:#9fc0db}
.section__foot{text-align:center;margin-top:2.8rem}

.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--fbody);font-weight:700;font-size:.78rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--teal-500);
  background:#fff;border:1px solid var(--line);padding:.5rem .95rem;border-radius:999px;margin-bottom:1.1rem;box-shadow:var(--shadow-sm)}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--grad-bright)}
.eyebrow--light{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18);color:var(--mint);backdrop-filter:blur(6px)}

/* Icons */
.icon{width:24px;height:24px;flex:none}
.icon--sm{width:18px;height:18px}

/* Buttons */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--fdisp);font-weight:700;font-size:.98rem;line-height:1;padding:1rem 1.6rem;border-radius:999px;
  border:1.5px solid transparent;cursor:pointer;transition:transform .22s var(--ease),box-shadow .22s var(--ease),background .22s,color .22s;text-align:center;white-space:nowrap}
.btn .icon{width:20px;height:20px}
.btn--primary{background:var(--grad-bright);color:var(--ink-900);box-shadow:var(--glow);background-size:140% 140%}
.btn--primary:hover{color:var(--ink-900);transform:translateY(-3px);box-shadow:0 20px 48px -10px rgba(25,211,223,.65);background-position:100% 50%}
.btn--ghost{background:rgba(255,255,255,.07);color:#fff;border-color:rgba(255,255,255,.3);backdrop-filter:blur(6px)}
.btn--ghost:hover{background:rgba(255,255,255,.16);color:#fff;transform:translateY(-3px)}
.btn--outline{background:#fff;color:var(--ink);border-color:var(--line)}
.btn--outline:hover{border-color:var(--cyan-500);color:var(--teal-500);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.btn--whatsapp{background:#25d366;color:#fff}
.btn--whatsapp:hover{background:#1eb858;color:#fff;transform:translateY(-3px)}
.btn--lg{padding:1.15rem 2rem;font-size:1.05rem}
.btn--sm{padding:.65rem 1.15rem;font-size:.9rem}
.btn--block{display:flex;width:100%}

/* Skip link */
.skip-link{position:absolute;left:-999px;top:0;z-index:1000;background:var(--ink-900);color:#fff;padding:.8rem 1.2rem;border-radius:0 0 10px 0}
.skip-link:focus{left:0;color:#fff}

/* Topbar */
.topbar{background:var(--ink-900);color:#9fc0db;font-size:.84rem}
.topbar__inner{display:flex;gap:1.5rem;align-items:center;justify-content:center;padding:.55rem 0;flex-wrap:wrap}
.topbar__item{display:inline-flex;align-items:center;gap:.45rem;color:#9fc0db}
.topbar__item .icon{color:var(--cyan-400)}
.topbar__phone{margin-left:auto;color:#fff;font-weight:600}
.topbar__phone:hover{color:var(--cyan-400)}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid transparent;transition:box-shadow .25s,border-color .25s,background .25s}
.site-header.is-scrolled{box-shadow:0 10px 30px -16px rgba(9,30,52,.25);border-color:var(--line);background:rgba(255,255,255,.92)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:78px}
.brand{display:inline-flex;align-items:center;gap:.65rem;font-family:var(--fdisp);font-size:1.24rem;font-weight:800;color:var(--ink)}
.brand__mark{position:relative;display:grid;place-items:center;width:46px;height:46px;border-radius:14px;
  background:var(--grad-bright);color:var(--ink-900);box-shadow:var(--glow)}
.brand__mark::after{content:"";position:absolute;width:9px;height:9px;border-radius:50%;background:#fff;top:7px;right:8px;opacity:.85}
.brand__mark .icon{width:25px;height:25px}
.brand__text{letter-spacing:-.02em}
.brand__text strong{color:var(--teal-500)}
.brand--footer{color:#fff;margin-bottom:1rem}
.brand--footer .brand__text{color:#fff}

.main-nav__list{display:flex;align-items:center;gap:.2rem}
.main-nav a{display:inline-block;padding:.6rem .9rem;border-radius:10px;color:var(--ink);font-weight:600;font-size:.97rem;transition:color .18s,background .18s}
.main-nav a:hover,.main-nav a.is-active{color:var(--teal-500);background:var(--bg-tint)}
.main-nav__cta{margin-left:.6rem}

.nav-toggle{display:none;background:none;border:0;color:var(--ink);padding:.4rem;cursor:pointer}
.nav-toggle .icon{width:30px;height:30px}
.nav-toggle__close{display:none}
.nav-toggle[aria-expanded="true"] .nav-toggle__open{display:none}
.nav-toggle[aria-expanded="true"] .nav-toggle__close{display:block}

/* ============================ HERO ============================ */
.hero{position:relative;background:var(--grad-dark);color:#fff;overflow:hidden;
  padding:clamp(3rem,6vw,6rem) 0 clamp(5rem,9vw,8rem)}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(40% 50% at 8% 12%,rgba(25,211,223,.28),transparent 60%),
  radial-gradient(36% 46% at 88% 78%,rgba(159,240,74,.20),transparent 62%),
  radial-gradient(30% 40% at 70% 8%,rgba(58,160,230,.22),transparent 60%);pointer-events:none}
.hero::after{content:"";position:absolute;inset:0;background-image:var(--noise);opacity:.04;mix-blend-mode:overlay;pointer-events:none}
.hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.hero__title{color:#fff;margin-bottom:1.1rem;letter-spacing:-.03em}
.hero__lead{font-size:1.18rem;color:#bcd6ea;max-width:40ch;margin-bottom:2rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem}
.hero__actions--center{justify-content:center}
.hero__usps{display:flex;flex-wrap:wrap;gap:.7rem 1.5rem;margin-top:2.2rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.12)}
.hero__usps li{display:inline-flex;align-items:center;gap:.5rem;color:#d6e7f3;font-weight:600;font-size:.93rem}
.hero__usps .icon{color:var(--lime-400)}

/* Hero media: organische vorm + ring + bubbels */
.hero__media{position:relative;z-index:2}
.hero__media img{position:relative;z-index:2;width:100%;object-fit:cover;background:#13314c;
  border-radius:46% 54% 56% 44%/52% 46% 54% 48%;box-shadow:var(--shadow-lg);
  animation:morph 16s ease-in-out infinite}
@keyframes morph{
  0%,100%{border-radius:46% 54% 56% 44%/52% 46% 54% 48%}
  33%{border-radius:58% 42% 40% 60%/46% 58% 42% 54%}
  66%{border-radius:42% 58% 60% 40%/56% 44% 56% 44%}
}
.hero__media::before{content:"";position:absolute;inset:-22px;border:2px dashed rgba(255,255,255,.18);
  border-radius:50%;z-index:1;animation:spin 40s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.hero__badge{position:absolute;z-index:3;left:-8px;bottom:30px;background:rgba(255,255,255,.92);color:var(--ink);
  border-radius:18px;padding:.95rem 1.15rem;box-shadow:var(--shadow);display:flex;flex-direction:column;line-height:1.1;
  backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.6)}
.hero__badge-num{font-family:var(--fdisp);font-size:1.8rem;font-weight:800;color:var(--teal-500)}
.hero__badge-label{font-size:.78rem;color:var(--muted);max-width:12ch}
.hero__chip{position:absolute;z-index:3;right:-6px;top:34px;display:flex;align-items:center;gap:.55rem;
  background:rgba(255,255,255,.92);border-radius:999px;padding:.55rem .9rem;box-shadow:var(--shadow);font-weight:700;
  font-size:.85rem;color:var(--ink);backdrop-filter:blur(8px)}
.hero__chip .dot{width:9px;height:9px;border-radius:50%;background:var(--lime-500);box-shadow:0 0 0 4px rgba(159,240,74,.25)}
/* zwevende bubbels */
.bubbles{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.bubbles span{position:absolute;bottom:-40px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.5),rgba(25,211,223,.12));
  border:1px solid rgba(255,255,255,.14);animation:rise linear infinite}
.bubbles span:nth-child(1){left:6%;width:18px;height:18px;animation-duration:13s}
.bubbles span:nth-child(2){left:20%;width:30px;height:30px;animation-duration:18s;animation-delay:2s}
.bubbles span:nth-child(3){left:38%;width:12px;height:12px;animation-duration:11s;animation-delay:1s}
.bubbles span:nth-child(4){left:62%;width:24px;height:24px;animation-duration:16s;animation-delay:3s}
.bubbles span:nth-child(5){left:78%;width:16px;height:16px;animation-duration:14s;animation-delay:1.5s}
.bubbles span:nth-child(6){left:90%;width:34px;height:34px;animation-duration:20s;animation-delay:4s}
@keyframes rise{to{transform:translateY(-118vh) translateX(20px);opacity:0}}

/* Golf-overgang onderaan hero */
.hero-wave{position:absolute;left:0;right:0;bottom:-1px;z-index:2;line-height:0;color:var(--bg)}
.hero-wave svg{width:100%;height:clamp(40px,6vw,90px);display:block}

/* Logos / vertrouwensstrip */
.logos{display:flex;flex-wrap:wrap;gap:1.4rem 2.4rem;align-items:center;justify-content:center;opacity:.85}
.logos span{font-family:var(--fdisp);font-weight:700;color:var(--muted);font-size:1.05rem;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:.5rem}
.logos .icon{color:var(--teal-500)}

/* Page hero (binnenpagina's) */
.page-hero{position:relative;background:var(--grad-dark);color:#fff;overflow:hidden;padding:clamp(2.8rem,5vw,4.4rem) 0 clamp(3rem,5vw,4.6rem)}
.page-hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(40% 60% at 6% 10%,rgba(25,211,223,.22),transparent 60%),
  radial-gradient(40% 60% at 94% 90%,rgba(159,240,74,.15),transparent 60%);pointer-events:none}
.page-hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:2.8rem;align-items:center}
.page-hero--compact{padding-bottom:clamp(2.4rem,4vw,3.4rem)}
.page-hero .eyebrow{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18);color:var(--mint)}
.page-hero__title{color:#fff;position:relative;z-index:2}
.page-hero__lead{color:#bcd6ea;font-size:1.12rem;max-width:64ch;margin-bottom:1.6rem;position:relative;z-index:2}
.page-hero__lead a{color:var(--cyan-400);text-decoration:underline;text-underline-offset:3px}
.page-hero__media{position:relative;z-index:2}
.page-hero__media img{width:100%;object-fit:cover;background:#13314c;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  border:6px solid rgba(255,255,255,.08)}

/* Breadcrumbs */
.breadcrumbs{padding:1.1rem 0 .2rem}
.breadcrumbs__list{display:flex;flex-wrap:wrap;gap:.4rem;font-size:.85rem;color:var(--muted)}
.breadcrumbs__item:not(:last-child)::after{content:"›";margin-left:.5rem;color:var(--line)}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--teal-500)}
.breadcrumbs [aria-current]{color:var(--ink);font-weight:600}

/* Trust grid */
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.trust-card{position:relative;display:flex;gap:1rem;align-items:flex-start;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:1.5rem;transition:transform .25s var(--ease),box-shadow .25s,border-color .25s}
.trust-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.trust-card__icon{display:grid;place-items:center;width:50px;height:50px;border-radius:14px;flex:none;
  background:var(--bg-tint);color:var(--teal-500);transition:background .25s,color .25s}
.trust-card:hover .trust-card__icon{background:var(--grad-bright);color:var(--ink-900)}
.trust-card__title{font-size:1.05rem;margin-bottom:.25rem}
.trust-card p{margin:0;color:var(--muted);font-size:.92rem;line-height:1.6}

/* ============================ Cards ============================ */
.cards{display:grid;gap:1.5rem}
.cards--services{grid-template-columns:repeat(3,1fr)}
.cards--cities{grid-template-columns:repeat(3,1fr)}
.cards--provinces{grid-template-columns:repeat(3,1fr)}
.cards--reviews{grid-template-columns:repeat(3,1fr)}
.card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;overflow:hidden;
  transition:transform .26s var(--ease),box-shadow .26s var(--ease),border-color .26s}
.card::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--grad-bright);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.card--service:hover,.card--city:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.card--service:hover::before,.card--city:hover::before{transform:scaleX(1)}
.card__icon{position:relative;display:grid;place-items:center;width:58px;height:58px;border-radius:16px;margin-bottom:1.1rem;
  background:var(--bg-tint);color:var(--teal-500);transition:transform .3s var(--ease)}
.card--service:hover .card__icon,.card--city:hover .card__icon{transform:rotate(-6deg) scale(1.06)}
.card__icon .icon{width:30px;height:30px}
.card__title{margin-bottom:.5rem;font-size:1.18rem}
.card--service .card__title,.card--city .card__title{color:var(--ink)}
.card__text{color:var(--muted);font-size:.94rem;margin-bottom:1.1rem}
.card__link{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--fdisp);font-weight:700;color:var(--teal-500);font-size:.9rem}
.card--service:hover .card__link,.card--city:hover .card__link{gap:.7rem}
.card--province{padding:1.6rem 1.7rem}
.card--province .card__title{font-size:1.2rem;display:flex;margin-bottom:.4rem}
.card--province .card__title a{display:inline-flex;align-items:center;gap:.5rem;color:var(--ink)}
.card--province .card__title .icon{color:var(--teal-500)}
.card__cities{display:flex;flex-wrap:wrap;gap:.4rem .9rem;margin:.7rem 0 1.1rem}
.card__cities a{color:var(--muted);font-size:.92rem}
.card__cities a:hover{color:var(--teal-500)}

/* Chips */
.chip-grid{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center}
.chip{display:inline-flex;align-items:center;gap:.45rem;background:#fff;border:1px solid var(--line);
  padding:.65rem 1.1rem;border-radius:999px;font-weight:600;font-size:.92rem;color:var(--ink);transition:transform .2s,border-color .2s,background .2s,box-shadow .2s}
.chip .icon{color:var(--teal-500)}
.chip:hover{border-color:transparent;background:var(--ink-800);color:#fff;transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.chip:hover .icon{color:var(--lime-400)}
/* Spoed: compacte balk */
.section--spoed{background:var(--bg-soft)}
.eyebrow--spoed{background:var(--lime-500);color:var(--ink-900);border-color:transparent;box-shadow:0 6px 18px -6px rgba(159,240,74,.7)}
.eyebrow--spoed::before{background:var(--ink-900)}
.spoed-bar{position:relative;display:flex;gap:2rem;align-items:center;justify-content:space-between;flex-wrap:wrap;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.4rem);
  box-shadow:var(--shadow-sm);overflow:hidden}
.spoed-bar::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--grad-bright)}
.spoed-bar__text{flex:1 1 320px;margin-bottom:0}
.spoed-bar__title{margin:.7rem 0 .4rem;font-size:clamp(1.4rem,2.6vw,1.9rem)}
.spoed-bar__text p{margin:0;color:var(--muted);max-width:52ch}
.spoed-bar__actions{display:flex;flex-direction:column;gap:.7rem;align-items:stretch;flex:0 0 auto}
.spoed-bar__more{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;font-family:var(--fdisp);font-weight:700;color:var(--teal-500);font-size:.92rem}
@media (max-width:620px){
  .spoed-bar__actions{width:100%}
}

/* ============================ Steps ============================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem;position:relative;z-index:2}
.step{position:relative;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);padding:1.8rem 1.4rem;backdrop-filter:blur(4px);transition:transform .25s,background .25s}
.step:hover{transform:translateY(-6px);background:rgba(255,255,255,.07)}
.step__num{display:grid;place-items:center;width:50px;height:50px;border-radius:14px;font-family:var(--fdisp);font-weight:800;font-size:1.25rem;
  background:var(--grad-bright);color:var(--ink-900);margin-bottom:1.1rem;box-shadow:var(--glow)}
.step__title{color:#fff;font-size:1.1rem;margin-bottom:.4rem}
.step__text{color:#9fc0db;font-size:.93rem;margin:0}
.section--steps .section__head{position:relative;z-index:2}

/* Before/after */
.beforeafter{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.beforeafter__item{position:relative;margin:0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.beforeafter__item img{width:100%;aspect-ratio:3/2;object-fit:cover;background:#dde9f1;transition:transform .5s var(--ease)}
.beforeafter__item:hover img{transform:scale(1.04)}
.beforeafter figcaption{position:absolute;left:14px;top:14px}
.tag{display:inline-block;padding:.35rem .9rem;border-radius:999px;font-family:var(--fdisp);font-weight:700;font-size:.78rem;color:#fff}
.tag--before{background:rgba(10,26,44,.82);backdrop-filter:blur(4px)}
.tag--after{background:var(--grad-bright);color:var(--ink-900)}

/* Reviews */
.review{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.9rem;margin:0;box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s}
.review:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.review::after{content:"\201D";position:absolute;right:18px;top:6px;font-family:var(--fdisp);font-size:5rem;line-height:1;color:var(--bg-tint)}
.review__stars{display:flex;gap:.1rem;color:#ffb22e;margin-bottom:.9rem;position:relative;z-index:1}
.review__stars .icon{color:#ffb22e}
.review__text{font-size:1.04rem;color:var(--ink);margin:0 0 1.2rem;line-height:1.6;position:relative;z-index:1}
.review__author{display:flex;flex-direction:column}
.review__author strong{font-family:var(--fdisp);color:var(--ink)}
.review__author span{color:var(--muted);font-size:.87rem}

/* Why */
.why{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.why--reverse .why__media{order:2}
.why__media{position:relative}
.why__media img{border-radius:var(--radius-lg);box-shadow:var(--shadow);width:100%;object-fit:cover;background:#dde9f1}
.why__media::after{content:"";position:absolute;inset:auto -16px -16px auto;width:60%;height:60%;z-index:-1;
  border-radius:var(--radius-lg);background:var(--grad-bright);opacity:.16;filter:blur(4px)}
.check-list{display:grid;gap:1rem;margin:1.4rem 0 2rem}
.check-list li{display:flex;gap:.8rem;align-items:flex-start}
.check-list .icon{flex:none;margin-top:1px;width:26px;height:26px;padding:4px;border-radius:8px;background:var(--bg-tint);color:var(--teal-500)}
.check-list--sm li{font-size:.94rem}
.check-list--sm .icon{width:22px;height:22px}

/* Content layout (dienst/combinatie) */
.content-grid{display:grid;grid-template-columns:1fr 340px;gap:clamp(2rem,4vw,3.4rem);align-items:start}
.content-main h2{margin-top:2.4rem}
.content-main h2:first-child{margin-top:0}
.content-main p{color:var(--body)}
.task-list{display:grid;gap:.7rem;margin:1.1rem 0 1.6rem}
.task-list li{display:flex;gap:.7rem;align-items:flex-start;color:var(--body)}
.task-list .icon{color:var(--teal-500);flex:none;margin-top:3px}
.benefit-grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin:1.1rem 0 1.6rem}
.benefit{display:flex;gap:.6rem;align-items:flex-start;background:var(--bg-soft);border:1px solid var(--line);
  border-radius:12px;padding:.95rem 1.1rem;font-weight:600;font-size:.95rem;color:var(--ink);transition:transform .2s,box-shadow .2s}
.benefit:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.benefit .icon{color:var(--teal-500);flex:none}

.content-aside{position:sticky;top:100px;display:grid;gap:1.3rem}
.aside-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem}
.aside-card h3{margin-bottom:.9rem}
.aside-card--cta{background:var(--grad-dark);color:#fff;border:0;position:relative;overflow:hidden}
.aside-card--cta::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 80% 10%,rgba(25,211,223,.3),transparent 60%)}
.aside-card--cta>*{position:relative;z-index:1}
.aside-card--cta h3{color:#fff}
.aside-card--cta p{color:#bcd6ea;font-size:.94rem}
.aside-card--cta .btn{margin-bottom:.6rem}
.aside-card__phone{display:flex;align-items:center;gap:.5rem;font-family:var(--fdisp);font-weight:700;color:#fff;justify-content:center;margin-top:.5rem}
.aside-card--cta .aside-card__phone{color:var(--cyan-400)}
.aside-links{display:grid;gap:.1rem}
.aside-links a{display:flex;align-items:center;gap:.5rem;padding:.6rem 0;color:var(--ink);font-weight:600;font-size:.95rem;border-bottom:1px solid var(--line)}
.aside-links a:last-child{border-bottom:0}
.aside-links a:hover{color:var(--teal-500)}
.aside-links .icon{color:var(--teal-500)}
.aside-card--stats .stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;text-align:center}
.stats li{background:var(--bg-soft);border-radius:14px;padding:1.1rem}
.stats strong{display:block;font-family:var(--fdisp);font-size:1.9rem;color:var(--teal-500);line-height:1}
.stats span{font-size:.82rem;color:var(--muted)}
.aside-card--contact .aside-card__phone{color:var(--ink);justify-content:flex-start;margin-bottom:.7rem}
.aside-card--contact .aside-card__phone .icon{color:var(--teal-500)}

/* CTA inline */
.cta-inline{position:relative;background:var(--grad-dark);color:#fff;border-radius:var(--radius-lg);overflow:hidden;
  padding:clamp(2rem,4vw,3.2rem);display:flex;gap:1.6rem;align-items:center;justify-content:space-between;flex-wrap:wrap;box-shadow:var(--shadow)}
.cta-inline::before{content:"";position:absolute;inset:0;background:
  radial-gradient(40% 80% at 100% 0,rgba(25,211,223,.28),transparent 60%),
  radial-gradient(40% 90% at 0 100%,rgba(159,240,74,.18),transparent 60%)}
.cta-inline>*{position:relative;z-index:1}
.cta-inline__title{color:#fff;margin-bottom:.4rem}
.cta-inline__text{color:#bcd6ea;margin:0;max-width:48ch}
.cta-inline__actions{display:flex;gap:.9rem;flex-wrap:wrap}

/* CTA band (footer top) */
.cta-band{position:relative;background:var(--ink-900);color:#fff;padding:clamp(2.8rem,5vw,4rem) 0;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:
  radial-gradient(30% 80% at 12% 30%,rgba(25,211,223,.2),transparent 60%),
  radial-gradient(34% 90% at 92% 80%,rgba(159,240,74,.14),transparent 60%)}
.cta-band__inner{position:relative;z-index:1;display:flex;gap:2rem;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cta-band__title{color:#fff;margin-bottom:.4rem}
.cta-band__text{color:#9fc0db;margin:0;max-width:50ch}
.cta-band__actions{display:flex;gap:.9rem;flex-wrap:wrap}

/* Accordion */
.accordion{display:grid;gap:.9rem}
.accordion__item{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.accordion__item:has([aria-expanded="true"]){border-color:transparent;box-shadow:var(--shadow)}
.accordion__head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.25rem 1.4rem;background:none;border:0;cursor:pointer;text-align:left;font-family:var(--fdisp);font-weight:700;
  font-size:1.03rem;color:var(--ink)}
.accordion__chevron{transition:transform .25s var(--ease);color:var(--teal-500);flex:none}
.accordion__head[aria-expanded="true"] .accordion__chevron{transform:rotate(90deg)}
.accordion__panel{padding:0 1.4rem 1.3rem}
.accordion__panel p{margin:0;color:var(--body)}

/* ============================ Forms ============================ */
.form-layout{display:grid;grid-template-columns:1fr 330px;gap:2.2rem;align-items:start}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.4rem);box-shadow:var(--shadow-sm)}
.form-aside{display:grid;gap:1.3rem;position:sticky;top:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{margin-bottom:1.2rem;display:flex;flex-direction:column}
.field label,.field legend{font-weight:600;font-size:.92rem;margin-bottom:.45rem;color:var(--ink)}
.field input,.field select,.field textarea{font:inherit;font-size:1rem;padding:.85rem .95rem;border:1.5px solid var(--line);
  border-radius:12px;background:var(--bg-soft);color:var(--ink);width:100%;transition:border-color .18s,box-shadow .18s,background .18s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--cyan-500);background:#fff;box-shadow:0 0 0 4px rgba(25,211,223,.16)}
.field textarea{resize:vertical;min-height:128px}
.field--error input,.field--error select,.field--error textarea{border-color:#e0564f;background:#fff6f5}
.field__msg{color:#cf3b34;font-size:.84rem;margin-top:.35rem}
.req{color:#e0564f}
.field--radio{border:0;padding:0;margin:0 0 1.2rem}
.radio-group{display:flex;gap:.6rem;flex-wrap:wrap}
.radio{display:inline-flex;align-items:center;gap:.45rem;border:1.5px solid var(--line);border-radius:12px;
  padding:.65rem 1.1rem;cursor:pointer;font-weight:600;font-size:.95rem;color:var(--ink);transition:border-color .2s,background .2s}
.radio input{width:auto;accent-color:var(--teal-500)}
.radio:has(input:checked){border-color:var(--cyan-500);background:var(--bg-tint);color:var(--teal-500)}
.field--check .checkbox{flex-direction:row;display:flex;gap:.6rem;align-items:flex-start;font-weight:500;color:var(--body);font-size:.92rem}
.checkbox input{width:auto;margin-top:3px;accent-color:var(--teal-500)}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.85rem;margin:1.1rem 0 0;justify-content:center}
.form-note .icon{color:var(--teal-500)}
.alert{padding:1rem 1.2rem;border-radius:12px;margin-bottom:1.3rem;font-size:.95rem}
.alert--error{background:#fdecea;border:1px solid #f5c6c2;color:#a3322b}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:2.2rem;align-items:start}
.contact-info{display:grid;gap:1.1rem}
.contact-info__item{display:flex;gap:1.1rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;transition:transform .2s,box-shadow .2s}
.contact-info__item:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.contact-info__icon{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;flex:none;background:var(--bg-tint);color:var(--teal-500)}
.contact-info__item h2{font-family:var(--fdisp);font-size:1.05rem;margin-bottom:.2rem}
.contact-info__item a{font-weight:700}
.contact-info__item p{margin:.1rem 0 0;color:var(--muted);font-size:.86rem}
.contact-info address{font-style:normal}

/* Center blocks (404 / bedankt) */
.center-block{text-align:center}
.success-icon{display:grid;place-items:center;width:92px;height:92px;border-radius:50%;margin:0 auto 1.5rem;
  background:var(--grad-bright);color:var(--ink-900);box-shadow:var(--glow)}
.success-icon .icon{width:46px;height:46px}
.error-code{display:block;font-family:var(--fdisp);font-size:clamp(4.5rem,16vw,9rem);font-weight:800;line-height:1;
  background:var(--grad-bright);-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{font-size:1.14rem;color:var(--muted)}
.center-block .hero__actions{margin:1.8rem 0 0}
.error-links{margin-top:2.8rem}
.error-links h2{font-size:1.1rem}

/* Legal pages */
.legal h2{margin-top:2rem;font-size:1.3rem}
.legal ul{list-style:none;padding-left:0;color:var(--body)}
.legal ul li{margin-bottom:.5rem;padding-left:1.6rem;position:relative}
.legal ul li::before{content:"";position:absolute;left:0;top:.65em;width:8px;height:8px;border-radius:50%;background:var(--grad-bright)}

/* ============================ Footer ============================ */
.site-footer{position:relative;background:var(--ink-900);color:#8aa6bd;padding:clamp(3rem,5vw,4.5rem) 0 1.6rem;overflow:hidden}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-bright)}
.site-footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.2rem}
.site-footer__about p{color:#7c97ae;font-size:.93rem;max-width:34ch}
.site-footer__title{font-family:var(--fdisp);color:#fff;font-size:1rem;margin-bottom:1.1rem}
.site-footer__links{display:grid;gap:.55rem}
.site-footer__links--cols{grid-template-columns:1fr 1fr;gap:.55rem 1rem}
.site-footer__links a,.contact-list a{color:#8aa6bd;font-size:.93rem;transition:color .18s,padding .18s}
.site-footer__links a:hover{color:var(--cyan-400);padding-left:4px}
.contact-list a:hover{color:var(--cyan-400)}
.contact-list{display:grid;gap:.6rem;margin-top:1.2rem}
.contact-list li{display:flex;align-items:center;gap:.55rem;font-size:.93rem}
.contact-list .icon{color:var(--cyan-400)}
.site-footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.1);margin-top:2.6rem;padding-top:1.5rem;font-size:.86rem;color:#67839a}
.site-footer__legal{display:flex;gap:1.3rem;flex-wrap:wrap}
.site-footer__legal a{color:#8aa6bd}
.site-footer__legal a:hover{color:var(--cyan-400)}

/* Sticky mobile bar */
.mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;background:rgba(255,255,255,.96);
  backdrop-filter:blur(10px);border-top:1px solid var(--line);box-shadow:0 -6px 24px rgba(9,30,52,.12);grid-template-columns:repeat(3,1fr)}
.mobile-bar__btn{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.65rem 0;font-family:var(--fdisp);font-size:.72rem;font-weight:700;color:var(--ink)}
.mobile-bar__btn .icon{width:22px;height:22px}
.mobile-bar__btn--call{color:var(--teal-500)}
.mobile-bar__btn--quote{color:var(--cyan-600)}
.mobile-bar__btn--wa{color:#25d366}
/* Onderbalk verbergen tijdens invullen van een formulier (toetsenbord open) -> geen trillen */
body.form-focus .mobile-bar{display:none}

/* WhatsApp float */
.wa-float{position:fixed;right:22px;bottom:26px;z-index:91;display:grid;place-items:center;width:60px;height:60px;
  border-radius:50%;background:#25d366;color:#fff;box-shadow:0 12px 30px rgba(37,211,102,.5);transition:transform .2s}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #25d366;animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.6);opacity:0}}
.wa-float:hover{transform:scale(1.08);color:#fff}
.wa-float .icon{width:30px;height:30px;position:relative;z-index:1}

/* Reveal animation */
@media (prefers-reduced-motion:no-preference){
  [data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
  [data-reveal].is-visible{opacity:1;transform:none}
}
@media (prefers-reduced-motion:reduce){
  .hero__media,.hero__media::before,.bubbles span,.wa-float::after{animation:none}
}

/* ============================ Responsive ============================ */
@media (max-width:1024px){
  .hero__inner{grid-template-columns:1fr;gap:2.5rem}
  .hero__media{max-width:520px;margin:0 auto}
  .page-hero__inner{grid-template-columns:1fr}
  .page-hero__media{max-width:500px}
  .trust-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .content-grid{grid-template-columns:1fr}
  .content-aside{position:static;grid-template-columns:1fr 1fr;display:grid}
  .form-layout{grid-template-columns:1fr}
  .form-aside{position:static;grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .why,.why--reverse .why__media{grid-template-columns:1fr;order:0}
  .site-footer__grid{grid-template-columns:1fr 1fr}
}
/* Spoed-accent in het hoofdmenu */
.main-nav a.nav-spoed{color:var(--ink);background:var(--lime-500)}
.main-nav a.nav-spoed:hover,.main-nav a.nav-spoed.is-active{background:var(--lime-400);color:var(--ink-900)}
.main-nav a.nav-spoed::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--ink-900);margin-right:.4rem;vertical-align:middle}

/* Navigatie + sticky balk: eerder inklappen (≤1024px) zodat het menu nooit verdringt */
@media (max-width:1024px){
  /* backdrop-filter zou het fixed off-canvas menu in de header opsluiten -> uitzetten */
  .site-header,.site-header.is-scrolled{backdrop-filter:none;-webkit-backdrop-filter:none;background:#fff}
  .topbar__inner{justify-content:center}
  .topbar__phone{margin-left:0}
  .main-nav{position:fixed;inset:0 0 0 auto;width:min(84%,360px);background:#fff;transform:translateX(100%);
    transition:transform .3s var(--ease);box-shadow:var(--shadow-lg);padding:5.5rem 1.5rem 2rem;z-index:120;overflow-y:auto}
  .main-nav.is-open{transform:translateX(0)}
  .main-nav__list{flex-direction:column;align-items:stretch;gap:.2rem}
  .main-nav a{padding:.95rem 1rem;font-size:1.05rem;border-radius:12px}
  .main-nav__cta{margin:.7rem 0 0}
  .main-nav__cta .btn{width:100%}
  .nav-toggle{display:block;z-index:130}
  .mobile-bar{display:grid}
  .wa-float{display:none}
  body{padding-bottom:66px}
}

@media (max-width:760px){
  body{font-size:16px}
  .topbar{display:none}
  .cards--services,.cards--cities,.cards--provinces,.cards--reviews{grid-template-columns:1fr}
  .trust-grid,.steps,.benefit-grid,.beforeafter{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .content-aside,.form-aside{grid-template-columns:1fr}
  .cta-inline{flex-direction:column;align-items:flex-start}
  .site-footer__grid{grid-template-columns:1fr}
  .site-footer__bottom{flex-direction:column;text-align:center}
  .hero__badge{left:0}
  .hero__chip{right:0}
}
@media (max-width:430px){
  .hero__badge,.hero__chip{position:static;display:inline-flex;margin-top:1rem;box-shadow:var(--shadow-sm)}
  .hero__media::before{display:none}
}
