/* =====================================================================
   Converzo — Modern dark homepage (staging)
   Scope: loaded on the front page only. Heavy layout rules are scoped
   under body.home / .cz-modern so the rest of the site is untouched.
   Brand: teal #029ca6 / #14757b, dark charcoal, Open Sans.
   ===================================================================== */

:root{
  --cz-teal:#029ca6;
  --cz-teal-2:#14757b;
  --cz-teal-soft:rgba(2,156,166,.14);
  --cz-bg:#0c0d10;
  --cz-bg-2:#121419;
  --cz-bg-3:#171a21;
  --cz-line:rgba(255,255,255,.10);
  --cz-text:#f3f5f7;
  --cz-muted:rgba(243,245,247,.62);
  --cz-faint:rgba(243,245,247,.40);
  --cz-radius:18px;
  --cz-ease:cubic-bezier(.22,1,.36,1);
  --cz-maxw:1280px;
  --cz-pad:clamp(20px,5vw,80px);
  --cz-font:'Open Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}

/* ---- Base (front page) ------------------------------------------------ */
body.cz-skin{background:var(--cz-bg);color:var(--cz-text);font-family:var(--cz-font);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;}
body.cz-skin #body-bg{display:none;}
/* pull hero/video to the very top (drop theme's .main-content top margin) */
body.home .cz-modern{margin-top:0;}
html.lenis,html.lenis body{height:auto;}
.lenis.lenis-smooth{scroll-behavior:auto !important;}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain;}
.lenis.lenis-stopped{overflow:hidden;}
body.home a{color:inherit;text-decoration:none;}
body.home img{max-width:100%;display:block;}
.cz-modern *{box-sizing:border-box;}

/* Ambient teal glows */
.cz-modern{position:relative;background:var(--cz-bg);}
.cz-glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5;pointer-events:none;z-index:0;}
.cz-glow--1{width:46vw;height:46vw;background:radial-gradient(circle,rgba(2,156,166,.55),transparent 70%);top:-10vw;right:-8vw;}
.cz-glow--2{width:40vw;height:40vw;background:radial-gradient(circle,rgba(20,117,123,.45),transparent 70%);top:120vh;left:-12vw;}

.cz-wrap{max-width:var(--cz-maxw);margin:0 auto;padding-left:var(--cz-pad);padding-right:var(--cz-pad);position:relative;z-index:2;}
.cz-section{padding-block:clamp(48px,7vh,96px);position:relative;z-index:2;}

/* ---- Typography ------------------------------------------------------- */
.cz-modern h1,.cz-modern h2,.cz-modern h3{font-family:var(--cz-font);font-weight:800;line-height:1.02;letter-spacing:-.02em;color:#fff;margin:0;}
.cz-h2{font-size:clamp(2rem,4.6vw,4rem);line-height:1.04;}
.cz-eyebrow{display:inline-flex;align-items:center;gap:.6em;font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--cz-teal);margin:0 0 1.4rem;}
.cz-eyebrow::before{content:"";width:34px;height:1px;background:var(--cz-teal);display:inline-block;}
.cz-lead{font-size:clamp(1.05rem,1.5vw,1.35rem);line-height:1.65;color:var(--cz-muted);font-weight:300;max-width:54ch;}
.cz-teal{color:var(--cz-teal);}

/* ---- Buttons ---------------------------------------------------------- */
.cz-btn{position:relative;display:inline-flex;align-items:center;gap:.7em;font-weight:700;font-size:.95rem;letter-spacing:.01em;padding:1.05em 1.9em;border-radius:100px;border:1px solid transparent;cursor:pointer;transition:transform .4s var(--cz-ease),background .4s var(--cz-ease),color .4s var(--cz-ease),border-color .4s var(--cz-ease);will-change:transform;}
.cz-btn svg{width:16px;height:16px;transition:transform .4s var(--cz-ease);}
.cz-btn--primary{background:var(--cz-teal);color:#04181a;}
.cz-btn--primary:hover{background:#06b9c4;transform:translateY(-2px);}
.cz-btn--primary:hover svg{transform:translateX(4px);}
.cz-btn--ghost{border-color:var(--cz-line);color:#fff;}
.cz-btn--ghost:hover{border-color:var(--cz-teal);color:var(--cz-teal);transform:translateY(-2px);}
.cz-btn-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:2.4rem;}

/* ======================================================================
   HEADER (front page) — transparent over hero, floating glass pill on
   scroll. Logo = original logo.svg rendered white. Robust menu resets.
   ====================================================================== */
body.cz-skin header#header{position:fixed;top:0;left:0;right:0;z-index:60;padding:16px 0;background:transparent !important;border-bottom:0 !important;transition:padding .45s var(--cz-ease);}
body.cz-skin header#header.cz-scrolled{padding:12px 0;}
body.cz-skin header#header .wrapper{max-width:var(--cz-maxw);margin:0 auto;padding-left:var(--cz-pad);padding-right:var(--cz-pad);display:flex;align-items:center;justify-content:flex-start;gap:20px;border:1px solid transparent;border-radius:100px;transition:background .45s var(--cz-ease),box-shadow .45s var(--cz-ease),border-color .45s var(--cz-ease),padding .45s var(--cz-ease);}
body.cz-skin header#header.cz-scrolled .wrapper{background:rgba(16,18,23,.72);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-color:var(--cz-line);box-shadow:0 14px 50px rgba(0,0,0,.40);padding:8px 12px 8px 24px;}
/* desktop: always show the sticky/glass header (not only after scroll) */
@media(min-width:981px){
  body.cz-skin header#header .wrapper{background:rgba(16,18,23,.72);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-color:var(--cz-line);box-shadow:0 14px 50px rgba(0,0,0,.40);padding:8px 12px 8px 24px;}
}
/* logo: original asset, forced white */
body.cz-skin header#header .logo{margin-right:auto;display:flex;align-items:center;}
body.cz-skin header#header .logo img{height:34px;width:auto;filter:brightness(0) invert(1);}
body.cz-skin header#header .wrapper .clear{display:none;}
/* menu bar */
body.cz-skin header#header .menuBar{display:flex;align-items:center;gap:22px;flex-wrap:nowrap;}
body.cz-skin header#header nav#menu>div,body.cz-skin header#header nav#menu .menu-menu-1-container{display:block;}
body.cz-skin header#header nav#menu ul{display:flex;flex-wrap:nowrap;align-items:center;gap:24px;list-style:none;margin:0;padding:0;white-space:nowrap;}
body.cz-skin header#header nav#menu li{margin:0;padding:0;float:none;list-style:none;background:none;white-space:nowrap;}
body.cz-skin header#header nav#menu a{display:inline-block;font-size:.92rem;font-weight:600;white-space:nowrap;color:rgba(255,255,255,.82);position:relative;padding:6px 0;background:none;transition:color .3s;}
body.cz-skin header#header nav#menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--cz-teal);transition:width .35s var(--cz-ease);}
body.cz-skin header#header nav#menu a:hover{color:#fff;}
body.cz-skin header#header nav#menu a:hover::after{width:100%;}
/* phone number item -> subtle pill */
body.cz-skin header#header nav#menu li:last-child a{color:var(--cz-teal);font-weight:700;}
body.cz-skin header#header nav#menu li:last-child a::after{display:none;}
/* injected CTA */
.cz-nav-cta{padding:.7em 1.4em !important;font-size:.86rem !important;white-space:nowrap;}
/* hamburger */
body.cz-skin header#header .mobile_bar{display:none;flex-direction:column;gap:5px;cursor:pointer;}
body.cz-skin header#header .mobile_bar span{width:26px;height:2px;background:#fff;display:block;}
@media(max-width:980px){
  body.cz-skin header#header nav#menu{display:none;}
  body.cz-skin header#header .cz-nav-cta{display:none !important;}
  body.cz-skin header#header .mobile_bar{display:flex;}
}

/* ======================================================================
   HERO — background video + animated headline
   ====================================================================== */
.cz-hero{min-height:100svh;display:flex;align-items:center;position:relative;padding-top:120px;padding-bottom:60px;overflow:hidden;background:var(--cz-bg);}
.cz-hero__video{position:absolute;inset:0;z-index:0;overflow:hidden;}
.cz-hero__video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.cz-hero__veil{position:absolute;inset:0;background:
   linear-gradient(180deg,rgba(12,13,16,.55) 0%,rgba(12,13,16,.66) 45%,rgba(12,13,16,.92) 88%,var(--cz-bg) 100%),
   linear-gradient(90deg,rgba(12,13,16,.80) 0%,rgba(12,13,16,.28) 60%,rgba(12,13,16,0) 100%);}
.cz-hero .cz-glow--1{opacity:.35;mix-blend-mode:screen;}
.cz-hero__inner{position:relative;z-index:3;width:100%;}
.cz-hero__title{font-size:clamp(2.7rem,8.2vw,7.6rem);font-weight:800;line-height:1.22;letter-spacing:-.03em;color:#fff;max-width:16ch;}
.cz-hero__title .cz-teal{color:var(--cz-teal);}
.cz-hero__sub{margin-top:1.8rem;}
/* word-reveal mask — extra bottom room so descenders (g, j, p) aren't clipped */
.cz-word{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.18em;margin-bottom:-.18em;}
.cz-word>span{display:inline-block;will-change:transform;}
.cz-hero__scroll{position:absolute;bottom:30px;left:var(--cz-pad);display:flex;align-items:center;gap:12px;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cz-faint);z-index:3;}
.cz-hero__scroll i{width:22px;height:34px;border:1px solid var(--cz-line);border-radius:12px;position:relative;display:inline-block;}
.cz-hero__scroll i::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;border-radius:3px;background:var(--cz-teal);transform:translateX(-50%);animation:cz-wheel 1.7s var(--cz-ease) infinite;}
@keyframes cz-wheel{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,12px)}}

/* Service marquee under hero */
.cz-marquee{border-top:1px solid var(--cz-line);border-bottom:1px solid var(--cz-line);padding:18px 0;overflow:hidden;white-space:nowrap;position:relative;z-index:2;}
.cz-marquee__track{display:inline-flex;gap:48px;align-items:center;animation:cz-marq 28s linear infinite;}
.cz-marquee span{font-size:clamp(1.1rem,2vw,1.6rem);font-weight:800;letter-spacing:-.01em;color:rgba(255,255,255,.30);text-transform:uppercase;display:inline-flex;align-items:center;gap:48px;}
.cz-marquee span::after{content:"✶";color:var(--cz-teal);font-size:.8em;}
@keyframes cz-marq{to{transform:translateX(-50%)}}

