/* ============================================================
   Labelbewust — premium renovatie-preview
   Trison-geïnspireerd in ritme, cards en motion; eigen Labelbewust identiteit.
   ============================================================ */
:root{
  --accent:#34b36f;
  --accent-2:#1f8f55;
  --ink:#06110f;
  --ink-2:#14201c;
  --dark:#020b0a;
  --dark-soft:#0b1714;
  --sand:#e8e5dc;
  --sand-2:#d3cdbf;
  --sand-3:#f5f2ea;
  --muted:#7d786d;
  --ink-soft:#5f5a50;
  --accent-soft:rgba(52,179,111,.14);
  --white:#fff;
  --line:rgba(6,17,15,.13);
  --line-dark:rgba(255,255,255,.13);
  --font-head:"Inter Tight","Mulish",system-ui,sans-serif;
  --font-body:"Inter Tight","Mulish",system-ui,sans-serif;
  --maxw:1280px;
  --gutter:clamp(20px,5vw,64px);
  --radius:18px;
  --radius-lg:30px;
  --topbar-h:38px;
  --header-h:76px;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--sand);color:var(--ink);font-family:var(--font-body);font-size:17px;line-height:1.45;font-weight:430;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img,video{display:block;max-width:100%}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{cursor:pointer}
h1,h2,h3,h4{margin:0;font-family:var(--font-head);font-weight:540;line-height:.96;letter-spacing:-.045em;text-wrap:balance}p{margin:0 0 1em;text-wrap:pretty}.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
::selection{background:var(--accent);color:#fff}

/* ---------- primitives ---------- */
.kicker,.eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--muted);font-size:13px;font-weight:650;letter-spacing:.03em;margin-bottom:16px}.kicker::before,.eyebrow::before{content:"";width:9px;height:9px;border-radius:2px;background:var(--accent);box-shadow:12px 0 0 color-mix(in srgb,var(--accent) 45%,#fff)}
.slash{display:inline-flex;align-items:center;color:var(--accent);margin-bottom:18px}.slash .brand-ico{width:34px;height:34px}.slash.white{color:#fff}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:52px;padding:14px 25px;border-radius:999px;border:1px solid transparent;background:var(--accent-2);color:#fff;font-weight:700;letter-spacing:-.015em;transition:transform .32s var(--ease),background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease)}
.btn:hover{transform:translateY(-2px);background:#187a48}.btn--green{background:var(--accent)}.btn--green:hover{background:#279b5c}.btn--dark{background:var(--dark);color:#fff}.btn--dark:hover{background:var(--ink-2)}.btn--ghost{background:transparent;border-color:rgba(255,255,255,.38);color:#fff}.btn--ghost:hover{background:#fff;color:var(--dark);border-color:#fff}
.circle-link{display:inline-flex;align-items:center;gap:13px;font-weight:700;letter-spacing:-.015em;color:var(--ink);transition:color .25s var(--ease)}.circle-link .circ{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;border:1.5px solid currentColor;transition:transform .32s var(--ease),background .25s var(--ease),color .25s var(--ease)}.circle-link:hover .circ{transform:translateX(3px);background:currentColor}.circle-link:hover .circ svg{color:var(--sand)}.circle-link.green-text{color:var(--accent)}.circle-link.white-text{color:#fff}.circle-link.white-text:hover .circ svg{color:var(--dark)}
.section{padding-block:clamp(78px,9vw,148px)}.section--sand{background:var(--sand)}.section--light{background:var(--sand-3)}.section--dark{background:var(--dark);color:#fff}.section--split{background:linear-gradient(90deg,var(--dark) 0 50%,var(--sand-2) 50% 100%);min-height:42vw}.section-title{font-size:clamp(44px,7vw,106px);max-width:10ch}.section-copy{max-width:650px;color:color-mix(in srgb,var(--ink) 63%,transparent);font-size:clamp(18px,2vw,24px);line-height:1.25;letter-spacing:-.025em}.section--dark .section-copy{color:rgba(255,255,255,.68)}

/* ---------- header ---------- */
.newsbar{position:fixed;inset:0 0 auto 0;height:var(--topbar-h);z-index:90;background:var(--dark);color:rgba(255,255,255,.78);font-size:13px;font-weight:650;display:flex;align-items:center}.newsbar .wrap{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px}.newsbar a{display:inline-flex;align-items:center;gap:8px}.newsbar .dot{width:13px;height:13px;border-radius:3px;background:var(--accent);display:inline-grid;place-items:center;color:var(--dark);font-size:9px;font-weight:900}
.site-header{position:fixed;top:var(--topbar-h);left:0;right:0;height:var(--header-h);z-index:91;color:#fff;background:rgba(2,11,10,.08);backdrop-filter:blur(12px);transition:background .32s var(--ease),color .32s var(--ease),border-color .32s var(--ease);border-bottom:1px solid transparent}.site-header.scrolled,.site-header:not(.is-hero){background:rgba(232,229,220,.94);color:var(--ink);border-bottom-color:var(--line)}.header-inner{height:100%;max-width:var(--maxw);margin:auto;padding-inline:var(--gutter);display:flex;align-items:center;gap:28px}.brand{display:flex;align-items:center;gap:13px;min-width:0}.brand .logo-img{height:42px;width:auto;transition:filter .25s var(--ease),transform .25s var(--ease)}.brand:hover .logo-img{transform:translateY(-1px)}.site-header.is-hero:not(.scrolled) .logo-img,.overlay .logo-img,.site-footer .logo-img{filter:brightness(0) invert(1)}.nav-main{display:flex;align-items:center;gap:25px;margin-left:auto}.nav-main a{position:relative;font-weight:650;font-size:15px;letter-spacing:-.015em;padding:8px 0}.nav-main a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--accent-2);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease)}.nav-main a:hover::after,.nav-main a.active::after{transform:scaleX(1)}.nav-badge{position:absolute;top:-7px;right:-14px;min-width:18px;height:18px;padding:0 5px;display:grid;place-items:center;background:var(--accent);color:#fff;border-radius:999px;font-size:10px;font-weight:800}.header-right{display:flex;align-items:center;gap:14px;margin-left:12px}.header-cta{display:inline-flex}@media(max-width:1120px){.header-cta{display:none}}.menu-btn{display:inline-flex;align-items:center;gap:12px;border:0;background:transparent;color:inherit;font-weight:700;padding:8px 0}.menu-btn .bars{display:flex;flex-direction:column;gap:5px}.menu-btn .bars span{width:26px;height:2px;background:currentColor;transition:transform .25s var(--ease);transform-origin:right}.menu-btn:hover .bars span:first-child{transform:scaleX(.65)}.menu-btn:hover .bars span:last-child{transform:scaleX(.82)}.icon-btn{display:none}

/* ---------- overlay menu ---------- */
.overlay{position:fixed;inset:0;z-index:200;visibility:hidden;opacity:0;transition:opacity .35s var(--ease),visibility .35s}.overlay.open{visibility:visible;opacity:1}.overlay-scrim{position:absolute;inset:0;background:rgba(2,11,10,.56);backdrop-filter:blur(5px)}.overlay-panel{position:absolute;top:0;right:0;width:min(900px,100%);height:100%;background:var(--dark);color:#fff;display:flex;flex-direction:column;transform:translateX(60px);opacity:0;transition:transform .45s var(--ease),opacity .45s var(--ease);overflow:auto}.overlay.open .overlay-panel{transform:none;opacity:1}.overlay-top{height:calc(var(--topbar-h) + var(--header-h));display:flex;align-items:center;justify-content:space-between;padding:24px var(--gutter);border-bottom:1px solid var(--line-dark)}.overlay-close{width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.24);background:transparent;color:#fff;font-size:24px;transition:transform .3s var(--ease),background .3s var(--ease)}.overlay-close:hover{transform:rotate(90deg);background:rgba(255,255,255,.1)}.overlay-body{padding:clamp(34px,6vw,72px) var(--gutter);display:grid;grid-template-columns:1fr 1fr;gap:48px}.menu-col h4{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin:0 0 16px}.menu-list{display:flex;flex-direction:column}.menu-list a{font-size:clamp(24px,3.1vw,42px);line-height:1.05;letter-spacing:-.045em;font-weight:520;padding:14px 0;border-bottom:1px solid var(--line-dark);display:flex;align-items:center;justify-content:space-between;color:rgba(255,255,255,.86);transition:color .25s var(--ease),padding-left .25s var(--ease)}.menu-list a:hover{color:#fff;padding-left:10px}.menu-contact{grid-column:1/-1;display:flex;gap:40px;flex-wrap:wrap;border-top:1px solid var(--line-dark);padding-top:30px}.menu-contact .lbl{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-weight:700;margin-bottom:7px}.menu-contact a{font-size:20px;font-weight:650;color:#fff}

/* ---------- hero ---------- */
.hero{position:relative;min-height:82svh;padding-top:calc(var(--topbar-h) + var(--header-h));color:#fff;overflow:hidden;background:var(--dark);display:grid;align-items:center}.hero .kicker{color:rgba(255,255,255,.82);text-shadow:0 2px 18px rgba(0,0,0,.28)}.hero .hero-fallback,.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transform:scale(1.03);animation:heroZoom 16s var(--ease) both}.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(2,11,10,.78),rgba(2,11,10,.36) 46%,rgba(2,11,10,.18)),linear-gradient(0deg,rgba(2,11,10,.25),transparent 35%)}.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:auto;padding:clamp(70px,8vw,120px) var(--gutter) 95px}.hero h1{font-size:clamp(48px,8.4vw,128px);max-width:11ch;color:#fff}.hero-lead{max-width:620px;margin-top:24px;color:rgba(255,255,255,.82);font-size:clamp(18px,2vw,25px);line-height:1.25;letter-spacing:-.025em}.hero-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:34px}.hero-wordmark{position:absolute;z-index:1;left:var(--gutter);bottom:clamp(8px,4vw,42px);font-size:clamp(72px,18vw,260px);line-height:.75;letter-spacing:-.08em;font-weight:560;color:rgba(255,255,255,.22);pointer-events:none}.hero-project{position:absolute;z-index:3;right:var(--gutter);bottom:clamp(24px,7vw,72px);width:min(390px,31vw);min-width:280px;border-radius:var(--radius);overflow:hidden;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);box-shadow:0 24px 80px rgba(0,0,0,.24);transition:transform .5s var(--ease)}.hero-project:hover{transform:translateY(-8px)}.hero-project img{width:100%;height:190px;object-fit:cover;filter:saturate(.95)}.hero-project .project-label{position:absolute;left:18px;right:18px;bottom:16px;display:flex;align-items:end;justify-content:space-between;gap:16px;color:#fff;text-shadow:0 3px 18px rgba(0,0,0,.42)}.hero-project strong{font-size:19px;letter-spacing:-.03em}.hero-project span{display:block;color:rgba(255,255,255,.74);font-size:14px}.hero-divider{position:absolute;left:0;right:0;bottom:0;height:0;z-index:5}.hero-scroll-btn{position:absolute;left:50%;bottom:0;transform:translate(-50%,50%);width:58px;height:58px;border-radius:50%;border:0;background:var(--sand);color:var(--dark);display:grid;place-items:center;box-shadow:0 12px 40px rgba(0,0,0,.2);transition:transform .3s var(--ease)}.hero-scroll-btn:hover{transform:translate(-50%,50%) scale(1.07)}
@keyframes heroZoom{from{transform:scale(1.09)}to{transform:scale(1.03)}}

/* ---------- home sections ---------- */
.intro-spacer{height:clamp(120px,23vw,360px);background:var(--sand)}.intro-showcase{margin-top:calc(clamp(120px,23vw,360px) * -1 + 50px);position:relative;z-index:2}.intro-showcase img{width:100%;height:clamp(360px,55vw,770px);object-fit:cover;border-radius:var(--radius-lg)}.intro-copy-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(34px,7vw,110px);align-items:end;margin-top:clamp(42px,7vw,90px)}.intro-copy-grid h2{font-size:clamp(44px,7vw,104px)}.intro-copy-grid p{font-size:clamp(18px,2.15vw,28px);line-height:1.2;letter-spacing:-.033em;color:#585348}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(6,17,15,.13);border-radius:var(--radius);overflow:hidden;margin-top:44px}.stat{background:var(--sand-3);padding:26px}.stat strong{display:block;font-size:clamp(32px,4vw,58px);font-weight:560;letter-spacing:-.05em;line-height:.95}.stat span{display:block;margin-top:8px;color:var(--muted);font-weight:650}
.cards-stage{position:relative;min-height:clamp(640px,88vw,1080px);overflow:hidden;background:var(--sand-2)}.cards-stage .stage-title{position:sticky;top:calc(var(--topbar-h) + var(--header-h) + 34px);padding-top:clamp(58px,8vw,105px);z-index:2}.cards-stage h2{font-size:clamp(54px,9vw,140px);max-width:9ch}.service-lane{position:absolute;top:clamp(250px,30vw,410px);left:max(var(--gutter),calc((100vw - var(--maxw))/2 + var(--gutter)));display:flex;gap:34px;will-change:transform}.service-card{width:clamp(270px,28vw,390px);min-height:clamp(310px,35vw,470px);background:var(--dark);color:#fff;border-radius:var(--radius);padding:clamp(30px,4vw,48px);display:flex;flex-direction:column;justify-content:flex-end;box-shadow:0 20px 60px rgba(0,0,0,.1);transition:transform .5s var(--ease),background .3s}.service-card:hover{transform:translateY(-12px);background:#061613}.service-card .num{position:absolute;margin-top:-60px;color:var(--accent-2);font-weight:750}.service-card h3{font-size:clamp(30px,3.2vw,48px);letter-spacing:-.05em}.service-card p{margin-top:18px;color:rgba(255,255,255,.68);font-size:17px;line-height:1.35}.service-card.is-light{background:var(--sand-3);color:var(--ink)}.service-card.is-light p{color:#6a6358}
.advice-panel{display:grid;grid-template-columns:.9fr 1.1fr;min-height:620px;background:var(--dark);color:#fff}.advice-panel .advice-media{position:relative;overflow:hidden}.advice-panel .advice-media img{width:100%;height:100%;object-fit:cover;filter:saturate(.9)}.advice-panel .advice-content{padding:clamp(44px,7vw,96px);display:flex;flex-direction:column;justify-content:center}.advice-panel h2{font-size:clamp(48px,7vw,104px)}.advice-panel p{max-width:560px;margin-top:24px;color:rgba(255,255,255,.69);font-size:clamp(18px,2vw,23px);line-height:1.28;letter-spacing:-.025em}.advice-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:38px;background:var(--line-dark);border-radius:var(--radius);overflow:hidden}.advice-step{background:var(--dark-soft);padding:24px}.advice-step strong{display:block;color:var(--accent-2);font-size:14px;margin-bottom:13px}.advice-step span{font-size:18px;font-weight:650;letter-spacing:-.02em}
.proj-head{display:flex;justify-content:space-between;align-items:end;gap:24px}.proj-head h2{font-size:clamp(48px,8vw,120px)}.carousel{display:flex;gap:28px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;margin-top:48px;padding-left:max(var(--gutter),calc((100% - var(--maxw))/2 + var(--gutter)));padding-right:var(--gutter);padding-bottom:6px;cursor:grab;scroll-padding-left:max(var(--gutter),calc((100% - var(--maxw))/2 + var(--gutter)))}.carousel::-webkit-scrollbar{display:none}.carousel.dragging{cursor:grabbing;scroll-snap-type:none}.carousel.dragging .pcard{pointer-events:none}.pcard{flex:0 0 clamp(280px,31vw,410px);height:clamp(320px,38vw,520px);scroll-snap-align:start;border-radius:var(--radius);background:var(--dark);color:#fff;position:relative;overflow:hidden;display:block}.pcard .ph{position:absolute;inset:0;opacity:0;transition:opacity .38s var(--ease),transform .7s var(--ease);transform:scale(1.04)}.pcard .ph img{width:100%;height:100%;object-fit:cover}.pcard::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(2,11,10,.86),rgba(2,11,10,.15));opacity:0;transition:opacity .35s}.pcard:hover .ph,.pcard:focus-visible .ph{opacity:1;transform:scale(1)}.pcard:hover::after,.pcard:focus-visible::after{opacity:1}.pcard-info{position:absolute;z-index:2;inset:auto 28px 28px 28px;background:transparent;backdrop-filter:none;border-radius:0;padding:0;max-width:none}.pcard-info h3{font-size:clamp(25px,2.6vw,39px);max-width:10ch;color:#fff}.pcard-info .circle-link{margin-top:28px;color:#fff}.pcard-info .circle-link .circ{width:38px;height:38px}.carousel-track{margin-top:34px;height:3px;background:rgba(6,17,15,.14);border-radius:999px;overflow:hidden}.carousel-track .bar{height:100%;background:var(--dark);border-radius:999px;transition:width .15s,transform .15s}
.cta-photos{display:grid;grid-template-columns:1fr 1fr;gap:40px}.cta-photo{display:grid;min-height:420px;border-radius:var(--radius);overflow:hidden;position:relative;background:var(--dark);color:#fff}.cta-photo .ph{position:absolute;inset:0}.cta-photo .ph img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}.cta-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(2,11,10,.74),rgba(2,11,10,.05))}.cta-photo:hover .ph img{transform:scale(1.05)}.cta-photo h3,.cta-photo .circle-link{position:relative;z-index:2;align-self:end;margin:0 34px}.cta-photo h3{font-size:clamp(28px,3.4vw,52px);max-width:11ch;color:#fff}.cta-photo .circle-link{margin-top:18px;margin-bottom:34px;color:#fff}
.final-cta{background:var(--dark);color:#fff;padding:clamp(72px,10vw,130px) 0}.final-cta-grid{display:grid;grid-template-columns:1fr .9fr;gap:clamp(36px,7vw,100px);align-items:end}.final-cta h2{font-size:clamp(52px,8vw,128px);max-width:9ch}.final-cta p{color:rgba(255,255,255,.68);font-size:22px;line-height:1.25;letter-spacing:-.025em;max-width:550px;margin-bottom:28px}

/* ---------- subpage support ---------- */
.page-hero{position:relative;color:#fff;overflow:hidden;min-height:58svh;padding-top:calc(var(--topbar-h) + var(--header-h) + clamp(80px,9vw,130px));padding-bottom:clamp(70px,8vw,110px);background:var(--dark)}.page-hero .bgimg{position:absolute;inset:0;z-index:0}.page-hero .bgimg img{width:100%;height:100%;object-fit:cover;opacity:.72}.page-hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(2,11,10,.8),rgba(2,11,10,.25))}.page-hero .wrap{position:relative;z-index:2}.page-hero h1{font-size:clamp(48px,8vw,110px);max-width:11ch}.page-hero p{max-width:650px;margin-top:22px;color:rgba(255,255,255,.78);font-size:22px;line-height:1.25;letter-spacing:-.025em}.intro-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(38px,7vw,100px)}.intro-grid h2{font-size:clamp(42px,6vw,86px)}.intro-grid .lead,.intro-grid .body-col p{color:#5f5a50;font-size:19px;line-height:1.45}.intro-figure img,.image-band img{width:100%;object-fit:cover;border-radius:var(--radius)}.intro-figure img{height:clamp(320px,40vw,520px)}.image-band{width:min(1120px,calc(100% - var(--gutter)*2));margin-inline:auto}.image-band img{height:clamp(300px,45vw,650px)}.band-overlap{margin-bottom:0}.section--blue{background:var(--dark);color:#fff;position:relative;overflow:hidden}.section--blue .watermark{position:absolute;inset:0;opacity:.12;filter:grayscale(1)}.section--blue .watermark img{width:100%;height:100%;object-fit:cover}.section--blue>.wrap{position:relative;z-index:1}.section--blue.has-overlap{padding-top:clamp(90px,12vw,160px)}.sec-head h2{font-size:clamp(42px,6vw,86px);color:#fff}.exp-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,80px);margin-top:46px}.exp-block h3{font-size:28px;color:#fff;margin-bottom:18px}.chip-list{display:flex;flex-direction:column}.chip-list a{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line-dark);color:rgba(255,255,255,.84);font-size:18px;font-weight:650;transition:padding-left .28s var(--ease),color .28s}.chip-list a:hover{padding-left:8px;color:#fff}.chip-list .dot{width:28px;height:28px;border:1px solid rgba(255,255,255,.45);border-radius:50%;display:grid;place-items:center;font-size:12px}.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:26px;margin-top:42px}.proj-card{position:relative;border-radius:var(--radius);overflow:hidden;display:block;min-height:360px;background:var(--dark);color:#fff}.proj-card .ph{position:absolute;inset:0}.proj-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}.proj-card::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(2,11,10,.82),rgba(2,11,10,.05))}.proj-card:hover .ph img{transform:scale(1.05)}.proj-card-info{position:absolute;z-index:2;left:24px;right:24px;bottom:24px}.proj-card-info .status{display:inline-block;color:var(--accent-2);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}.proj-card-info h3{font-size:30px;color:#fff}.proj-card-info .loc{color:rgba(255,255,255,.7);margin-top:5px}.filterbar{display:flex;flex-wrap:wrap;gap:10px}.filterbar .grp{display:flex;gap:8px;flex-wrap:wrap}.pill{border:1px solid var(--line);background:var(--sand-3);color:var(--ink);border-radius:999px;padding:10px 18px;font-weight:700}.pill.active,.pill:hover{background:var(--dark);color:#fff;border-color:var(--dark)}

/* ---------- footer ---------- */
.site-footer{background:var(--sand);color:var(--ink)}.footer-cta{border-bottom:1px solid var(--line);padding:clamp(58px,8vw,98px) 0}.footer-cta .wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:end}.footer-cta h4{font-size:clamp(40px,6vw,86px);max-width:9ch}.footer-main{padding-block:clamp(48px,7vw,82px);display:grid;grid-template-columns:1.25fr 1fr 1fr 1fr;gap:40px}.footer-tagline{font-size:clamp(23px,2.5vw,34px);font-weight:560;line-height:1.05;letter-spacing:-.04em;max-width:12ch}.site-footer .brand{margin-top:32px}.site-footer .logo-img{filter:none;height:50px}.footer-col h4{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:0 0 16px}.footer-col .lbl{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-weight:750;margin:18px 0 6px}.footer-col .lbl:first-child{margin-top:0}.footer-col .big{font-size:20px;font-weight:650}.footer-col span,.footer-col address{font-style:normal;color:#575246}.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.footer-col li a{display:inline-flex;gap:8px;color:#575246;transition:gap .25s,color .25s}.footer-col li a::before{content:"›";color:var(--accent);font-weight:800}.footer-col li a:hover{gap:12px;color:var(--ink)}.footer-bottom{border-top:1px solid var(--line);padding-block:22px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;color:#777166;font-size:14px}.footer-bottom .legal,.footer-bottom .socials{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.footer-bottom .socials a{width:38px;height:38px;border-radius:50%;background:var(--dark);color:#fff;display:grid;place-items:center;transition:transform .25s,background .25s}.footer-bottom .socials a:hover{transform:translateY(-3px);background:var(--accent-2)}.footer-bottom .to-top{background:var(--accent)}

/* ---------- motion ---------- */
.reveal{opacity:0;transform:translateY(38px);transition:opacity .82s var(--ease),transform .82s var(--ease)}.reveal.in{opacity:1;transform:none}.reveal[data-delay="1"]{transition-delay:.08s}.reveal[data-delay="2"]{transition-delay:.16s}.reveal[data-delay="3"]{transition-delay:.24s}.float-in{animation:floatIn .9s var(--ease) both}.hero-project{animation:floatIn 1s .18s var(--ease) both}@keyframes floatIn{from{opacity:0;transform:translateY(28px) scale(.98)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1!important;transform:none!important}}

/* ---------- responsive ---------- */
@media(max-width:980px){:root{--topbar-h:0px;--header-h:74px}.newsbar{display:none}.site-header{top:0}.nav-main{display:none}.header-inner{justify-content:space-between}.hero{min-height:78svh}.hero-wordmark{font-size:22vw}.hero-project{display:none}.intro-spacer{height:70px}.intro-showcase{margin-top:0}.intro-copy-grid,.advice-panel,.final-cta-grid,.footer-cta .wrap,.intro-grid{grid-template-columns:1fr}.stats-row,.advice-steps{grid-template-columns:1fr}.cards-stage{min-height:860px}.service-lane{position:relative;top:auto;left:auto;padding:42px var(--gutter) 80px;overflow-x:auto;scroll-snap-type:x mandatory}.service-card{flex:0 0 280px;scroll-snap-align:start}.cards-stage .stage-title{position:relative;top:auto}.section--split{background:var(--sand-2);min-height:240px}.exp-cols,.cta-photos{grid-template-columns:1fr}.footer-main{grid-template-columns:1fr 1fr}.overlay-body{grid-template-columns:1fr}.advice-panel .advice-media{min-height:360px}.menu-list a{font-size:31px}}
@media(max-width:620px){body{font-size:16px}.brand .logo-img{height:36px}.header-right{gap:10px}.hero-inner{padding-bottom:72px}.hero h1{font-size:clamp(47px,16vw,72px)}.hero-lead{font-size:18px}.btn{width:100%}.hero-actions .circle-link{width:100%}.intro-showcase img{height:360px}.stats-row{margin-top:30px}.advice-panel .advice-content{padding:42px 24px}.footer-main,.footer-cta .wrap{grid-template-columns:1fr}.footer-bottom{align-items:flex-start}.cta-photo{min-height:360px}.pcard{flex-basis:76vw;height:380px}.newsbar{display:none}}

/* Ava 2026-06-08 — homepage stability fixes
   Keep Trison-inspired rhythm, but prevent broken empty sections when JS/reveal/hover state does not run. */
body[data-page="home"] .reveal,
body[data-page="home"] .reveal.in{
  opacity:1;
  transform:none;
}
body[data-page="home"] .intro-spacer{
  height:clamp(44px,8vw,110px);
}
body[data-page="home"] .intro-showcase{
  margin-top:0;
}
body[data-page="home"] .intro-showcase img{
  height:clamp(340px,46vw,650px);
  object-position:center;
}
body[data-page="home"] .cards-stage{
  min-height:clamp(520px,58vw,760px);
  padding-bottom:clamp(58px,8vw,100px);
}
body[data-page="home"] .cards-stage .stage-title{
  position:relative;
  top:auto;
  padding-top:clamp(56px,7vw,92px);
}
body[data-page="home"] .cards-stage h2{
  max-width:12ch;
}
body[data-page="home"] .service-lane{
  top:clamp(230px,24vw,310px);
}
body[data-page="home"] .advice-panel{
  min-height:0;
}
body[data-page="home"] .advice-panel .advice-media{
  min-height:clamp(360px,45vw,620px);
}
body[data-page="home"] .pcard{
  background:var(--dark);
}
body[data-page="home"] .pcard .ph{
  opacity:1;
  transform:none;
}
body[data-page="home"] .pcard::after{
  opacity:1;
  background:linear-gradient(0deg,rgba(2,11,10,.86),rgba(2,11,10,.18) 62%,rgba(2,11,10,.04));
}
body[data-page="home"] .pcard-info{
  text-shadow:0 3px 20px rgba(0,0,0,.38);
}
@media(max-width:980px){
  body[data-page="home"] .cards-stage{min-height:auto;padding-bottom:0;}
  body[data-page="home"] .service-lane{top:auto;}
}
@media(max-width:620px){
  body[data-page="home"] .intro-spacer{height:36px;}
  body[data-page="home"] .intro-showcase img{height:320px;}
  body[data-page="home"] .cards-stage .stage-title{padding-top:42px;}
}
/* Ava 2026-06-08 — service lane overlap fix */
body[data-page="home"] .cards-stage{
  min-height:auto;
  overflow:hidden;
}
body[data-page="home"] .service-lane{
  position:relative;
  top:auto;
  left:auto;
  margin-top:clamp(34px,5vw,64px);
  padding-left:max(var(--gutter),calc((100vw - var(--maxw))/2 + var(--gutter)));
  padding-right:var(--gutter);
  padding-bottom:clamp(72px,8vw,112px);
}
body[data-page="home"] .service-card{
  flex:0 0 clamp(280px,28vw,390px);
}
@media(max-width:980px){
  body[data-page="home"] .service-lane{
    margin-top:0;
    padding-top:36px;
    padding-bottom:72px;
  }
}
/* Ava 2026-06-08 — official Labelbewust logo lockup */
.brand{gap:10px;align-items:center;flex-shrink:0;}
.brand .logo-img{height:44px!important;width:44px!important;object-fit:contain;filter:none!important;}
.brand-text{display:flex;flex-direction:column;line-height:1;color:currentColor;min-width:0;}
.brand-text strong{font-size:20px;font-weight:780;letter-spacing:-.035em;text-transform:lowercase;}
.brand-text small{margin-top:4px;font-size:9.5px;font-weight:700;letter-spacing:.08em;color:color-mix(in srgb,currentColor 68%,transparent);white-space:nowrap;}
.site-footer .brand .logo-img{height:50px!important;width:50px!important;}
.site-footer .brand-text strong{font-size:22px;}
.site-footer .brand-text small{color:#6b655b;}
.overlay .brand-text small{color:rgba(255,255,255,.62);}
@media(max-width:620px){
  .brand .logo-img{height:38px!important;width:38px!important;}
  .brand-text strong{font-size:18px;}
  .brand-text small{display:none;}
}


/* Ava 2026-06-08 — Danish feedback: offerteformulier en premium renovatiepositionering */
.form-wrap{max-width:920px;margin-inline:auto}.quote-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(26px,5vw,56px);box-shadow:0 24px 80px rgba(2,11,10,.08)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.quote-form label,.quote-form legend{font-weight:750;letter-spacing:-.015em}.quote-form input[type="text"],.quote-form input[type="email"],.quote-form input[type="tel"],.quote-form input[type="file"],.quote-form textarea{width:100%;margin-top:8px;border:1.5px solid var(--line);border-radius:14px;background:var(--sand-3);padding:14px 15px;color:var(--ink);outline:none}.quote-form textarea{resize:vertical}.quote-form input:focus,.quote-form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(52,179,111,.12)}.quote-form fieldset{border:1.5px solid var(--line);border-radius:18px;margin:24px 0;padding:22px}.check-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}.check-grid label{font-weight:600;background:var(--sand-3);border-radius:12px;padding:12px;display:flex;gap:9px;align-items:flex-start}.form-help{display:block;margin-top:8px;color:var(--muted);font-size:14px}.hp{position:absolute!important;left:-9999px!important}.section--warm .section-copy{color:#5f5a50}.footer-bottom .socials a[aria-label="TikTok"]{font-size:11px;font-weight:800;letter-spacing:.02em;width:auto;padding-inline:13px;border-radius:999px}@media(max-width:760px){.form-grid,.check-grid{grid-template-columns:1fr}.quote-form{padding:24px}.footer-bottom .socials a[aria-label="TikTok"]{width:38px;padding:0;font-size:10px}}

/* Jarvis 2026-06-23 — kop-leesbaarheid: rustiger regelafstand, minder krappe tracking, consistentere display-schaal */
h1,h2,h3,h4{line-height:1.05;letter-spacing:-.02em}
.service-card h3,.stat strong{letter-spacing:-.025em}
.hero h1,.cards-stage h2,.final-cta h2{font-size:clamp(46px,6.6vw,100px)}
.proj-head h2{font-size:clamp(42px,5.8vw,92px)}
.section-title,.intro-copy-grid h2,.advice-panel h2{font-size:clamp(40px,5.4vw,88px)}
.intro-grid h2,.sec-head h2,.footer-cta h4{font-size:clamp(38px,5vw,80px)}

/* Jarvis 2026-06-23 — SEO dienst-landingspagina's: gedeelde componenten */
.breadcrumb{display:flex;flex-wrap:wrap;gap:9px;align-items:center;font-size:13.5px;font-weight:600;color:rgba(255,255,255,.82);margin-bottom:18px}
.breadcrumb a{color:rgba(255,255,255,.82);transition:color .2s var(--ease)}
.breadcrumb a:hover{color:#fff}
.breadcrumb .sep{opacity:.45}
.breadcrumb .cur{color:#fff}
.svc-list{list-style:none;margin:22px 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:13px 30px}
.svc-list li{position:relative;padding-left:32px;color:#5f5a50;font-size:16.5px;line-height:1.45}
.svc-list li::before{content:"✓";position:absolute;left:0;top:1px;width:21px;height:21px;border-radius:50%;background:color-mix(in srgb,var(--accent) 16%,#fff);color:var(--accent);font-size:12px;font-weight:800;display:grid;place-items:center}
.svc-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px}
.svc-step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.svc-step .n{font-family:var(--font-head);font-weight:750;font-size:15px;color:var(--accent);letter-spacing:.04em}
.svc-step h3{font-size:21px;margin:12px 0 8px}
.svc-step p{margin:0;color:#6a6358;font-size:15.5px;line-height:1.5}
.svc-why{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:46px}
.svc-why .value{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.svc-why .value h3{font-size:20px;margin-bottom:10px}
.svc-why .value p{color:#6a6358;font-size:15.5px;line-height:1.5;margin:0}
.svc-faq{max-width:840px;margin-top:34px}
.svc-faq details{border-bottom:1px solid var(--line)}
.svc-faq summary{cursor:pointer;list-style:none;padding:20px 0;font-family:var(--font-head);font-weight:600;font-size:clamp(18px,2.1vw,21px);letter-spacing:-.01em;display:flex;justify-content:space-between;align-items:center;gap:18px;color:var(--ink)}
.svc-faq summary::-webkit-details-marker{display:none}
.svc-faq summary::after{content:"+";font-size:24px;font-weight:400;color:var(--accent);transition:transform .25s var(--ease);flex:0 0 auto}
.svc-faq details[open] summary::after{content:"–"}
.svc-faq details p{margin:0 0 22px;color:#5f5a50;font-size:16.5px;line-height:1.6;max-width:760px}
.area-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.area-list span,.area-list a{padding:10px 16px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:650;color:var(--ink);transition:border-color .2s var(--ease),color .2s var(--ease)}
.area-list a:hover{border-color:var(--accent);color:var(--accent)}
.svc-related{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:22px;margin-top:42px}
.svc-cta-band{background:var(--dark);color:#fff;border-radius:var(--radius-lg);padding:clamp(34px,5vw,60px);display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between;margin-top:clamp(40px,6vw,72px)}
.svc-cta-band h2{font-size:clamp(28px,3.4vw,42px);max-width:18ch}
.svc-cta-band p{color:rgba(255,255,255,.7);margin:10px 0 0;max-width:46ch}
@media(max-width:760px){.svc-list,.svc-steps,.svc-why{grid-template-columns:1fr}}

/* Jarvis 2026-06-23 — UX/UI audit fixes: toegankelijkheid, contrast, focus, motion */
/* Contrast: gedempte tekst donkerder zodat AA (4.5:1) gehaald wordt op lichte achtergrond */
:root{--muted:#67625a}
.footer-bottom{color:#5e594f}
/* Knoppen: groen iets dieper zodat witte tekst AA (>=4.5:1) haalt. Header-CTA gebruikte fel --accent (2.68:1), gewone knop 4.1:1 */
.btn,.btn--green{background:#187a48}
.btn:hover,.btn--green:hover{background:#136338}
/* Footer micro-labels (Contact/Openingstijden): fel groen op zand was 2.13:1, nu donkergroen ~5.5:1 */
.footer-col .lbl{color:#15663d}
/* Sectie-titels standaard donker; alleen wit op donkere secties (sec-head h2 was globaal #fff -> wit op lichte content) */
.sec-head h2{color:var(--ink)}
.section--dark .sec-head h2,.section--blue .sec-head h2{color:#fff}
/* Eyebrows/kickers op donkere achtergronden licht en leesbaar houden (anders te grijs) */
.page-hero .eyebrow,.page-hero .kicker,.section--dark .eyebrow,.section--dark .kicker,.advice-panel .kicker,.advice-panel .eyebrow,.final-cta .kicker,.final-cta .eyebrow,.section--blue .eyebrow{color:rgba(255,255,255,.86)}
/* Zichtbare focus voor toetsenbordnavigatie */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,summary:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:5px}
.menu-btn:focus-visible,.overlay-close:focus-visible,.hero-scroll-btn:focus-visible{outline:3px solid var(--accent);outline-offset:3px}
/* Grotere tap-targets in footer op mobiel */
.footer-col li a{padding-block:4px}
.footer-bottom .legal a,.footer-bottom .socials a{padding-block:2px}
/* Respecteer bewegingsvoorkeur: geen animaties, content altijd zichtbaar */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .float-in,.hero-project,.hero video,.hero .hero-fallback{animation:none!important}
}
