/* =====================================================================
   SPACKER BAKKER — plafond- & wandafwerking
   Eén stylesheet. Huisstijl via CSS-variabelen.
   §3 SUPERPROMPT: vervang --primary door de dominante kleur uit het logo.
   ===================================================================== */

:root {
  /* --- ACCENT (warm klei/pleister — past bij spack & sierpleister) --- */
  --primary:        #B85C38;   /* dominante accentkleur — pas aan op logo */
  --primary-hover:  #9E4B2C;   /* ~10% donkerder */
  --primary-deep:   #833C22;   /* ~20% donkerder, voor accents */
  --primary-tint:   #FAF4EF;   /* zeer licht, voor backgrounds */
  --primary-tint-2: #F0DDD0;   /* licht, voor pills/badges */

  --ink:        #2A211B;       /* warm espresso — headings/text */
  --text:       #4A3F37;
  --text-soft:  #6E6157;
  --text-muted: #9A8E83;

  --white:    #FFFFFF;
  --bg:       #FFFFFF;
  --bg-alt:   #FAF6F2;         /* warme crème sectie-achtergrond */
  --bg-dark:  #5A2E1A;         /* donkere variant primary, calc/forms */
  --bg-darker:#241B15;         /* footer */

  --line:      #EAE1D9;
  --line-soft: #F2ECE6;

  --gold: #FBBC04;             /* sterren */
  --green:#25D366;             /* whatsapp */

  --radius:   16px;
  --radius-sm:10px;
  --radius-lg:26px;
  --shadow:    0 18px 50px -22px rgba(42,33,27,.30);
  --shadow-sm: 0 8px 24px -12px rgba(42,33,27,.25);
  --ease: cubic-bezier(0.22, 1, 0.36, 1);

  --maxw: 1200px;
  --nav-h: 78px;
}