/* ---- Intro / statement ------------------------------------------------ */
.cz-statement__title{font-size:clamp(1.9rem,4.4vw,3.7rem);font-weight:800;line-height:1.08;letter-spacing:-.02em;color:#fff;max-width:18ch;}
.cz-statement__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(30px,5vw,80px);align-items:end;}
.cz-reveal-line{display:block;overflow:hidden;}
.cz-reveal-line>span{display:block;will-change:transform;}
@media(max-width:820px){.cz-statement__grid{grid-template-columns:1fr;align-items:start;}}

/* ---- Services --------------------------------------------------------- */
.cz-services__head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:clamp(34px,5vw,64px);flex-wrap:wrap;}
.cz-svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;}
.cz-card{position:relative;display:flex;flex-direction:column;justify-content:flex-end;min-height:380px;padding:34px;border-radius:var(--cz-radius);border:1px solid var(--cz-line);background:var(--cz-bg-2);overflow:hidden;isolation:isolate;transition:transform .5s var(--cz-ease),border-color .5s var(--cz-ease);}
.cz-card:hover{transform:translateY(-6px);border-color:rgba(2,156,166,.5);}
.cz-card__media{position:absolute;inset:0;z-index:-2;}
.cz-card__media img{width:100%;height:100%;object-fit:cover;opacity:.34;transform:scale(1.05);transition:opacity .6s var(--cz-ease),transform .9s var(--cz-ease);}
.cz-card:hover .cz-card__media img{opacity:.5;transform:scale(1.12);}
.cz-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(12,13,16,.15) 0%,rgba(12,13,16,.78) 62%,rgba(12,13,16,.96) 100%);}
.cz-card__num{font-size:.8rem;font-weight:700;letter-spacing:.18em;color:var(--cz-teal);margin-bottom:auto;}
.cz-card__title{font-size:clamp(1.5rem,2.4vw,2.1rem);font-weight:800;color:#fff;margin:0 0 .6rem;letter-spacing:-.01em;}
.cz-card__text{color:var(--cz-muted);font-size:1rem;line-height:1.6;font-weight:300;margin:0 0 1.2rem;max-width:46ch;}
.cz-card__link{display:inline-flex;align-items:center;gap:.6em;font-weight:700;font-size:.92rem;color:#fff;}
.cz-card__link svg{width:15px;height:15px;color:var(--cz-teal);transition:transform .4s var(--cz-ease);}
.cz-card:hover .cz-card__link svg{transform:translateX(5px);}
@media(max-width:760px){.cz-svc-grid{grid-template-columns:1fr;}.cz-card{min-height:320px;}}

/* ---- Stats ------------------------------------------------------------ */
.cz-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;border-top:1px solid var(--cz-line);border-bottom:1px solid var(--cz-line);padding-block:clamp(40px,6vw,72px);}
.cz-stat__num{font-size:clamp(2.6rem,6vw,5rem);font-weight:800;letter-spacing:-.03em;color:#fff;line-height:1;}
.cz-stat__num .cz-teal{color:var(--cz-teal);}
.cz-stat__label{margin-top:.7rem;color:var(--cz-muted);font-size:.95rem;font-weight:300;}
@media(max-width:820px){.cz-stats{grid-template-columns:repeat(2,1fr);gap:36px 24px;}}

/* ---- Cases: pinned horizontal scroll, image-led project cards --------- */
.cz-cases{position:relative;background:var(--cz-bg);overflow:hidden;}
.cz-cases__pin{height:100svh;display:flex;align-items:center;overflow:hidden;}
.cz-cases__track{display:flex;align-items:stretch;gap:26px;padding-inline:var(--cz-pad);will-change:transform;}
.cz-cases__intro{flex:0 0 auto;width:min(80vw,420px);display:flex;flex-direction:column;justify-content:center;padding-right:20px;}
.cz-cases__hint{display:flex;align-items:center;gap:10px;color:var(--cz-faint);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-top:18px;}
.cz-cases__hint svg{width:16px;height:16px;}
.cz-case{flex:0 0 auto;display:flex;flex-direction:column;border-radius:var(--cz-radius);border:1px solid var(--cz-line);background:var(--cz-bg-2);transition:border-color .4s var(--cz-ease),transform .4s var(--cz-ease);overflow:hidden;}
.cz-case:hover{border-color:rgba(2,156,166,.5);}
.cz-case--project{width:min(86vw,470px);height:min(70svh,580px);}
/* Thumb is a CSS background (ShortPixel serves these sharp at w_1920) rather
   than an <img> (which it sized to the small measured width -> blurry). */
.cz-case--project .cz-case__thumb{display:block;flex:1 1 auto;min-height:0;overflow:hidden;background:transparent center/cover no-repeat;transition:transform .9s var(--cz-ease);transform-origin:center;}
.cz-case--project:hover .cz-case__thumb{transform:scale(1.06);}
.cz-case__body{display:flex;flex-direction:column;gap:.55rem;padding:26px 28px 30px;}
.cz-case__cat{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--cz-teal);}
.cz-case--project .cz-case__title{font-size:clamp(1.35rem,2vw,1.85rem);font-weight:800;color:#fff;letter-spacing:-.01em;line-height:1.05;margin:0;}
.cz-case__body .cz-case__link{display:inline-flex;align-items:center;gap:.5em;font-weight:700;font-size:.9rem;color:#fff;margin-top:.5rem;}
.cz-case__body .cz-case__link svg{width:15px;height:15px;color:var(--cz-teal);transition:transform .4s var(--cz-ease);}
.cz-case--project:hover .cz-case__link svg{transform:translateX(5px);}
.cz-case--all{width:min(74vw,330px);background:linear-gradient(150deg,var(--cz-teal-2),var(--cz-teal));justify-content:flex-end;padding:34px;}
.cz-case--all .cz-case__allinner{display:flex;flex-direction:column;gap:.6rem;}
.cz-case--all .cz-case__cat{color:rgba(4,24,26,.7);}
.cz-case--all .cz-case__title{color:#04181a;font-size:clamp(1.6rem,2.4vw,2.2rem);}
.cz-case--all .cz-case__link{color:#04181a;display:inline-flex;align-items:center;gap:.5em;font-weight:700;}
.cz-case--all .cz-case__link svg{width:15px;height:15px;color:#04181a;}
.cz-cases.cz-no-pin .cz-cases__pin{height:auto;display:block;}
.cz-cases.cz-no-pin .cz-cases__track{overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;padding-block:10px;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;}
.cz-cases.cz-no-pin .cz-cases__track::-webkit-scrollbar{display:none;}
.cz-cases.cz-no-pin .cz-cases__track.cz-dragging{cursor:grabbing;scroll-snap-type:none;user-select:none;}
.cz-cases.cz-no-pin .cz-cases__track.cz-dragging a{pointer-events:none;}
.cz-cases.cz-no-pin .cz-case{scroll-snap-align:center;}

/* ---- Onze klanten: logo pills + seamless marquee --------------------- */
.cz-clients__head{max-width:60ch;margin-bottom:clamp(24px,3vw,40px);}
.cz-logos{overflow:hidden;position:relative;padding-block:6px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.cz-logos__track{display:inline-flex;align-items:center;gap:18px;animation:cz-marq 40s linear infinite;white-space:nowrap;will-change:transform;}
.cz-logo{display:inline-flex;align-items:center;justify-content:center;height:84px;min-width:170px;padding:0 30px;background:rgba(255,255,255,.035);border:1px solid var(--cz-line);border-radius:16px;transition:background .35s var(--cz-ease),border-color .35s var(--cz-ease),transform .35s var(--cz-ease);}
.cz-logo:hover{background:var(--cz-teal-soft);border-color:rgba(2,156,166,.5);transform:translateY(-3px);}
.cz-logo img{height:40px;max-width:130px;width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.6;transition:opacity .35s;}
.cz-logo:hover img{opacity:1;}

/* ---- Big quote -------------------------------------------------------- */
.cz-quote{text-align:center;}
.cz-quote__text{font-size:clamp(1.8rem,4.4vw,3.8rem);font-weight:800;line-height:1.12;letter-spacing:-.02em;color:#fff;max-width:20ch;margin:0 auto;}

/* ---- CTA / Kop koffie doen (with Stefan & Luc photo) ------------------ */
.cz-cta{position:relative;border-radius:clamp(20px,3vw,34px);padding:clamp(48px,8vw,110px) var(--cz-pad);text-align:center;background:linear-gradient(135deg,var(--cz-teal-2),var(--cz-teal));overflow:hidden;}
.cz-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.22),transparent 55%);z-index:1;}
.cz-cta--photo{background:var(--cz-bg-3);}
.cz-cta__photo{position:absolute;inset:0;background-size:cover;background-position:center 28%;z-index:0;}
.cz-cta--photo::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(20,117,123,.90) 0%,rgba(2,156,166,.80) 55%,rgba(2,156,166,.66) 100%);z-index:1;}
.cz-cta__content{position:relative;z-index:2;}
.cz-cta__title{font-size:clamp(2.1rem,5.4vw,4.6rem);font-weight:800;letter-spacing:-.03em;color:#04181a;line-height:1;}
.cz-cta__text{color:rgba(4,24,26,.82);font-size:1.1rem;margin:1.2rem auto 0;max-width:46ch;font-weight:400;}
.cz-cta .cz-btn{margin-top:2.4rem;background:#04181a;color:#fff;}
.cz-cta .cz-btn:hover{background:#000;transform:translateY(-2px);}

/* ---- Reveal utilities ------------------------------------------------- */
.cz-reveal{opacity:0;transform:translateY(34px);}
.cz-ready .cz-reveal{transition:opacity .9s var(--cz-ease),transform .9s var(--cz-ease);}
.cz-reveal.cz-in{opacity:1;transform:none;}
.no-js .cz-reveal,html:not(.cz-ready) .cz-reveal{opacity:1;transform:none;}

/* ---- Custom cursor ---------------------------------------------------- */
.cz-cursor,.cz-cursor-dot{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;mix-blend-mode:difference;will-change:transform;}
.cz-cursor{width:40px;height:40px;border:1px solid rgba(255,255,255,.7);transform:translate(-50%,-50%);transition:width .3s var(--cz-ease),height .3s var(--cz-ease),background .3s var(--cz-ease);}
.cz-cursor-dot{width:6px;height:6px;background:#fff;transform:translate(-50%,-50%);}
.cz-cursor.cz-hover{width:64px;height:64px;background:rgba(255,255,255,.12);}
body.cz-has-cursor,body.cz-has-cursor *{cursor:none !important;}
@media(hover:none),(pointer:coarse){.cz-cursor,.cz-cursor-dot{display:none !important;}body.cz-has-cursor,body.cz-has-cursor *{cursor:auto !important;}}

/* ---- Fixed Google reviews badge (scrolls along, bottom-left) --------- */
.cz-reviews{position:fixed;left:20px;bottom:20px;z-index:45;width:210px;}
.cz-reviews__inner{background:rgba(16,18,23,.82);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:0;border-radius:16px;padding:14px 16px;box-shadow:0 16px 50px rgba(0,0,0,.45);color:#fff;}
.cz-reviews__inner .rpi,.cz-reviews__inner .rpi *{color:#f3f5f7;}
.cz-reviews__inner a{color:#fff;}
.cz-reviews__inner img{max-width:100%;height:auto;}
@media(max-width:1280px){.cz-reviews{display:none;}}

/* ======================================================================
   FOOTER (front page) — compact dark footer + clean contact form
   ====================================================================== */
body.cz-skin footer{background:var(--cz-bg-2);border-top:1px solid var(--cz-line);padding-block:clamp(20px,2.6vw,32px);color:var(--cz-muted);font-weight:300;}
/* Hide the floating "kop koffie doen" coffee-cup CTA on the contact page. */
body.page-id-8579 .coffee_cup{display:none !important;}
/* Hide the "Over Converzo" block on the Over ons page (page-id 1224). */
body.page-id-1224 .tldr_overons{display:none !important;}
body.cz-skin footer .wrapper{max-width:var(--cz-maxw);margin:0 auto;padding-inline:var(--cz-pad);}
body.cz-skin footer .footer_logo img{width:300px;height:auto;max-width:100%;margin-bottom:16px;filter:brightness(0) invert(1);}
body.cz-skin footer .footer_inner{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,4vw,64px);align-items:start;}
body.cz-skin footer h3{color:#fff;font-size:1rem;font-weight:700;letter-spacing:.02em;margin:0 0 14px;}
body.cz-skin footer a{color:var(--cz-muted);text-decoration:none;transition:color .3s var(--cz-ease);}
body.cz-skin footer a:hover{color:var(--cz-teal);}
body.cz-skin footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px;}
body.cz-skin footer li{float:none;margin:0;}
body.cz-skin footer .footer_content{display:flex;gap:clamp(28px,5vw,56px);flex-wrap:wrap;}
body.cz-skin footer .footer_address{line-height:1.8;font-size:.92rem;}
body.cz-skin footer .copy_right{margin-top:18px;padding-top:14px;border-top:1px solid var(--cz-line);display:flex;justify-content:space-between;align-items:center;gap:10px 18px;flex-wrap:nowrap;font-size:.76rem;}
body.cz-skin footer .copy_right p{white-space:nowrap;}
body.cz-skin footer .copy_right ul{flex-direction:row;gap:4px 14px;flex-wrap:nowrap;font-size:.74rem;}
body.cz-skin footer .copy_right ul a{white-space:nowrap;}
body.cz-skin footer .copy_right p{margin:0;}
/* contact form */
body.cz-skin footer .contact_section .wpcf7{max-width:309px;}
body.cz-skin footer .contact_section p{margin:0;}
body.cz-skin footer .contact_section input:not([type=submit]):not([type=checkbox]):not([type=radio]),
body.cz-skin footer .contact_section textarea{width:100%;background:var(--cz-bg-3);border:1px solid var(--cz-line);border-radius:10px;padding:12px 14px;color:#fff;font-family:var(--cz-font);font-size:.95rem;margin-bottom:10px;}
body.cz-skin footer .contact_section textarea{height:96px;min-height:96px;resize:vertical;display:block;}
body.cz-skin footer .contact_section input::placeholder,body.cz-skin footer .contact_section textarea::placeholder{color:var(--cz-faint);letter-spacing:.04em;}
body.cz-skin footer .contact_section input:focus,body.cz-skin footer .contact_section textarea:focus{outline:none;border-color:var(--cz-teal);}
body.cz-skin footer .contact_section input[type=submit]{width:auto;background:var(--cz-teal);color:#04181a;border:none;border-radius:100px;padding:12px 30px;font-weight:700;font-size:.9rem;cursor:pointer;margin-top:4px;transition:background .3s,transform .3s;}
body.cz-skin footer .contact_section input[type=submit]:hover{background:#06b9c4;transform:translateY(-2px);}
body.cz-skin footer .contact_section br{display:none;}
@media(max-width:820px){
  body.cz-skin footer .footer_inner{grid-template-columns:1fr;gap:34px;}
  body.cz-skin footer .copy_right{flex-direction:column;align-items:flex-start;gap:8px;}
  /* let the legal links wrap on narrow screens instead of overflowing */
  body.cz-skin footer .copy_right ul{flex-wrap:wrap;gap:6px 14px;}
}

/* ---- Reduced motion --------------------------------------------------- */
@media(prefers-reduced-motion:reduce){
  .cz-marquee__track,.cz-logos__track,.cz-hero__scroll i::after{animation:none !important;}
  .cz-reveal{opacity:1 !important;transform:none !important;}
  html{scroll-behavior:auto !important;}
}

/* =====================================================================
   v3 — header layout fixes (override theme floats/widths), mobile menu
   overlay, mobile hero above-the-fold, mobile case cards.
   ===================================================================== */

/* Desktop header: kill theme float/width so links + CTA never overlap */
body.cz-skin header#header .logo{width:auto !important;float:none !important;}
body.cz-skin header#header .menuBar{display:flex;align-items:center;gap:20px;flex-wrap:nowrap;}
body.cz-skin header#header nav#menu{width:auto !important;float:none !important;text-align:left;display:flex;align-items:center;}
body.cz-skin header#header nav#menu .menu-menu-1-container{display:flex;align-items:center;}
body.cz-skin header#header nav#menu ul{display:flex;flex-wrap:nowrap;align-items:center;gap:22px;white-space:nowrap;margin:0;padding:0;}
body.cz-skin header#header nav#menu li{display:inline-flex;align-items:center;margin:0 !important;float:none !important;vertical-align:middle;}
body.cz-skin header#header nav#menu a{display:inline-flex;align-items:center;line-height:1;letter-spacing:.05em;text-transform:uppercase;font-size:.8rem;padding:12px 0 2px;}

/* Mobile full-screen menu overlay */
.cz-mobile-nav{position:fixed;inset:0;z-index:200;background:rgba(10,11,14,.98);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .35s var(--cz-ease),visibility .35s;}
.cz-mobile-nav.cz-open{opacity:1;visibility:visible;}
.cz-mobile-nav__inner{display:flex;flex-direction:column;gap:18px;text-align:center;padding:88px 32px 44px;width:100%;}
.cz-mobile-nav__inner a{color:#fff;font-size:1.55rem;font-weight:700;letter-spacing:-.01em;text-transform:none;}
.cz-mobile-nav__inner a.cz-btn{align-self:center;margin-top:14px;font-size:1rem;color:#04181a;}
.cz-mobile-nav__close{position:absolute;top:18px;right:22px;background:none;border:0;color:#fff;font-size:2.6rem;line-height:1;cursor:pointer;padding:6px;}
body.cz-skin header#header .mobile_bar span{transition:transform .3s var(--cz-ease),opacity .3s;}
.mobile_bar.cz-active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.mobile_bar.cz-active span:nth-child(2){opacity:0;}
.mobile_bar.cz-active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Mobile hero: keep eyebrow, title, subtitle AND both buttons above the fold */
@media(max-width:600px){
  .cz-hero{padding-top:90px;padding-bottom:72px;}
  .cz-hero__title{font-size:clamp(2.1rem,8.5vw,2.9rem);line-height:1.14;}
  .cz-hero__sub{margin-top:1rem;}
  .cz-lead{font-size:1rem;line-height:1.55;}
  .cz-btn-row{margin-top:1.3rem;gap:10px;}
  .cz-btn{padding:.95em 1.5em;font-size:.9rem;}
  .cz-eyebrow{margin-bottom:.9rem;}
  .cz-hero__scroll{display:none;}
}

/* Mobile case cards: natural height instead of 70svh */
@media(max-width:820px){
  .cz-case--project{height:auto;}
  .cz-case--project .cz-case__thumb{flex:0 0 auto;aspect-ratio:16/10;}
}

/* =====================================================================
   v4 — Footer: clean contact form + 2-column quick menu
   ===================================================================== */
/* contact form */
body.cz-skin footer .contact_section h2{color:#fff;font-size:clamp(1.15rem,1.6vw,1.5rem);font-weight:800;letter-spacing:-.015em;line-height:1.1;margin:0 0 16px;white-space:nowrap;}
/* match form-field width to the footer logo above (300x33 svg @ 34px tall ≈ 309px) */
body.cz-skin footer .contact_section .wpcf7{max-width:309px;}
body.cz-skin footer .contact_section .field{width:100%;float:none;margin:0 0 20px;}
body.cz-skin footer .contact_section .field p{margin:0;}
body.cz-skin footer .contact_section .wpcf7-form-control-wrap{display:block;width:100%;}
/* Turnstile ships an inline negative bottom margin that crowds the submit. */
body.cz-skin footer .contact_section .cf7-cf-turnstile{margin:8px 0 16px !important;}
body.cz-skin footer .contact_section input[type=submit]{margin-top:6px;}
body.cz-skin footer .contact_section input:not([type=submit]):not([type=checkbox]):not([type=radio]),
body.cz-skin footer .contact_section textarea{width:100%;background:var(--cz-bg-3);border:1px solid var(--cz-line);border-radius:10px;padding:13px 15px;color:#fff;font-family:var(--cz-font);font-size:.95rem;margin:0;}
body.cz-skin footer .contact_section textarea{height:76px;min-height:76px;resize:vertical;display:block;}
body.cz-skin footer .contact_section input::placeholder,body.cz-skin footer .contact_section textarea::placeholder{color:var(--cz-faint);letter-spacing:.05em;}
body.cz-skin footer .contact_section input:focus,body.cz-skin footer .contact_section textarea:focus{outline:none;border-color:var(--cz-teal);}
body.cz-skin footer .contact_section input[type=submit]{width:auto;background:var(--cz-teal);color:#04181a;border:none;border-radius:100px;padding:13px 32px;font-weight:700;font-size:.9rem;letter-spacing:.02em;cursor:pointer;margin-top:6px;transition:background .3s,transform .3s;}
body.cz-skin footer .contact_section input[type=submit]:hover{background:#06b9c4;transform:translateY(-2px);}
body.cz-skin footer .contact_section .cf7-cf-turnstile{margin:2px 0 6px !important;}
body.cz-skin footer .contact_section .wpcf7-response-output{margin:10px 0 0;border-radius:8px;font-size:.85rem;padding:8px 12px;}
body.cz-skin footer .contact_section br{display:none;}

/* 2-column quick menu */
body.cz-skin footer .footer_menu .menu{display:grid;grid-template-columns:1fr 1fr;gap:10px 30px;}
body.cz-skin footer .footer_menu li{margin:0;float:none;}
body.cz-skin footer .footer_content{display:flex;gap:clamp(30px,5vw,68px);flex-wrap:wrap;}
body.cz-skin footer .footer_address{min-width:230px;flex:1 1 230px;}
body.cz-skin footer .footer_menu{min-width:260px;flex:1 1 260px;}
@media(max-width:520px){body.cz-skin footer .footer_menu .menu{grid-template-columns:1fr;}}

/* =====================================================================
   v5 — coffee photo parallax, readable statement text, footer address
   ===================================================================== */
/* Static cover (parallax removed — it glitched on scroll). */
.cz-cta__photo{inset:0;width:100%;height:100%;background-position:center;}

/* Statement / rich-text paragraphs were inheriting the theme's dark body
   colour — force the light muted colour and teal links */
.cz-modern .cz-lead,.cz-modern .cz-lead p,.cz-modern .cz-lead li{color:var(--cz-muted) !important;}
.cz-modern .cz-lead a{color:var(--cz-teal) !important;text-decoration:underline;text-underline-offset:3px;}

/* Footer: theme sets `footer p{display:inline}` which collapses the address —
   restore block flow for the address column */
body.cz-skin footer .footer_address p{display:block;margin:0 0 12px;color:var(--cz-muted);}
body.cz-skin footer .footer_address h3{margin-bottom:10px;}
body.cz-skin footer .footer_left{width:auto;float:none;min-height:0;}

/* =====================================================================
   v6 — FINAL mobile header override. Must come last: earlier v3 header
   rules set nav#menu{display:flex} without a media query, which leaked
   the desktop menu onto mobile. Force logo-left + hamburger-right here.
   ===================================================================== */
@media(max-width:980px){
  body.cz-skin header#header nav#menu{display:none !important;}
  body.cz-skin header#header .cz-nav-cta{display:none !important;}
  body.cz-skin header#header .menuBar{display:flex !important;align-items:center;gap:0;}
  body.cz-skin header#header .mobile_bar{display:flex !important;flex-direction:column;gap:5px;cursor:pointer;}
  body.cz-skin header#header .mobile_bar span{display:block;width:26px;height:2px;background:#fff;}
  body.cz-skin header#header .logo{margin-right:auto;}
  body.cz-skin header#header .wrapper{justify-content:space-between;}
}

/* =====================================================================
   v7 — mobile header polish: smaller logo + a full-width header bar
   background that is tall enough to contain logo + hamburger.
   ===================================================================== */
@media(max-width:980px){
  body.cz-skin header#header{padding:0 !important;}
  body.cz-skin header#header .logo img{height:24px;}
  body.cz-skin header#header .wrapper{border-radius:0;border:0;padding:13px var(--cz-pad);background:rgba(12,13,16,.55);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:none;}
  body.cz-skin header#header.cz-scrolled .wrapper{background:rgba(12,13,16,.93);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 6px 24px rgba(0,0,0,.45);padding:11px var(--cz-pad);}
}
/* opened mobile menu must always fill the viewport height */
.cz-mobile-nav{height:100svh;height:100dvh;}
.cz-mobile-nav__inner a{text-transform:none;}

/* =====================================================================
   v8 — match footer form field width to the Cloudflare Turnstile box
   (Turnstile "normal" size = 300px). Appended last to win.
   ===================================================================== */
body.cz-skin footer .contact_section .wpcf7{max-width:300px;}
body.cz-skin footer .contact_section .field{max-width:300px;}
body.cz-skin footer .contact_section input:not([type=submit]):not([type=checkbox]):not([type=radio]),
body.cz-skin footer .contact_section textarea{width:300px;max-width:100%;}

/* =====================================================================
   v9 — tighten desktop header: less padding below menu items, more
   compact bar. (Appended last to win over earlier header rules.)
   ===================================================================== */
@media(min-width:981px){
  body.cz-skin header#header{padding:10px 0;}
  body.cz-skin header#header nav#menu a{padding:2px 0;line-height:1;}
  body.cz-skin header#header nav#menu a::after{bottom:-2px;}
  body.cz-skin header#header .logo img{height:30px;}
}

/* =====================================================================
   v10 — Kop koffie photo: bias focus upward so the people's heads stay
   visible on desktop. (Appended last to win.)
   ===================================================================== */
.cz-cta__photo{background-position:center 18%;}

/* =====================================================================
   v11 — unify footer contact field radius. The theme forces
   `.contact_section .field input{border-radius:0 !important}`, which
   squared off the email field while the textarea stayed rounded.
   ===================================================================== */
body.cz-skin footer .contact_section .field input:not([type=submit]),
body.cz-skin footer .contact_section .field textarea,
body.cz-skin footer .contact_section input:not([type=submit]):not([type=checkbox]):not([type=radio]),
body.cz-skin footer .contact_section textarea{border-radius:10px !important;}

/* =====================================================================
   v12 — unify the footer contact column to the logo width. The logo
   (300x33 svg @ 34px tall) renders ~309px wide; match the title, form
   container, fields and inputs to it. Appended last to beat the v8
   Turnstile-driven 300px caps.
   ===================================================================== */
@media(min-width:781px){
  body.cz-skin footer .contact_section h2{max-width:300px;}
  body.cz-skin footer .contact_section .wpcf7{max-width:300px;}
  body.cz-skin footer .contact_section .field{max-width:300px;}
  body.cz-skin footer .contact_section input:not([type=submit]):not([type=checkbox]):not([type=radio]),
  body.cz-skin footer .contact_section textarea{width:100%;max-width:300px;}
}

/* =====================================================================
   v13 — force the footer text inputs to actually FILL the 300px column
   (match the logo + Turnstile box). A validation-icon wrapper was
   shrink-wrapping the email/textarea below their 300px container, so
   force every wrapper and the controls to 100%/300px. Appended last.
   ===================================================================== */
@media(min-width:781px){
  body.cz-skin footer .contact_section .wpcf7,
  body.cz-skin footer .contact_section .wpcf7-form,
  body.cz-skin footer .contact_section .field,
  body.cz-skin footer .contact_section .field > p,
  body.cz-skin footer .contact_section .wpcf7-form-control-wrap{display:block !important;width:100% !important;max-width:300px !important;float:none !important;}
  body.cz-skin footer .contact_section .field input:not([type=submit]),
  body.cz-skin footer .contact_section .field textarea,
  body.cz-skin footer .contact_section input[type=email],
  body.cz-skin footer .contact_section input[type=text],
  body.cz-skin footer .contact_section input[type=tel],
  body.cz-skin footer .contact_section textarea{display:block !important;width:300px !important;min-width:300px !important;max-width:300px !important;float:none !important;box-sizing:border-box !important;}
  /* size attr also nudges intrinsic width — neutralise it */
  body.cz-skin footer .contact_section input[size]{width:300px !important;min-width:300px !important;max-width:300px !important;}
}

/* =====================================================================
   v14 — SITEWIDE INNER-PAGE SKIN (theme pass). Scoped to body.cz-inner
   (every non-home page) so the homepage is untouched. Dark-themes the
   legacy page markup: header clearance, banners, content, sections,
   cards, buttons, forms, blog, logo grid, pagination.
   ===================================================================== */
body.cz-inner{background:var(--cz-bg);color:var(--cz-text);}

/* Clear the fixed header (inner pages have no hero). #content wraps every
   template, so pad it once; neutralise the theme's .main-content margin. */
body.cz-inner #content{padding-top:clamp(80px,9vh,116px);position:relative;z-index:1;}
body.cz-inner .main-content{margin-top:0;}

/* Kill legacy white overlays / side-fills */
body.cz-inner .banner::before,
body.cz-inner .cta::after,
body.cz-inner .cta .cta_inner::before,
body.cz-inner .cta .cta_inner::after,
body.cz-inner #body-bg{display:none !important;}

/* Containers -> transparent over the dark body */
body.cz-inner .banner,
body.cz-inner .blog_section,
body.cz-inner .tldr_overons,
body.cz-inner .our_customer,
body.cz-inner .cta,
body.cz-inner .overons_page,
body.cz-inner .portfolio_page,
body.cz-inner .portfolio_inner_page,
body.cz-inner .onze_werkwijze_detail_page,
body.cz-inner .styling_page{background:transparent !important;}

/* Banner content + cards -> subtle dark panels */
body.cz-inner .banner .content_box,
body.cz-inner .blog_box{background:var(--cz-bg-2) !important;border:1px solid var(--cz-line);border-radius:var(--cz-radius);}
body.cz-inner .blog_box{padding:clamp(22px,3vw,36px) !important;margin-bottom:26px;}

/* Typography */
body.cz-inner h1,body.cz-inner h2,body.cz-inner h3,body.cz-inner h4,body.cz-inner h5,body.cz-inner h6,
body.cz-inner .heading h1,body.cz-inner .pagetitle,body.cz-inner .banner h1{color:#fff !important;font-family:var(--cz-font);letter-spacing:-.01em;}
body.cz-inner p,body.cz-inner li,body.cz-inner td,body.cz-inner dd,
body.cz-inner .content_box,body.cz-inner .right_part,body.cz-inner .left_part{color:var(--cz-muted);font-weight:300;}
body.cz-inner a{color:var(--cz-teal);text-decoration:none;transition:color .3s;}
body.cz-inner a:hover{color:#06b9c4;}
body.cz-inner hr{border-color:var(--cz-line);}
body.cz-inner blockquote{border-left:3px solid var(--cz-teal);padding-left:18px;color:var(--cz-text);}

/* Content images */
body.cz-inner #content img:not(.logo_slider img){max-width:100%;height:auto;border-radius:12px;}

/* Buttons -> teal pills (matches homepage .cz-btn) */
body.cz-inner .button,
body.cz-inner a.button,
body.cz-inner .btn_box a,
body.cz-inner .email{display:inline-flex !important;align-items:center;gap:.6em;background:var(--cz-teal) !important;color:#04181a !important;border:none !important;border-radius:100px !important;padding:.95em 1.7em !important;font-weight:700;font-size:.9rem;letter-spacing:.02em;text-transform:none;width:auto !important;transition:background .3s,transform .3s;}
body.cz-inner .button:hover,
body.cz-inner a.button:hover,
body.cz-inner .btn_box a:hover,
body.cz-inner .email:hover{background:#06b9c4 !important;color:#04181a !important;transform:translateY(-2px);}

/* CTA block -> dark card with white heading (often holds the contact form) */
body.cz-inner .cta .cta_inner{background:var(--cz-bg-2) !important;border:1px solid var(--cz-line);border-radius:var(--cz-radius);padding:clamp(28px,4vw,60px) !important;}
body.cz-inner .cta h3{color:#fff !important;}
body.cz-inner .cta p,body.cz-inner .cta a{color:var(--cz-muted) !important;}

/* Quote band (fringilla) -> black band, white text, with a subtle teal aurora. */
body.cz-inner .fringilla{background:#08090c !important;height:auto !important;padding:clamp(64px,9vw,120px) 0 !important;}
body.cz-inner .fringilla h2{color:#ffffff !important;}
/* Parallax aurora background (JS block 12 injects .cz-fringilla-bg). Two layers:
   a glow gradient that parallax-translates on scroll + a second drifting layer
   on a slow loop so the band feels alive even at rest. Recoloured for black. */
body.cz-inner .fringilla.cz-fringilla-parallax{position:relative;overflow:hidden;isolation:isolate;}
body.cz-inner .fringilla .cz-fringilla-bg{
  position:absolute;left:-10%;right:-10%;top:-45%;bottom:-45%;z-index:0;pointer-events:none;will-change:transform;
  background:
    radial-gradient(38% 55% at 16% 20%, rgba(6,185,196,.30), transparent 66%),
    radial-gradient(44% 62% at 86% 84%, rgba(2,156,166,.22), transparent 70%),
    radial-gradient(34% 50% at 62% 6%, rgba(60,235,245,.16), transparent 66%),
    radial-gradient(52% 72% at 50% 122%, rgba(20,117,123,.34), transparent 70%),
    #08090c;
  background-size:cover;}
body.cz-inner .fringilla .cz-fringilla-bg::after{
  content:"";position:absolute;inset:-20%;pointer-events:none;mix-blend-mode:screen;will-change:transform;
  background:
    radial-gradient(30% 40% at 25% 30%, rgba(6,185,196,.20), transparent 60%),
    radial-gradient(36% 46% at 76% 66%, rgba(60,235,245,.18), transparent 62%);
  animation:cz-fringilla-drift 16s ease-in-out infinite alternate;}
@keyframes cz-fringilla-drift{from{transform:translate3d(-3%,-2%,0) scale(1);}to{transform:translate3d(4%,3%,0) scale(1.12);}}
@media (prefers-reduced-motion:reduce){body.cz-inner .fringilla .cz-fringilla-bg::after{animation:none;}}
body.cz-inner .fringilla.cz-fringilla-parallax > .wrapper,
body.cz-inner .fringilla.cz-fringilla-parallax > .text,
body.cz-inner .fringilla.cz-fringilla-parallax .text,
body.cz-inner .fringilla.cz-fringilla-parallax h2{position:relative;z-index:1;}

/* Logo strip -> static glass grid (owl carousel is dequeued sitewide) */
body.cz-inner .logo_slider{display:flex !important;flex-wrap:wrap;gap:14px;justify-content:flex-start;align-items:stretch;list-style:none;padding:0 !important;margin:0 !important;float:none !important;width:auto !important;}
body.cz-inner .logo_slider li{background:rgba(255,255,255,.04);border:1px solid var(--cz-line);border-radius:14px;padding:16px 22px;display:flex;align-items:center;justify-content:center;min-width:130px;min-height:64px;}
body.cz-inner .logo_slider li img{max-width:120px;width:auto;height:auto;filter:brightness(0) invert(1);opacity:.85;}

/* Forms (contact / styling templates) -> dark inputs */
body.cz-inner input:not([type=submit]):not([type=checkbox]):not([type=radio]):not([type=file]),
body.cz-inner textarea,
body.cz-inner select{background:var(--cz-bg-3);border:1px solid var(--cz-line);border-radius:10px;color:#fff;padding:12px 14px;font-family:var(--cz-font);font-size:.95rem;}
body.cz-inner input::placeholder,body.cz-inner textarea::placeholder{color:var(--cz-faint);}
body.cz-inner input:focus,body.cz-inner textarea:focus,body.cz-inner select:focus{outline:none;border-color:var(--cz-teal);}
body.cz-inner input[type=submit]{background:var(--cz-teal) !important;color:#04181a !important;border:none !important;border-radius:100px !important;padding:12px 30px !important;font-weight:700;cursor:pointer;width:auto !important;transition:background .3s,transform .3s;}
body.cz-inner input[type=submit]:hover{background:#06b9c4 !important;transform:translateY(-2px);}

/* Pagination / post navigation */
body.cz-inner .pagination a,body.cz-inner .pagination span,
body.cz-inner .navigation a{display:inline-flex;align-items:center;justify-content:center;background:var(--cz-bg-2) !important;border:1px solid var(--cz-line) !important;color:#fff !important;border-radius:10px;padding:8px 14px;}
body.cz-inner .pagination a:hover,body.cz-inner .pagination .current{background:var(--cz-teal) !important;color:#04181a !important;border-color:var(--cz-teal) !important;}

/* Tables in content */
body.cz-inner table{border-color:var(--cz-line);}
body.cz-inner th{color:#fff;}

/* =========================================================================
   v15 — Business Reviews Bundle widget dark skin (klanten-vertellen page).
   Plugin is fully CSS-var driven off `.rpi` (defaults: light #f5f5f5 cards,
   #333 text, #154fc1 names). Re-map those vars to the dark glass-card look
   used elsewhere. Higher specificity (body.cz-skin .rpi) beats the plugin.
   Gold star color (#fb8e28) is kept — reads well on dark.
   ========================================================================= */
body.cz-skin .rpi{
  /* card surfaces -> dark glass (matches .blog_box / .cta_inner) */
  --card-bg:var(--cz-bg-2);--card-bg-color:var(--cz-bg-2);
  --head-card-bg:var(--cz-bg-2);--head-card-bg-color:var(--cz-bg-2);
  --slider-head-card-bg-color:var(--cz-bg-2);
  --card-radius:var(--cz-radius);--head-card-radius:var(--cz-radius);
  --card-shadow:0 14px 40px rgba(0,0,0,.35);--head-card-shadow:none;
  /* borders -> subtle hairline */
  --card-br-color:rgba(255,255,255,.10);
  --head-card-br-color:rgba(255,255,255,.10);
  --slider-head-card-br-color:rgba(255,255,255,.10);
  --slider-btn-bc:rgba(255,255,255,.18);
  /* text -> light palette */
  --card-color:var(--cz-text);--tag-text-color:var(--cz-text);
  --name-color:#ffffff;--head-scale-color:#ffffff;
  --time-color:rgba(243,245,247,.55);--head-based-color:rgba(243,245,247,.55);
  /* slider nav buttons -> dark */
  --slider-btn-bg:var(--cz-bg-3);--slider-btn-color:rgba(243,245,247,.75);
}
/* hard-coded light values the plugin sets outside the var system */
body.cz-skin .rpi-card.rpi-highlight{background:var(--cz-bg-3) !important;}
body.cz-skin .rpi-slider-btn{box-shadow:0 2px 10px rgba(0,0,0,.45) !important;}
/* "read more"/expand links and review text stay legible on dark */
body.cz-skin .rpi-text,body.cz-skin .rpi-normal-up__body,body.cz-skin .rpi-body{color:var(--cz-text);}
body.cz-skin .rpi-review_us,body.cz-skin .rpi-readmore{color:var(--cz-teal) !important;}

/* WP-PageNavi (cases/portfolio archives) — plugin ships #BFBFBF/#000 borders.
   Match the dark pill style v14 already uses for .pagination/.navigation. */
body.cz-skin .wp-pagenavi{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:30px;}
body.cz-skin .wp-pagenavi a,body.cz-skin .wp-pagenavi span{
  display:inline-flex;align-items:center;justify-content:center;min-width:38px;
  background:var(--cz-bg-2);border:1px solid var(--cz-line) !important;color:#fff;
  border-radius:10px;padding:8px 12px;margin:0;text-decoration:none;
  transition:background .3s var(--cz-ease),border-color .3s var(--cz-ease);}
body.cz-skin .wp-pagenavi a:hover,body.cz-skin .wp-pagenavi span.current{
  background:var(--cz-teal);color:#04181a;border-color:var(--cz-teal) !important;}

/* Ajax Search Lite (search-results page) — plugin injects a white input +
   light results dropdown via inline !important styles. Darken core surfaces. */
body.cz-skin .asl_s.asl_w,body.cz-skin input.orig{
  background-color:var(--cz-bg-3) !important;background-image:none !important;color:var(--cz-text) !important;}
body.cz-skin .asl_s.asl_w::placeholder{color:var(--cz-faint) !important;}
body.cz-skin div.asl_r.asl_w,body.cz-skin .wpdreams_asl_results,
body.cz-skin div.asl_r.asl_w .results{background:var(--cz-bg-2) !important;border-color:var(--cz-line) !important;color:var(--cz-text) !important;}
body.cz-skin .wpdreams_asl_results .results .item,
body.cz-skin .wpdreams_asl_results .results .item *{color:var(--cz-text) !important;}
body.cz-skin div.asl_r.asl_w.vertical .results .item::after{background:var(--cz-line) !important;}
body.cz-skin .wpdreams_asl_results div.resdrg span.highlighted{color:var(--cz-teal) !important;background-color:var(--cz-teal-soft) !important;}

/* =========================================================================
   v16 — Inner-page review fixes (werkwijze / portfolio / cases / over-ons).
   ========================================================================= */

/* Alignment — the original theme mixed container widths (.wrapper 1440px vs
   .wrapper_inner 1100px), so section edges jumped in/out down the page and
   didn't line up with the header/footer. Unify every inner container to one
   centered column at the site width with consistent gutters. (Sections use
   either .wrapper OR .wrapper_inner — never nested — so padding both is safe.)
   overflow:visible lets the portfolio left/right slide-in reveal show; the
   page itself can't scroll sideways because body.cz-skin clips overflow-x. */
body.cz-inner .wrapper,
body.cz-inner .wrapper_inner{
  max-width:var(--cz-maxw) !important;margin-left:auto !important;margin-right:auto !important;
  padding-left:var(--cz-pad) !important;padding-right:var(--cz-pad) !important;
  box-sizing:border-box;overflow:visible !important;}
body.cz-inner .banner_inner{padding-left:0 !important;}

/* Flat content — drop the boxed panel on .banner .content_box (was #fff in the
   original light theme, a dark card in v14). Transparent, no border, and no
   extra horizontal indent so it aligns with the page heading above it. */
body.cz-inner .banner .content_box{
  background:transparent !important;border:0 !important;box-shadow:none !important;
  padding-left:0 !important;padding-right:0 !important;}

/* Portfolio — flatten the item rows (remove card bg/border/radius). */
body.cz-inner .portfolio_page .blog_box{
  background:transparent !important;border:0 !important;box-shadow:none !important;
  border-radius:0 !important;padding:clamp(22px,3vw,40px) 0 !important;}

/* Readability — the original theme hard-set near-black (#1f1f1d) text deep
   inside these blocks; those selectors beat the generic v14 light-text rule,
   so the copy rendered black-on-dark. Force the muted light color. */
body.cz-inner .tldr_overons .right_part p,
body.cz-inner .tldr_overons .right_part li,
body.cz-inner .tldr_overons .right_part li a,
body.cz-inner .banner .content_box ul li{color:var(--cz-muted) !important;}
body.cz-inner .tldr_overons .right_part li a:hover{color:var(--cz-teal) !important;}

/* =========================================================================
   v17 — werkwijze H1, homepage quote centering, homepage "Over ons" block.
   ========================================================================= */

/* Werkwijze (and other inner) page H1 — the original .heading had padding:0
   170px, indenting the title far from the now-flush content below it. Pull it
   to the left gutter and lift it a touch. */
body.cz-inner .banner_common .heading{padding-left:0 !important;padding-right:0 !important;text-align:left !important;}
body.cz-inner .banner_common .heading h1,
body.cz-inner .banner h1{text-align:left !important;padding-top:0 !important;margin-top:0 !important;margin-bottom:24px !important;}

/* Homepage quote — guarantee it sits centered horizontally. */
.cz-quote{text-align:center;}
.cz-quote .cz-wrap{display:flex;flex-direction:column;align-items:center;}
.cz-quote .cz-eyebrow{justify-content:center;}
.cz-quote__text{margin-left:auto !important;margin-right:auto !important;text-align:center !important;}

/* Homepage "Over ons" block — photo + text, two columns. Photo is a CSS
   background (not an <img>) so ShortPixel's lazy-swap can't blur it. */
.cz-about__grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(28px,5vw,72px);align-items:center;}
.cz-about__photo{display:block;width:100%;aspect-ratio:4/3;border-radius:clamp(16px,2vw,24px);background-size:cover;background-position:center;overflow:hidden;}
.cz-about__text{max-width:54ch;}
.cz-about__title{font-size:clamp(1.9rem,3.6vw,3rem);font-weight:800;letter-spacing:-.02em;color:#fff;line-height:1.04;margin:0 0 1.2rem;}
.cz-about__text p{color:var(--cz-muted);font-size:1.05rem;line-height:1.7;font-weight:300;margin:0 0 1rem;}
.cz-about__links{display:flex;flex-wrap:wrap;gap:14px;margin-top:1.6rem;}
.cz-about__links .cz-btn{font-size:.9rem;}
@media (max-width:860px){
  .cz-about__grid{grid-template-columns:1fr;gap:30px;}
  .cz-about__photo{aspect-ratio:16/10;}
}

/* =========================================================================
   v19 — "Onze klanten" band: white background + sliding logo marquee
   (same motion as the homepage clients marquee). JS (block 11) wraps the
   list in .cz-logos--inner and duplicates the items for a seamless loop.
   ========================================================================= */
/* Dark clients band (matches the page) — keep the section dark; text light. */
body.cz-inner .our_customer{background:transparent !important;}

/* Marquee track (the logos slide; edges fade via the mask). */
.cz-logos--inner{overflow:hidden;position:relative;width:100%;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
body.cz-inner .logo_slider.cz-logo-marquee{
  display:inline-flex !important;flex-wrap:nowrap !important;width:max-content !important;
  gap:40px;align-items:center;padding:10px 0 !important;margin:0 !important;list-style:none;
  animation:cz-marq 80s linear infinite;}
body.cz-inner .logo_slider.cz-logo-marquee li{
  flex:0 0 auto;background:transparent !important;border:0 !important;
  min-width:0;min-height:0;padding:0 6px;}
/* On the dark band, show logos white (same as the homepage marquee). */
body.cz-inner .our_customer .logo_slider.cz-logo-marquee li img{
  filter:brightness(0) invert(1) !important;opacity:.78 !important;max-width:150px;max-height:50px;width:auto;height:auto;object-fit:contain;}
@media (prefers-reduced-motion:reduce){
  body.cz-inner .logo_slider.cz-logo-marquee{animation:none !important;flex-wrap:wrap !important;width:auto !important;justify-content:center;}
}

/* =========================================================================
   v20 — header CTA legibility + contact social icons.
   ========================================================================= */
/* "Kennismaken" CTA: the header nav-link color rule (uses the #header id, so
   high specificity) was bleeding into the injected <a> and washing out its
   dark text on the teal pill. Pin it back to dark-on-teal. */
body.cz-skin header#header a.cz-nav-cta{
  background:
    radial-gradient(85% 130% at 12% 16%, rgba(6,185,196,.40), transparent 70%),
    radial-gradient(90% 140% at 92% 96%, rgba(20,117,123,.48), transparent 72%),
    #0a0c10 !important;
  color:#fff !important;border:0 !important;}
body.cz-skin header#header a.cz-nav-cta:hover{filter:brightness(1.2) !important;color:#fff !important;}

/* Contact page social icons are dark SVGs from the original light theme, so
   they vanished on the dark background — whiten them. */
body.cz-inner .social_icons img{filter:brightness(0) invert(1) !important;opacity:.8;transition:opacity .3s;}
body.cz-inner .social_icons a:hover img{opacity:1;}
/* Clean inline-SVG social icons (JS block 13 swaps the old icon images). */
body.cz-skin .social_icons ul{display:flex;gap:10px;flex-wrap:wrap;margin:0;padding:0;list-style:none;}
body.cz-skin .social_icons li{margin:0;float:none;}
body.cz-skin .social_icons a.cz-social{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:1px solid var(--cz-line);color:var(--cz-text);transition:background .3s var(--cz-ease),border-color .3s var(--cz-ease),color .3s var(--cz-ease),transform .3s var(--cz-ease);}
body.cz-skin .social_icons a.cz-social img{display:none !important;}
body.cz-skin .social_icons a.cz-social svg{width:18px;height:18px;display:block;}
body.cz-skin .social_icons a.cz-social svg path{fill:currentColor;}
body.cz-skin .social_icons a.cz-social:hover{
  background:
    radial-gradient(85% 130% at 12% 16%, rgba(6,185,196,.40), transparent 70%),
    radial-gradient(90% 140% at 92% 96%, rgba(20,117,123,.48), transparent 72%),
    #0a0c10;
  border-color:transparent;color:#ffffff;filter:brightness(1.05);
  transform:translateY(-2px);box-shadow:0 8px 24px rgba(2,156,166,.30);}

/* =========================================================================
   v18 — Inner-page CF7 forms (contact page + page CTA forms). The dark field
   styling previously only covered the FOOTER form (footer .contact_section);
   the in-content forms kept the original light inputs. Give every field a
   dark background to match.
   ========================================================================= */
body.cz-inner .wpcf7-form input:not([type=submit]):not([type=button]):not([type=checkbox]):not([type=radio]):not([type=hidden]),
body.cz-inner .wpcf7-form textarea,
body.cz-inner .wpcf7-form select{
  width:100%;background:var(--cz-bg-3) !important;border:1px solid var(--cz-line) !important;border-radius:10px !important;
  padding:13px 15px !important;color:#fff !important;font-family:var(--cz-font);font-size:.95rem;box-sizing:border-box;}
body.cz-inner .wpcf7-form textarea{min-height:150px;resize:vertical;display:block;}
body.cz-inner .wpcf7-form input::placeholder,
body.cz-inner .wpcf7-form textarea::placeholder{color:var(--cz-faint) !important;letter-spacing:.04em;}
body.cz-inner .wpcf7-form input:focus,
body.cz-inner .wpcf7-form textarea:focus,
body.cz-inner .wpcf7-form select:focus{outline:none;border-color:var(--cz-teal) !important;}
body.cz-inner .wpcf7-form input[type=submit]{
  display:inline-flex;align-items:center;width:auto !important;background:var(--cz-teal) !important;color:#04181a !important;
  border:none !important;border-radius:100px !important;padding:13px 32px !important;font-weight:700;font-size:.9rem;
  letter-spacing:.02em;cursor:pointer;transition:background .3s,transform .3s;}
body.cz-inner .wpcf7-form input[type=submit]:hover{background:#06b9c4 !important;transform:translateY(-2px);}

/* =========================================================================
   v21 — LIGHT MODE. The design is variable-driven, so the bulk of the flip is
   redefining the core tokens under html.cz-light; the rest overrides hardcoded
   white text / white logo filters / dark "glass" that don't work on light.
   Teal accents (buttons, CTA, fringilla band) stay the same in both modes.
   The hero keeps its white-on-media treatment.
   ========================================================================= */
html.cz-light{
  --cz-bg:#ffffff;
  --cz-bg-2:#f4f6f9;
  --cz-bg-3:#e9edf2;
  --cz-line:rgba(16,22,30,.12);
  --cz-text:#161a21;
  --cz-muted:rgba(22,27,34,.70);
  --cz-faint:rgba(22,27,34,.45);
}
html.cz-light body.cz-skin{color:var(--cz-text);}

/* Headings / hero-excluded titles that were hardcoded #fff -> dark ink. */
html.cz-light .cz-modern h2,
html.cz-light .cz-modern h3,
html.cz-light .cz-quote__text,
html.cz-light .cz-about__title,
html.cz-light .cz-h2,
html.cz-light .cz-card__title,
html.cz-light .cz-case--project .cz-case__title,
html.cz-light .cz-stat__num,
html.cz-light body.cz-inner h1,
html.cz-light body.cz-inner h2,
html.cz-light body.cz-inner h3,
html.cz-light body.cz-inner h4,
html.cz-light body.cz-inner h5,
html.cz-light body.cz-inner h6,
html.cz-light body.cz-inner .heading h1,
html.cz-light body.cz-inner .pagetitle,
html.cz-light body.cz-inner .banner h1,
html.cz-light body.cz-skin footer h3{color:#161a21 !important;}

/* Header: dark nav text, light scrolled glass, real-colour logo. */
html.cz-light body.cz-skin header#header nav#menu a{color:rgba(22,27,34,.82) !important;}
html.cz-light body.cz-skin header#header.cz-scrolled .wrapper,
html.cz-light body.cz-skin header#header .wrapper{box-shadow:0 14px 40px rgba(16,22,30,.12) !important;}
html.cz-light body.cz-skin header#header.cz-scrolled .wrapper{background:rgba(255,255,255,.80) !important;}
@media(max-width:1024px){html.cz-light body.cz-skin header#header .wrapper{background:rgba(255,255,255,.85) !important;}}
html.cz-light body.cz-skin header#header .logo img{filter:none !important;}

/* Logos / icons: show real colours (drop the white-ising invert). */
html.cz-light .cz-logo img,
html.cz-light body.cz-inner .logo_slider li img,
html.cz-light body.cz-inner .our_customer .logo_slider.cz-logo-marquee li img,
html.cz-light body.cz-inner .social_icons img,
html.cz-light body.cz-skin footer .footer_logo img{filter:none !important;opacity:1 !important;}
html.cz-light .cz-logo{background:rgba(16,22,30,.04) !important;}
html.cz-light body.cz-inner .logo_slider li{background:rgba(16,22,30,.04) !important;}
html.cz-light .cz-marquee span{color:rgba(22,27,34,.30) !important;}

/* Misc dark-glass panels that need a light equivalent. */
html.cz-light .cz-reviews__inner{background:rgba(255,255,255,.92) !important;color:#161a21 !important;box-shadow:0 16px 50px rgba(16,22,30,.14) !important;}
html.cz-light .cz-mobile-nav{background:rgba(255,255,255,.98) !important;}
html.cz-light .cz-mobile-nav__inner a{color:#161a21 !important;}

/* ---- The theme toggle button in the header ---- */
.cz-theme-toggle{width:38px;height:38px;border-radius:50%;border:1px solid var(--cz-line);background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:#fff;flex:0 0 auto;padding:0;transition:border-color .3s,color .3s,background .3s;}
.cz-theme-toggle:hover{border-color:var(--cz-teal);}
body.cz-skin header#header .cz-theme-toggle{color:#fff;}
html.cz-light body.cz-skin header#header .cz-theme-toggle{color:#161a21;}
/* crescent-moon glyph (dark mode) -> filled sun (light mode) */
.cz-theme-toggle__icon{width:16px;height:16px;border-radius:50%;background:currentColor;box-shadow:inset -5px -3px 0 0 currentColor, inset -7px -4px 0 0 var(--cz-bg);transition:box-shadow .3s,background .3s,border-color .3s;}
html.cz-light .cz-theme-toggle__icon{background:transparent;box-shadow:none;border:2px solid currentColor;position:relative;width:12px;height:12px;}
html.cz-light .cz-theme-toggle__icon::after{content:"";position:absolute;inset:-6px;border-radius:50%;background:
  radial-gradient(circle, transparent 58%, currentColor 58% 66%, transparent 66%);
  -webkit-mask:radial-gradient(circle, transparent 60%, #000 60%);}

/* =========================================================================
   v22 — Client logo wall (.boutom_image_section / .image_outer_card). The
   theme rendered ~100+ logos 3-per-row at 30% width => a giant, page-lengthening
   stack the dark skin never touched. Make it a tight, uniform logo grid with
   white-knockout logos on subtle glass tiles (real colours in light mode).
   ========================================================================= */
body.cz-inner .image_outer_card{
  display:grid !important;grid-template-columns:repeat(auto-fill,minmax(108px,1fr)) !important;
  gap:10px !important;float:none !important;width:100% !important;align-items:stretch;}
body.cz-inner .image_outer_card .card_image{
  width:auto !important;height:clamp(66px,13vw,92px) !important;min-height:0 !important;margin:0 !important;padding:12px 16px !important;
  display:flex;align-items:center;justify-content:center;overflow:hidden;box-sizing:border-box;
  background:#fff !important;border:0 !important;border-radius:12px;
  transition:transform .3s var(--cz-ease),box-shadow .3s var(--cz-ease);}
body.cz-inner .image_outer_card .card_image:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,0,0,.30);}
/* Real logo colours on the white tiles (no white-knockout). */
body.cz-inner .image_outer_card .card_image img{
  max-width:100%;max-height:46px;width:auto;height:auto;object-fit:contain;
  filter:none !important;opacity:1 !important;}

/* "Kop koffie doen?" tab on the left edge — black + teal aurora to match the
   page-header band (keep its rotated position + the animated coffee-fill). */
body.cz-skin .coffee_cup{
  background:
    radial-gradient(62% 82% at 18% 30%, rgba(6,185,196,.42), transparent 70%),
    radial-gradient(70% 92% at 92% 78%, rgba(20,117,123,.48), transparent 72%),
    #08090c !important;
  border-radius:16px 16px 0 0 !important;box-shadow:0 -6px 34px rgba(0,0,0,.5) !important;
  transition:filter .3s,box-shadow .3s !important;}
body.cz-skin .coffee_cup:hover{filter:brightness(1.12) !important;box-shadow:0 -6px 44px rgba(2,156,166,.45) !important;}
body.cz-skin .coffee_cup h2{color:#ffffff !important;font-family:var(--cz-font) !important;font-weight:800 !important;font-size:16px !important;letter-spacing:.02em !important;}
body.cz-skin .coffee_cup .cup_box{background:var(--cz-teal) !important;width:38px !important;height:38px !important;}
body.cz-skin .coffee_cup .cup_box img{filter:brightness(0) invert(1) !important;}

/* =========================================================================
   v23 — Aurora page-header band behind the page title on inner pages (not the
   homepage, which is body.home and never gets cz-inner). Same black + subtle
   teal aurora as the quote band; fades into the page so there's no hard seam.
   ========================================================================= */
body.cz-inner #content{position:relative;}
body.cz-inner #content::before{
  content:"";position:absolute;top:0;left:0;right:0;height:clamp(300px,42vh,440px);
  z-index:0;pointer-events:none;
  background:
    radial-gradient(40% 60% at 18% 30%, rgba(6,185,196,.22), transparent 64%),
    radial-gradient(44% 64% at 84% 22%, rgba(20,117,123,.26), transparent 68%),
    radial-gradient(30% 44% at 60% 4%, rgba(60,235,245,.14), transparent 62%),
    linear-gradient(180deg,#08090c 0%,#08090c 48%,rgba(8,9,12,0) 100%);}
body.cz-inner #content > *{position:relative;z-index:1;}
/* Light mode: keep the dark aurora header band (intentional dark top zone). */

/* =========================================================================
   v24 — Business Reviews Bundle "sticky" Google-reviews badge + slide-in panel
   ship white surfaces; give them a dark background to match the site.
   ========================================================================= */
body.cz-skin .rpi-badge-body{
  --badge-bg-color:var(--cz-bg-2) !important;--badge-name-color:#ffffff !important;
  --badge-based-color:rgba(243,245,247,.6) !important;
  background:var(--cz-bg-2) !important;color:var(--cz-text) !important;
  border:1px solid var(--cz-line) !important;}
body.cz-skin .rpi-badge-body.rpi-badge-clickable:hover{background:var(--cz-bg-3) !important;}
body.cz-skin .rpi-badge{--badge-br-color:var(--cz-line) !important;box-shadow:0 12px 34px rgba(0,0,0,.45) !important;}
body.cz-skin .rpi-badge .rpi-name,body.cz-skin .rpi-badge .rpi-scale,body.cz-skin .rpi-badge .rpi-grade{color:#fff !important;}
body.cz-skin .rpi-badge .rpi-based{color:rgba(243,245,247,.6) !important;}
/* the slide-in review sidebar panel */
body.cz-skin .rpi-sb{background:var(--cz-bg-2) !important;border-left:1px solid var(--cz-line) !important;box-shadow:0 0 40px rgba(0,0,0,.5) !important;}
body.cz-skin .rpi-sb .rpi-header,body.cz-skin .rpi-sbf,body.cz-skin .rpi-sbh{background:var(--cz-bg-3) !important;box-shadow:0 1px 2px rgba(0,0,0,.3) !important;}
body.cz-skin .rpi-sb .rpi-card-inner{--card-bg:var(--cz-bg-3) !important;--card-color:var(--cz-text) !important;--name-color:#fff !important;}

/* =========================================================================
   v25 — Carry the black + teal "header band" look further: review-widget
   stars/top-bar, all primary buttons, and the Kop-koffie CTA overlay.
   ========================================================================= */
/* (a) Google review widget: teal stars + teal top bar. */
body.cz-skin .rpi-badge,body.cz-skin .rpi-sb{
  --head-star-color:var(--cz-teal-2) !important;--rpi-star-color:var(--cz-teal-2) !important;
  --star-color:var(--cz-teal-2) !important;--rpi-rating-color:var(--cz-teal-2) !important;}
body.cz-skin .rpi-badge-line{display:none !important;}
body.cz-skin .rpi-sb .rpi-header,body.cz-skin .rpi-sbh{border-top:3px solid #08090c !important;}

/* (b) Primary buttons -> black + teal aurora with a teal outline so they stay
   visible on any background (matches the header band / coffee tab). */
body.cz-skin .cz-btn--primary,
body.cz-skin .cz-nav-cta,
body.cz-skin .cz-cta .cz-btn,
body.cz-inner .button,
body.cz-inner a.button,
body.cz-inner .btn_box a,
body.cz-inner .email,
body.cz-inner .wpcf7-form input[type=submit]{
  background:
    radial-gradient(85% 130% at 12% 16%, rgba(6,185,196,.40), transparent 70%),
    radial-gradient(90% 140% at 92% 96%, rgba(20,117,123,.48), transparent 72%),
    #0a0c10 !important;
  color:#ffffff !important;border:0 !important;box-shadow:0 8px 24px rgba(0,0,0,.32) !important;}
body.cz-skin .cz-btn--primary:hover,
body.cz-skin .cz-nav-cta:hover,
body.cz-skin .cz-cta .cz-btn:hover,
body.cz-inner .button:hover,
body.cz-inner a.button:hover,
body.cz-inner .btn_box a:hover,
body.cz-inner .email:hover,
body.cz-inner .wpcf7-form input[type=submit]:hover{
  /* keep the aurora on hover (old rules flipped some buttons to flat teal) and
     apply the same brighten + lift as the Kennismaken button everywhere. */
  background:
    radial-gradient(85% 130% at 12% 16%, rgba(6,185,196,.40), transparent 70%),
    radial-gradient(90% 140% at 92% 96%, rgba(20,117,123,.48), transparent 72%),
    #0a0c10 !important;
  color:#ffffff !important;filter:brightness(1.2) !important;transform:translateY(-2px) !important;
  box-shadow:0 12px 30px rgba(2,156,166,.30) !important;}

/* (c) "Kop koffie doen?" CTA photo overlay -> light enough to see the faces,
   just a hint of teal + a soft dark wash; text stays legible via a shadow. */
.cz-cta--photo::after{
  background:
    radial-gradient(70% 95% at 24% 28%, rgba(6,185,196,.12), transparent 72%),
    linear-gradient(135deg, rgba(8,9,12,.60) 0%, rgba(8,9,12,.40) 100%) !important;}
.cz-cta--photo .cz-cta__title{color:#ffffff !important;text-shadow:0 2px 20px rgba(0,0,0,.55);}
.cz-cta--photo .cz-cta__text{color:#ffffff !important;text-shadow:0 1px 12px rgba(0,0,0,.6);}

/* =========================================================================
   v26 — Hero "AI" word as a dark aurora badge + the Google review widget
   surfaces get the same black + teal aurora.
   ========================================================================= */
/* The {{AI}} word in the hero title -> a black+teal aurora pill. (:has lets the
   reveal-clip on its word wrapper open up so the padded pill isn't cut off.) */
.cz-hero__title .cz-word:has(.cz-teal){overflow:visible;}
.cz-hero__title .cz-teal{
  display:inline-block;line-height:1.04;padding:0 .26em;border-radius:.2em;
  color:#ffffff !important;border:0;
  background:
    radial-gradient(120% 150% at 14% 8%, rgba(6,185,196,.5), transparent 70%),
    radial-gradient(120% 150% at 90% 100%, rgba(20,117,123,.55), transparent 72%),
    #0a0c10;}

/* Google review widget surfaces -> aurora instead of flat dark. */
body.cz-skin .rpi-badge-body{
  background:
    radial-gradient(80% 130% at 14% 16%, rgba(6,185,196,.26), transparent 70%),
    radial-gradient(90% 140% at 90% 92%, rgba(20,117,123,.30), transparent 72%),
    #0a0c10 !important;}
body.cz-skin .rpi-sb .rpi-header,body.cz-skin .rpi-sbh,body.cz-skin .rpi-sbf{
  background:
    radial-gradient(90% 160% at 12% 10%, rgba(6,185,196,.24), transparent 70%),
    #0a0c10 !important;}

/* =========================================================================
   v27 — "Werk waar we trots op zijn" case blocks get the black + teal aurora
   background (the thumbnail covers the top; the body area shows the aurora).
   ========================================================================= */
body.cz-skin .cz-case--project{
  background:
    radial-gradient(85% 92% at 14% 12%, rgba(6,185,196,.22), transparent 70%),
    radial-gradient(95% 100% at 90% 96%, rgba(20,117,123,.28), transparent 72%),
    #0a0c10 !important;}

/* =========================================================================
   v28 — Mobile fixes: phone-number -> icon in the menu, the coffee tab as a
   tidy bottom-left pill (it overlapped text), footer form field spacing.
   ========================================================================= */
@media(max-width:980px){
  /* Phone number in the mobile menu -> a phone icon. */
  body.cz-skin .cz-mobile-nav__inner a[href^="tel:"]{
    font-size:0 !important;display:inline-flex;align-items:center;justify-content:center;}
  body.cz-skin .cz-mobile-nav__inner a[href^="tel:"]::before{
    content:"";display:inline-block;width:30px;height:30px;background:currentColor;
    -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.62 10.79c1.44 2.83 3.76 5.14 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") center/contain no-repeat;
    mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.62 10.79c1.44 2.83 3.76 5.14 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3E%3C/svg%3E") center/contain no-repeat;}

  /* Coffee "Kop koffie doen?" tab -> un-rotate into a compact bottom-left pill
     so it no longer overlaps page text. */
  body.cz-skin .coffee_cup{
    transform:none !important;transform-origin:center !important;
    top:auto !important;bottom:14px !important;left:14px !important;right:auto !important;
    width:auto !important;height:auto !important;min-width:0 !important;
    flex-direction:row !important;gap:8px !important;
    border-radius:100px !important;padding:9px 16px 9px 12px !important;
    box-shadow:0 8px 26px rgba(0,0,0,.5) !important;}
  body.cz-skin .coffee_cup h2{font-size:13px !important;white-space:nowrap;}
  body.cz-skin .coffee_cup .cup_box{transform:none !important;width:30px !important;height:30px !important;margin:0 !important;}
  body.cz-skin .coffee_cup:hover .cup_box{transform:none !important;}
}

/* Footer contact-form fields get more breathing room on mobile (the desktop
   compaction isn't needed once the columns stack). The Turnstile box ships an
   inline -15px bottom margin that pulls the submit up — neutralise it. */
@media(max-width:820px){
  body.cz-skin footer .contact_section .field{margin:0 0 20px !important;}
  body.cz-skin footer .contact_section textarea{height:96px !important;min-height:96px !important;}
  body.cz-skin footer .contact_section .cf7-cf-turnstile{margin:6px 0 14px !important;}
  body.cz-skin footer .contact_section input[type=submit]{margin-top:14px !important;}
}

/* Footer submit button -> same black + teal aurora as every other button
   (it had its own flat-teal style on both desktop and mobile). */
body.cz-skin footer .contact_section input[type=submit]{
  background:
    radial-gradient(85% 130% at 12% 16%, rgba(6,185,196,.40), transparent 70%),
    radial-gradient(90% 140% at 92% 96%, rgba(20,117,123,.48), transparent 72%),
    #0a0c10 !important;
  color:#ffffff !important;border:0 !important;border-radius:100px !important;
  box-shadow:0 8px 24px rgba(0,0,0,.32) !important;}
body.cz-skin footer .contact_section input[type=submit]:hover{
  background:
    radial-gradient(85% 130% at 12% 16%, rgba(6,185,196,.40), transparent 70%),
    radial-gradient(90% 140% at 92% 96%, rgba(20,117,123,.48), transparent 72%),
    #0a0c10 !important;
  color:#ffffff !important;filter:brightness(1.2) !important;transform:translateY(-2px) !important;
  box-shadow:0 12px 30px rgba(2,156,166,.30) !important;}

/* Desktop: drop the phone-number item from the main header menu (kept as an
   icon in the mobile menu). */
@media(min-width:981px){
  body.cz-skin header#header nav#menu li:has(> a[href^="tel:"]){display:none !important;}
}

/* Inner-page section eyebrows (injected by modern.js). Centre the one in the
   centered quote band; keep a tidy gap above the heading. */
body.cz-inner .cz-eyebrow{margin:0 0 .9rem;}
/* The quote/filosofie band centers its heading but not its container, so the
   injected eyebrow sat left — make it a full-width flex row so it centers. */
body.cz-inner .fringilla .cz-eyebrow,
body.cz-inner .tldr_overons .cz-eyebrow{display:flex;justify-content:center;width:100%;}

/* "Over Converzo" block: vertically centre the photo against the text column,
   and keep the two LinkedIn name buttons in a tidy aligned row. */
body.cz-inner .tldr_overons .inner_content{display:flex;flex-wrap:wrap;align-items:center;}
body.cz-inner .tldr_overons .inner_content .image,
body.cz-inner .tldr_overons .right_part{box-sizing:border-box;}
body.cz-inner .tldr_overons .right_part .button{margin:8px 14px 0 0;vertical-align:top;}

/* Back link on case detail pages (below the title). */
body.cz-inner .heading .cz-back{display:inline-flex;align-items:center;gap:.5em;margin-top:14px;font-size:.9rem;font-weight:600;letter-spacing:.01em;color:var(--cz-muted);text-decoration:none;transition:color .3s var(--cz-ease),gap .3s var(--cz-ease);}
body.cz-inner .heading .cz-back:hover{color:var(--cz-teal);gap:.75em;}
body.cz-inner .heading .cz-back__arrow{transition:transform .3s var(--cz-ease);}
body.cz-inner .heading .cz-back:hover .cz-back__arrow{transform:translateX(-3px);}

/* Consistent, relative paragraph line-spacing on inner pages (the original
   theme mixed fixed 30px / 25px / 1.6 across breakpoints -> uneven on mobile). */
body.cz-inner p,body.cz-inner .content_box li,body.cz-inner .right_part li{line-height:1.6 !important;}