/* ----------------------------- Reset ----------------------------- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; scroll-padding-top:90px; }
body {
  font-family:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--text); background:var(--bg); line-height:1.65;
  font-weight:400; -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
h1,h2,h3,h4 { color:var(--ink); line-height:1.12; font-weight:800; letter-spacing:-.02em; }
em { font-style:normal; color:var(--primary); }
.container { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }
section { position:relative; }

/* ----------------------------- Buttons ----------------------------- */
.btn {
  display:inline-flex; align-items:center; gap:.55rem; justify-content:center;
  font-weight:700; font-size:.97rem; padding:.95rem 1.7rem; border-radius:999px;
  border:2px solid transparent; cursor:pointer; transition:all .25s var(--ease);
  letter-spacing:-.01em; line-height:1; text-align:center;
}
.btn-primary { background:var(--primary); color:#fff; box-shadow:0 12px 26px -12px rgba(184,92,56,.7); }
.btn-primary:hover { background:var(--primary-hover); transform:translateY(-2px); box-shadow:0 18px 34px -14px rgba(184,92,56,.85); }
.btn-outline { background:transparent; color:var(--ink); border-color:var(--line); }
.btn-outline:hover { border-color:var(--primary); color:var(--primary); transform:translateY(-2px); }
.btn-ghost-light { background:rgba(255,255,255,.1); color:#fff; border-color:rgba(255,255,255,.4); backdrop-filter:blur(4px); }
.btn-ghost-light:hover { background:rgba(255,255,255,.2); transform:translateY(-2px); }
.btn-block { width:100%; }
.btn-lg { padding:1.1rem 2rem; font-size:1.02rem; }

/* ----------------------------- Eyebrow / headings ----------------------------- */
.eyebrow {
  display:inline-flex; align-items:center; gap:.5rem; text-transform:uppercase;
  letter-spacing:.18em; font-size:.74rem; font-weight:700; color:var(--primary);
  margin-bottom:1rem;
}
.eyebrow::before { content:""; width:26px; height:2px; background:var(--primary); display:inline-block; }
.section-head { max-width:680px; margin-bottom:3rem; }
.section-head.center { margin-left:auto; margin-right:auto; text-align:center; }
.section-head.center .eyebrow::before { display:none; }
h2.display { font-size:clamp(1.9rem,4vw,2.9rem); }
.lead { font-size:1.12rem; color:var(--text-soft); margin-top:1rem; }

/* =====================================================================
   NAVIGATIE  (§5 scroll-gedrag: wit bovenaan → --ink bij scrollen)
   ===================================================================== */
.nav {
  position:fixed; inset:0 0 auto 0; z-index:1000; height:var(--nav-h);
  background:#fff; border-bottom:1px solid var(--line);
  transition:background .35s var(--ease), border-color .35s var(--ease), box-shadow .35s var(--ease);
}
.nav-inner { display:flex; align-items:center; gap:1.4rem; height:100%; }
.nav-logo { display:flex; align-items:center; transition:opacity .3s var(--ease); }
.nav-logo img { height:46px; width:auto; }
.nav-logo-fallback { font-weight:800; font-size:1.3rem; color:var(--ink); letter-spacing:-.03em; white-space:nowrap; }
.nav-logo-fallback span { color:var(--primary); }
.nav-links { display:flex; align-items:center; gap:.3rem; margin-left:auto; }
.nav-links > li { position:relative; }
.nav-links a.nav-link {
  display:inline-flex; align-items:center; gap:.3rem; padding:.6rem .85rem; border-radius:10px;
  font-weight:600; font-size:.95rem; color:var(--ink); transition:color .25s var(--ease), background .25s var(--ease);
}
.nav-links a.nav-link:hover { color:var(--primary); background:var(--primary-tint); }
.nav-link .caret { width:9px; height:9px; border-right:2px solid currentColor; border-bottom:2px solid currentColor; transform:rotate(45deg) translateY(-2px); transition:transform .25s; }

/* dropdown */
.dropdown-menu {
  position:absolute; top:calc(100% + 8px); left:0; min-width:248px; background:#fff;
  border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow);
  padding:.5rem; opacity:0; visibility:hidden; transform:translateY(8px);
  transition:all .22s var(--ease);
}
.nav-links li:hover .dropdown-menu { opacity:1; visibility:visible; transform:translateY(0); }
.dropdown-menu a { display:block; padding:.62rem .8rem; border-radius:9px; font-size:.92rem; font-weight:600; color:var(--text); }
.dropdown-menu a:hover { background:var(--primary-tint); color:var(--primary); }

.nav-phone { display:inline-flex; align-items:center; gap:.45rem; font-weight:700; font-size:.95rem; color:var(--ink); padding:.5rem .7rem; transition:color .25s; white-space:nowrap; }
.nav-phone:hover { color:var(--primary); }
.nav-phone svg { width:17px; height:17px; }
.nav-flag {
  width:34px; height:24px; border-radius:5px; border:1px solid var(--line); overflow:hidden;
  cursor:pointer; background:none; padding:0; transition:border-color .3s, transform .2s;
}
.nav-flag:hover { transform:scale(1.08); }
.nav-flag svg { width:100%; height:100%; }
.nav-cta { padding:.7rem 1.3rem; }

/* scrolled state — KRITIEK: class = is-scrolled in JS én CSS */
.nav.is-scrolled { background:var(--ink); border-color:rgba(255,255,255,.08); box-shadow:0 10px 40px -20px rgba(0,0,0,.6); }
.nav.is-scrolled .nav-logo { opacity:0; pointer-events:none; }
.nav.is-scrolled .nav-logo-fallback { color:#fff; }
.nav.is-scrolled .nav-link,
.nav.is-scrolled .nav-phone { color:#fff; }
.nav.is-scrolled .nav-link:hover { color:#fff; background:rgba(255,255,255,.12); }
.nav.is-scrolled .nav-flag { border-color:rgba(255,255,255,.5); }

/* hamburger */
.nav-toggle { display:none; width:46px; height:46px; border:1px solid var(--line); border-radius:12px; background:#fff; cursor:pointer; flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.nav-toggle span { width:20px; height:2px; background:var(--ink); border-radius:2px; transition:.3s; }
.nav.is-scrolled .nav-toggle { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.3); }
.nav.is-scrolled .nav-toggle span { background:#fff; }

/* mobile menu */
.mobile-menu {
  position:fixed; inset:0 0 0 auto; width:min(360px,86vw); background:#fff; z-index:1200;
  transform:translateX(100%); transition:transform .4s var(--ease); padding:2rem 1.6rem;
  overflow-y:auto; box-shadow:-20px 0 60px -30px rgba(0,0,0,.5);
}
.mobile-menu.open { transform:translateX(0); }
.mobile-backdrop { position:fixed; inset:0; background:rgba(42,33,27,.45); backdrop-filter:blur(5px); z-index:1100; opacity:0; visibility:hidden; transition:.35s; }
.mobile-backdrop.open { opacity:1; visibility:visible; }
.mobile-menu-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:1.5rem; }
.mobile-menu-head .logo-txt { font-weight:800; font-size:1.2rem; color:var(--ink); }
.mobile-menu-head .logo-txt span { color:var(--primary); }
.mobile-close { width:42px; height:42px; border:1px solid var(--line); border-radius:10px; background:#fff; font-size:1.4rem; cursor:pointer; color:var(--ink); }
.mobile-menu nav a { display:block; padding:.85rem .4rem; font-weight:700; font-size:1.05rem; color:var(--ink); border-bottom:1px solid var(--line-soft); }
.mobile-menu nav a.sub { font-weight:500; font-size:.95rem; color:var(--text-soft); padding-left:1.3rem; }
.mobile-menu nav a.sub::before { content:"— "; color:var(--primary); }
.mobile-menu .btn { margin-top:1.4rem; }
.mobile-contact { margin-top:1.5rem; padding-top:1.3rem; border-top:1px solid var(--line); font-size:.93rem; color:var(--text-soft); }
.mobile-contact a { color:var(--primary); font-weight:700; }

/* =====================================================================
   HERO  (§7.1)
   ===================================================================== */
.hero { position:relative; min-height:92vh; display:flex; align-items:center; padding-top:var(--nav-h); overflow:hidden; background:var(--ink); }
.hero-slides { position:absolute; inset:0; z-index:0; }
.hero-slide {
  position:absolute; inset:0; background-size:cover; background-position:center;
  background-color:var(--bg-dark); opacity:0; transition:opacity 1.2s ease-in-out;
}
.hero-slide.active { opacity:1; }
.hero-overlay { position:absolute; inset:0; z-index:1; background:linear-gradient(110deg, rgba(36,27,21,.88) 0%, rgba(36,27,21,.62) 42%, rgba(184,92,56,.42) 100%); }
.hero-inner { position:relative; z-index:2; padding:3rem 0 4rem; max-width:720px; }
.hero .eyebrow { color:#fff; }
.hero .eyebrow::before { background:var(--primary-tint-2); }
.hero h1 { color:#fff; font-size:clamp(2.4rem,6vw,4.3rem); line-height:1.02; letter-spacing:-.03em; }
.hero h1 em { color:#fff; position:relative; }
.hero h1 em::after { content:""; position:absolute; left:0; right:0; bottom:.06em; height:.16em; background:var(--primary); border-radius:3px; z-index:-1; opacity:.95; }
.hero-desc { color:rgba(255,255,255,.9); font-size:1.18rem; max-width:560px; margin:1.5rem 0 2.2rem; }
.hero-cta { display:flex; gap:1rem; flex-wrap:wrap; }
.hero-stats { display:flex; gap:2.6rem; margin-top:3.4rem; flex-wrap:wrap; }
.hero-stat .num { font-size:2.2rem; font-weight:800; color:#fff; letter-spacing:-.03em; }
.hero-stat .label { color:rgba(255,255,255,.78); font-size:.9rem; font-weight:600; }

/* =====================================================================
   OVER ONS 2-koloms  (§7.2)
   ===================================================================== */
.about { padding:6rem 0; }
.about-grid { display:grid; grid-template-columns:.9fr 1.1fr; gap:4rem; align-items:center; }
.about-photo { position:relative; }
.about-photo .frame { aspect-ratio:4/5; border-radius:var(--radius-lg); overflow:hidden; background:var(--primary-tint); box-shadow:var(--shadow); }
.about-photo .frame img { width:100%; height:100%; object-fit:cover; }
.about-photo .badge {
  position:absolute; bottom:-22px; left:-22px; background:#fff; border-radius:18px; padding:1.1rem 1.4rem;
  box-shadow:var(--shadow); display:flex; align-items:center; gap:.85rem; border:1px solid var(--line-soft);
}
.about-photo .badge .big { font-size:2rem; font-weight:800; color:var(--primary); line-height:1; }
.about-photo .badge .small { font-size:.82rem; color:var(--text-soft); font-weight:600; line-height:1.25; }
.about-body p + p { margin-top:1rem; }
.about-body .btn { margin-top:1.8rem; }

/* =====================================================================
   UNIEK — 3 kaarten + stats  (§7.3)
   ===================================================================== */
.section-pad { padding:6rem 0; }
.bg-alt { background:var(--bg-alt); }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.uniek-card { background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius); padding:2.2rem 1.9rem; transition:transform .3s var(--ease), box-shadow .3s var(--ease); }
.uniek-card:hover { transform:translateY(-6px); box-shadow:var(--shadow); }
.num-badge { width:52px; height:52px; border-radius:50%; background:var(--primary); color:#fff; display:grid; place-items:center; font-weight:800; font-size:1.2rem; margin-bottom:1.2rem; }
.uniek-card h3 { font-size:1.25rem; margin-bottom:.6rem; }
.uniek-card p { font-size:.97rem; color:var(--text-soft); }
.stats-row { display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; margin-top:3rem; text-align:center; }
.stat-big .num { font-size:clamp(2.4rem,5vw,3.4rem); font-weight:800; color:var(--primary); letter-spacing:-.03em; line-height:1; }
.stat-big .label { color:var(--text-soft); font-weight:600; margin-top:.4rem; }

/* =====================================================================
   HOOFD-DIENSTEN — 3 kaarten met calculator-CTA  (§7.4)
   ===================================================================== */
.svc-card { background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:transform .3s var(--ease), box-shadow .3s var(--ease); position:relative; }
.svc-card:hover { transform:translateY(-6px); box-shadow:var(--shadow); }
.svc-card .photo { aspect-ratio:16/11; background:var(--primary-tint) center/cover; }
.svc-card .body { padding:1.7rem 1.6rem 1.9rem; display:flex; flex-direction:column; flex:1; }
.svc-card h3 { font-size:1.32rem; margin-bottom:.9rem; }
.svc-card ul { margin-bottom:1.5rem; display:flex; flex-direction:column; gap:.55rem; }
.svc-card ul li { font-size:.95rem; color:var(--text-soft); padding-left:1.7rem; position:relative; }
.svc-card ul li::before { content:""; position:absolute; left:0; top:.4em; width:1.1rem; height:.6rem; border-left:2.5px solid var(--primary); border-bottom:2.5px solid var(--primary); transform:rotate(-45deg); }
.svc-card .btn { margin-top:auto; }
.pop-badge { position:absolute; top:1rem; left:1rem; z-index:2; background:var(--primary); color:#fff; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; padding:.4rem .8rem; border-radius:999px; }

/* =====================================================================
   WERKWIJZE — 4 stappen  (§7.5)
   ===================================================================== */
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.step-card { background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius); padding:2rem 1.5rem; position:relative; }
.step-card .num-badge { margin-bottom:1rem; }
.step-card h3 { font-size:1.1rem; margin-bottom:.5rem; }
.step-card p { font-size:.92rem; color:var(--text-soft); }

/* =====================================================================
   PORTFOLIO — Bento grid  (§7.6)
   ===================================================================== */
.bento { display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:1rem; }
.bento-tile { position:relative; border-radius:var(--radius); overflow:hidden; background:var(--primary-tint) center/cover; display:flex; align-items:flex-end; min-height:100%; }
.bento-tile::after { content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(36,27,21,.82) 0%, rgba(36,27,21,.05) 55%); }
.bento-tile .cap { position:relative; z-index:2; padding:1.4rem; color:#fff; }
.bento-tile .cap .t { font-weight:800; font-size:1.1rem; }
.bento-tile .cap .s { font-size:.84rem; opacity:.85; }
.bento-tile.big { grid-column:span 2; grid-row:span 2; }
.bento-tile.wide { grid-column:span 2; }
.bento-tile img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.bento-tile:hover img { transform:scale(1.06); }

/* =====================================================================
   MARQUEE (tips & reviews)  (§7.7 / 7.8)
   ===================================================================== */
.marquee { overflow:hidden; position:relative; -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); cursor:grab; }
.marquee:active { cursor:grabbing; }
.marquee-track { display:flex; gap:1.4rem; width:max-content; animation:scrollx 48s linear infinite; }
.marquee:hover .marquee-track { animation-play-state:paused; }
@keyframes scrollx { from{transform:translateX(0);} to{transform:translateX(-50%);} }

.tip-card { width:340px; flex:0 0 340px; background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius); overflow:hidden; cursor:pointer; transition:transform .3s var(--ease), box-shadow .3s var(--ease); }
.tip-card:hover { transform:translateY(-5px); box-shadow:var(--shadow); }
.tip-card .photo { aspect-ratio:16/10; background:var(--primary-tint) center/cover; }
.tip-card .body { padding:1.3rem 1.4rem 1.5rem; }
.pill { display:inline-block; background:var(--primary-tint-2); color:var(--primary-deep); font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; padding:.32rem .7rem; border-radius:999px; margin-bottom:.7rem; }
.tip-card h3 { font-size:1.12rem; margin-bottom:.5rem; }
.tip-card p { font-size:.9rem; color:var(--text-soft); }
.tip-card .meta { margin-top:.9rem; font-size:.82rem; color:var(--text-muted); font-weight:600; display:flex; justify-content:space-between; }
.tip-card .meta .more { color:var(--primary); }

/* reviews */
.rev-head { display:flex; align-items:center; gap:1rem; justify-content:center; margin-bottom:2.5rem; flex-wrap:wrap; }
.rev-head .glogo { font-weight:700; font-size:1.05rem; }
.rev-head .glogo b:nth-child(1){color:#4285F4;} 
.gword span:nth-child(1){color:#4285F4;}.gword span:nth-child(2){color:#EA4335;}.gword span:nth-child(3){color:#FBBC04;}.gword span:nth-child(4){color:#4285F4;}.gword span:nth-child(5){color:#34A853;}.gword span:nth-child(6){color:#EA4335;}
.gword { font-weight:800; font-size:1.15rem; }
.rev-rating { font-weight:800; color:var(--ink); }
.rev-rating .stars { color:var(--gold); letter-spacing:1px; }
.rev-card { width:330px; flex:0 0 330px; background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius); padding:1.5rem; }
.rev-card .top { display:flex; align-items:center; gap:.8rem; margin-bottom:.8rem; }
.rev-avatar { width:44px; height:44px; border-radius:50%; display:grid; place-items:center; color:#fff; font-weight:800; font-size:1.05rem; flex:0 0 44px; }
.rev-card .name { font-weight:700; color:var(--ink); font-size:.97rem; }
.rev-card .when { font-size:.8rem; color:var(--text-muted); }
.rev-stars { color:var(--gold); font-size:.95rem; letter-spacing:1px; margin-bottom:.5rem; }
.rev-text { font-size:.92rem; color:var(--text-soft); display:-webkit-box; -webkit-line-clamp:5; -webkit-box-orient:vertical; overflow:hidden; }
.rev-badge { margin-top:.9rem; display:inline-block; background:var(--primary-tint); color:var(--primary-deep); font-size:.74rem; font-weight:700; padding:.3rem .7rem; border-radius:999px; }

/* =====================================================================
   CALCULATOR  (§7.9 / 9)
   ===================================================================== */
.calc-section { background:var(--ink); padding:6rem 0; color:#fff; }
.calc-section .eyebrow { color:var(--primary-tint-2); }
.calc-section h2 { color:#fff; }
.calc-section .lead { color:rgba(255,255,255,.78); }
.calc-card { background:#fff; border-radius:var(--radius-lg); overflow:hidden; box-shadow:0 40px 90px -40px rgba(0,0,0,.6); margin-top:2.8rem; }
.calc-tabs { display:flex; border-bottom:1px solid var(--line); flex-wrap:wrap; }
.calc-tab { flex:1; min-width:130px; padding:1.1rem 1rem; background:var(--bg-alt); border:none; font-family:inherit; font-weight:700; font-size:.97rem; color:var(--text-soft); cursor:pointer; transition:.25s; border-bottom:3px solid transparent; }
.calc-tab.active { background:#fff; color:var(--primary); border-bottom-color:var(--primary); }
.calc-panel { display:none; grid-template-columns:1.15fr 1fr; }
.calc-panel.active { display:grid; }
.calc-inputs { padding:2.4rem; }
.calc-field { margin-bottom:1.8rem; }
.calc-field > label.field-label { display:flex; justify-content:space-between; font-weight:700; color:var(--ink); margin-bottom:.8rem; font-size:.97rem; }
.calc-field .val { color:var(--primary); }
input[type=range] { width:100%; -webkit-appearance:none; height:6px; border-radius:6px; background:var(--primary-tint-2); outline:none; }
input[type=range]::-webkit-slider-thumb { -webkit-appearance:none; width:24px; height:24px; border-radius:50%; background:var(--primary); cursor:pointer; border:3px solid #fff; box-shadow:0 3px 8px rgba(184,92,56,.5); }
input[type=range]::-moz-range-thumb { width:22px; height:22px; border-radius:50%; background:var(--primary); cursor:pointer; border:3px solid #fff; }
.opt-group { display:flex; gap:.6rem; flex-wrap:wrap; }
.opt-group label { flex:1; min-width:90px; text-align:center; padding:.7rem .5rem; border:2px solid var(--line); border-radius:12px; cursor:pointer; font-weight:600; font-size:.88rem; color:var(--text-soft); transition:.2s; user-select:none; }
.opt-group input { position:absolute; opacity:0; pointer-events:none; }
.opt-group label:hover { border-color:var(--primary-tint-2); }
.opt-group input:checked + label, .opt-group label.checked { border-color:var(--primary); background:var(--primary-tint); color:var(--primary-deep); }
.toggle-row { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:1rem 1.1rem; background:var(--bg-alt); border-radius:12px; }
.toggle-row .tt { font-weight:700; color:var(--ink); font-size:.94rem; }
.toggle-row .ts { font-size:.82rem; color:var(--text-soft); }
.switch { position:relative; width:52px; height:30px; flex:0 0 52px; }
.switch input { opacity:0; width:0; height:0; }
.switch .slider { position:absolute; inset:0; background:var(--line); border-radius:999px; cursor:pointer; transition:.3s; }
.switch .slider::before { content:""; position:absolute; width:22px; height:22px; left:4px; top:4px; background:#fff; border-radius:50%; transition:.3s; }
.switch input:checked + .slider { background:var(--primary); }
.switch input:checked + .slider::before { transform:translateX(22px); }

.calc-result { background:linear-gradient(155deg,var(--ink) 0%, var(--primary-deep) 130%); color:#fff; padding:2.4rem; display:flex; flex-direction:column; }
.calc-result .rlabel { text-transform:uppercase; letter-spacing:.14em; font-size:.74rem; font-weight:700; color:var(--primary-tint-2); }
.calc-result .price { font-size:clamp(2.6rem,6vw,3.6rem); font-weight:800; letter-spacing:-.03em; margin:.4rem 0 .2rem; }
.calc-result .disc { font-size:.82rem; color:rgba(255,255,255,.7); margin-bottom:1.4rem; }
.calc-summary { list-style:none; border-top:1px solid rgba(255,255,255,.16); padding-top:1.2rem; margin-bottom:1.6rem; }
.calc-summary li { display:flex; justify-content:space-between; font-size:.9rem; padding:.4rem 0; color:rgba(255,255,255,.86); }
.calc-summary li b { color:#fff; font-weight:700; }
.calc-result .btn { margin-top:auto; }

/* =====================================================================
   FAQ  (§7.10)
   ===================================================================== */
.faq-list { max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:.9rem; }
.faq-item { background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius); overflow:hidden; }
.faq-q { width:100%; display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:1.3rem 1.5rem; background:none; border:none; cursor:pointer; font-family:inherit; font-weight:700; font-size:1.03rem; color:var(--ink); text-align:left; }
.faq-icon { width:32px; height:32px; flex:0 0 32px; border-radius:50%; background:var(--primary-tint); display:grid; place-items:center; position:relative; transition:.3s; }
.faq-icon::before,.faq-icon::after { content:""; position:absolute; background:var(--primary); border-radius:2px; transition:.3s; }
.faq-icon::before { width:13px; height:2.5px; }
.faq-icon::after { width:2.5px; height:13px; }
.faq-item.open .faq-icon { transform:rotate(45deg); background:var(--primary); }
.faq-item.open .faq-icon::before,.faq-item.open .faq-icon::after { background:#fff; }
.faq-a { max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq-a-inner { padding:0 1.5rem 1.4rem; color:var(--text-soft); font-size:.97rem; }

/* =====================================================================
   FOOTER  (§7.11)
   ===================================================================== */
.footer { background:var(--bg-darker); color:rgba(255,255,255,.7); padding:4.5rem 0 0; }
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2.5rem; }
.footer h4 { color:#fff; font-size:1rem; margin-bottom:1.2rem; letter-spacing:0; }
.footer a { transition:color .2s; }
.footer a:hover { color:var(--primary-tint-2); }
.footer ul li { margin-bottom:.6rem; font-size:.93rem; }
.foot-logo-pill { display:inline-flex; background:#fff; border-radius:12px; padding:.7rem 1rem; margin-bottom:1.2rem; }
.foot-logo-pill img { height:40px; }
.foot-logo-pill .txt { font-weight:800; color:var(--ink); font-size:1.15rem; }
.foot-logo-pill .txt span { color:var(--primary); }
.footer .usp { font-size:.93rem; margin-bottom:1.3rem; max-width:320px; }
.foot-social { display:flex; gap:.6rem; }
.foot-social a { width:38px; height:38px; border-radius:10px; background:rgba(255,255,255,.08); display:grid; place-items:center; color:#fff; transition:.25s; }
.foot-social a:hover { background:var(--primary); transform:translateY(-2px); }
.foot-social svg { width:18px; height:18px; }
.foot-contact li { display:flex; gap:.7rem; align-items:flex-start; }
.foot-contact svg { width:17px; height:17px; flex:0 0 17px; margin-top:.25rem; color:var(--primary); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.08); margin-top:3.5rem; padding:1.6rem 0; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.85rem; }
.footer-bottom a:hover { color:#fff; }

/* =====================================================================
   STICKY CTA (mobile)  +  WHATSAPP bubble  (§12)
   ===================================================================== */
.whatsapp-bubble { position:fixed; right:18px; bottom:18px; width:58px; height:58px; border-radius:50%; background:var(--green); display:grid; place-items:center; z-index:900; box-shadow:0 10px 30px -8px rgba(37,211,102,.6); transition:transform .25s; }
.whatsapp-bubble:hover { transform:scale(1.08); }
.whatsapp-bubble svg { width:30px; height:30px; fill:#fff; }
.sticky-cta { display:none; position:fixed; left:0; right:0; bottom:0; z-index:950; background:#fff; border-top:1px solid var(--line); padding:.6rem; gap:.5rem; box-shadow:0 -8px 24px -12px rgba(0,0,0,.25); }
.sticky-cta a { flex:1; padding:.85rem; border-radius:12px; font-weight:700; font-size:.9rem; text-align:center; display:flex; align-items:center; justify-content:center; gap:.35rem; }
.sticky-cta .bel { background:var(--primary-tint); color:var(--primary-deep); }
.sticky-cta .wa { background:var(--green); color:#fff; }
.sticky-cta .off { background:var(--primary); color:#fff; }

/* =====================================================================
   TIPS MODAL  (§12)
   ===================================================================== */
.modal-backdrop { position:fixed; inset:0; background:rgba(36,27,21,.6); backdrop-filter:blur(4px); z-index:1500; display:none; align-items:center; justify-content:center; padding:1.5rem; opacity:0; transition:opacity .3s; }
.modal-backdrop.open { display:flex; opacity:1; }
.modal-panel { background:#fff; border-radius:var(--radius-lg); max-width:700px; width:100%; max-height:90vh; overflow-y:auto; transform:scale(.92); transition:transform .3s var(--ease); position:relative; }
.modal-backdrop.open .modal-panel { transform:scale(1); }
.modal-close { position:absolute; top:1rem; right:1rem; width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.9); border:none; font-size:1.5rem; cursor:pointer; z-index:3; color:var(--ink); }
.modal-photo { aspect-ratio:16/8; background:var(--primary-tint) center/cover; border-radius:var(--radius-lg) var(--radius-lg) 0 0; }
.modal-body { padding:2rem 2.2rem 2.4rem; }
.modal-body h3 { font-size:1.6rem; margin:.6rem 0 1rem; }
.modal-body .meta { color:var(--text-muted); font-size:.85rem; font-weight:600; margin-bottom:1.3rem; }
.modal-body p { margin-bottom:1rem; color:var(--text-soft); }
.modal-body .btn { margin-top:.6rem; }

/* =====================================================================
   INNER PAGES
   ===================================================================== */
.subhero { position:relative; min-height:46vh; display:flex; align-items:flex-end; padding:calc(var(--nav-h) + 2rem) 0 3rem; background:var(--ink) center/cover; overflow:hidden; }
.subhero::after { content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(36,27,21,.9), rgba(36,27,21,.55)); }
.subhero-inner { position:relative; z-index:2; }
.breadcrumb { color:rgba(255,255,255,.75); font-size:.85rem; font-weight:600; margin-bottom:.8rem; }
.breadcrumb a:hover { color:#fff; }
.subhero h1 { color:#fff; font-size:clamp(2rem,5vw,3.2rem); }
.subhero p { color:rgba(255,255,255,.85); max-width:560px; margin-top:.8rem; font-size:1.08rem; }

.two-col { display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:center; }
.two-col .txt h2 { font-size:clamp(1.7rem,3.5vw,2.4rem); margin-bottom:1rem; }
.two-col .txt p + p { margin-top:1rem; }
.two-col .img-frame { aspect-ratio:4/3; border-radius:var(--radius-lg); overflow:hidden; background:var(--primary-tint) center/cover; box-shadow:var(--shadow); }
.two-col .img-frame img { width:100%; height:100%; object-fit:cover; }

.benefit-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.benefit-card { background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius); padding:1.8rem; }
.benefit-card .ic { width:48px; height:48px; border-radius:13px; background:var(--primary-tint); display:grid; place-items:center; margin-bottom:1rem; color:var(--primary); }
.benefit-card .ic svg { width:24px; height:24px; }
.benefit-card h3 { font-size:1.1rem; margin-bottom:.4rem; }
.benefit-card p { font-size:.92rem; color:var(--text-soft); }

.material-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.3rem; }
.material-card { background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius); padding:1.6rem; }
.material-card h3 { font-size:1.05rem; margin-bottom:.4rem; color:var(--primary); }
.material-card p { font-size:.88rem; color:var(--text-soft); }

.meta-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.3rem; }
.meta-card { background:var(--bg-alt); border-radius:var(--radius); padding:1.5rem; text-align:center; }
.meta-card .l { font-size:.78rem; text-transform:uppercase; letter-spacing:.1em; color:var(--text-muted); font-weight:700; }
.meta-card .v { font-size:1.1rem; font-weight:800; color:var(--ink); margin-top:.3rem; }

/* CTA band */
.cta-band { background:linear-gradient(120deg,var(--ink),var(--primary-deep)); border-radius:var(--radius-lg); padding:3.2rem; text-align:center; color:#fff; }
.cta-band h2 { color:#fff; font-size:clamp(1.6rem,3.5vw,2.3rem); }
.cta-band p { color:rgba(255,255,255,.82); max-width:520px; margin:.8rem auto 1.8rem; }
.cta-band .btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* projecten overview grid */
.proj-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.proj-card { border-radius:var(--radius); overflow:hidden; background:#fff; border:1px solid var(--line-soft); transition:transform .3s var(--ease), box-shadow .3s var(--ease); display:block; }
.proj-card:hover { transform:translateY(-6px); box-shadow:var(--shadow); }
.proj-card .photo { aspect-ratio:4/3; background:var(--primary-tint) center/cover; }
.proj-card .body { padding:1.4rem 1.5rem 1.6rem; }
.proj-card h3 { font-size:1.15rem; margin-bottom:.3rem; }
.proj-card .loc { font-size:.85rem; color:var(--primary); font-weight:700; }
.proj-card p { font-size:.9rem; color:var(--text-soft); margin-top:.5rem; }

/* article */
.article-body { max-width:780px; margin:0 auto; }
.article-body h4 { font-size:1.25rem; margin:1.8rem 0 .6rem; }
.article-body p { margin-bottom:1rem; color:var(--text); }
.article-meta { display:flex; gap:1rem; align-items:center; color:var(--text-muted); font-size:.88rem; font-weight:600; margin-bottom:1.5rem; }

/* CONTACT / OFFERTE forms */
.form-layout { display:grid; grid-template-columns:1.4fr 1fr; gap:2.4rem; align-items:start; }
.form-card { background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius-lg); padding:2.4rem; box-shadow:var(--shadow-sm); }
.form-row { margin-bottom:1.3rem; }
.form-row label { display:block; font-weight:700; color:var(--ink); margin-bottom:.45rem; font-size:.92rem; }
.form-row label .req { color:var(--primary); }
.form-row input,.form-row select,.form-row textarea {
  width:100%; padding:.85rem 1rem; border:1.5px solid var(--line); border-radius:12px;
  font-family:inherit; font-size:.97rem; color:var(--ink); background:#fff; transition:border-color .2s;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus { outline:none; border-color:var(--primary); }
.form-row input[readonly] { background:var(--bg-alt); color:var(--primary-deep); font-weight:700; }
.form-row textarea { min-height:130px; resize:vertical; }
.info-aside { background:var(--ink); color:#fff; border-radius:var(--radius-lg); padding:2.2rem; position:sticky; top:100px; }
.info-aside h3 { color:#fff; font-size:1.3rem; margin-bottom:1.4rem; }
.info-aside .ic-row { display:flex; gap:.85rem; align-items:flex-start; margin-bottom:1.3rem; }
.info-aside .ic-row svg { width:19px; height:19px; flex:0 0 19px; margin-top:.2rem; color:var(--primary-tint-2); }
.info-aside .ic-row a, .info-aside .ic-row span { color:rgba(255,255,255,.85); font-size:.95rem; }
.info-aside .ic-row b { display:block; color:#fff; }
.info-divider { border-top:1px solid rgba(255,255,255,.14); margin:1.6rem 0; }
.btw-note { background:var(--primary-tint); border:1px solid var(--primary-tint-2); border-radius:14px; padding:1rem 1.2rem; font-size:.9rem; color:var(--primary-deep); font-weight:600; margin-bottom:1.5rem; }
.btw-note b { color:var(--primary-deep); }

/* =====================================================================
   REVEAL ANIMATIES  (§9)
   ===================================================================== */
.reveal-up      { opacity:0; transform:translateY(60px); }
.reveal-x       { opacity:0; transform:translateX(-100px); }
.reveal-x-r     { opacity:0; transform:translateX(100px); }
.reveal-zoom    { opacity:0; transform:scale(.85); }
.reveal-x-zoom  { opacity:0; transform:translateX(-80px) scale(.92); }
.reveal-x-r-zoom{ opacity:0; transform:translateX(80px) scale(.92); }
.reveal-flip    { opacity:0; transform:perspective(900px) rotateX(35deg) translateY(50px); transform-origin:center bottom; }
.reveal-up,.reveal-x,.reveal-x-r,.reveal-zoom,.reveal-x-zoom,.reveal-x-r-zoom,.reveal-flip {
  transition:opacity 1s var(--ease), transform 1s var(--ease);
}
.is-visible { opacity:1 !important; transform:none !important; }
.stagger > *:nth-child(1){transition-delay:0s;}
.stagger > *:nth-child(2){transition-delay:.10s;}
.stagger > *:nth-child(3){transition-delay:.20s;}
.stagger > *:nth-child(4){transition-delay:.30s;}
.stagger > *:nth-child(5){transition-delay:.40s;}
.stagger > *:nth-child(6){transition-delay:.50s;}
.stagger > *:nth-child(7){transition-delay:.60s;}
.stagger > *:nth-child(8){transition-delay:.70s;}

@media (prefers-reduced-motion: reduce) {
  .reveal-up,.reveal-x,.reveal-x-r,.reveal-zoom,.reveal-x-zoom,.reveal-x-r-zoom,.reveal-flip {
    opacity:1 !important; transform:none !important; transition:none !important;
  }
  .hero-slide { transition:none; }
  .marquee-track { animation:none; }
}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1024px){
  .nav-links,.nav-phone,.nav-flag,.nav-cta.desk { display:none; }
  .nav-toggle { display:flex; }
  .about-grid,.two-col,.form-layout { grid-template-columns:1fr; gap:2.5rem; }
  .grid-4,.material-grid,.meta-grid { grid-template-columns:repeat(2,1fr); }
  .calc-panel.active { grid-template-columns:1fr; }
  .info-aside { position:static; }
  .bento { grid-template-columns:repeat(2,1fr); grid-auto-rows:180px; }
  .bento-tile.big { grid-column:span 2; grid-row:span 2; }
  .bento-tile.wide { grid-column:span 2; }
}
@media (max-width:720px){
  .grid-3,.benefit-grid,.proj-grid,.stats-row { grid-template-columns:1fr; }
  .hero-stats { gap:1.8rem; }
  .hero-stat .num { font-size:1.8rem; }
  .about-photo .badge { left:0; }
  .cta-band,.form-card,.info-aside { padding:1.8rem; }
  .calc-inputs,.calc-result { padding:1.7rem; }
}
@media (max-width:640px){
  .sticky-cta { display:flex; }
  .whatsapp-bubble { bottom:78px; }
  body { padding-bottom:0; }
  .grid-4,.material-grid,.meta-grid { grid-template-columns:1fr; }
  .bento { grid-template-columns:1fr; }
  .bento-tile.big,.bento-tile.wide { grid-column:span 1; grid-row:span 1; }
}
