/**
 * IT Live — Unified Widget System CSS v1.0
 * Herbruikbare componenten voor showroom, webspaces en klant-sites.
 * Prefix: .itw- (IT Live Widget) — geen conflicten met Bootstrap/Tailwind.
 *
 * Vereist CSS custom properties op :root of parent:
 *   --c       Primary brand color
 *   --cl      Light variant (backgrounds)
 *   --cd      Dark variant (text, gradients)
 *   --ink     Text color (#020617)
 *   --dim     Muted text (#374151)
 *   --bdr     Border color (#e2e8f0)
 *   --bg      Surface/background (#f8fafc)
 *   --radius  Border radius (16px)
 */

/* ══════════════════════════════════════════════════════════════
   LAYOUT
   ══════════════════════════════════════════════════════════════ */
/* Reset */
body{padding:0!important;margin:0!important}

/* ══════════════════════════════════════════════════════════════
   LEGACY NAV — responsive fix voor shell_nav_html() output
   Zorgt dat de oude .nav-links/.nav-hamburger classes
   ook correct responsive zijn op alle pagina's.
   ══════════════════════════════════════════════════════════════ */
/* Nav: logo mag niet breder dan 200px worden, hamburger altijd rechts */
nav .nav-inner,.itw-nav-inner{flex-wrap:nowrap!important}
nav .logo-link,.itw-logo{max-width:220px!important;overflow:hidden!important;flex-shrink:1!important;min-width:0!important}
nav .logo-l2,.itw-logo-l2{font-size:clamp(.7rem,.9vw,1.05rem)!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;max-width:160px!important}
nav .logo-l1,.itw-logo-l1{white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;max-width:160px!important}
nav .nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border:none;background:none;flex-shrink:0!important;margin-left:auto!important}
nav .nav-hamburger span{display:block;width:24px;height:2px;background:var(--ink,#0f172a);border-radius:2px}
nav .nav-mobile{display:none;flex-direction:column;gap:0;border-top:1px solid var(--bdr,#e2e8f0);padding:12px 0}
nav .nav-mobile.open{display:flex!important}
nav .nav-mobile a{padding:12px 0;font-weight:600;font-size:1rem;color:var(--ink,#0f172a)!important;border-bottom:1px solid var(--bdr,#e2e8f0);text-decoration:none}
nav .nav-mobile a:last-child{border:none}
nav .nav-mobile .nav-cta{margin-top:8px;text-align:center;border-radius:50px;background:var(--c)!important;color:#fff!important;padding:12px 20px}
@media(max-width:768px){
  nav .itw-nav-links-legacy{display:none!important}
  nav .nav-hamburger{display:flex!important}
}
.itw-container{max-width:1140px;margin:0 auto;padding:0 24px}
.itw-section{padding:clamp(4rem,8vw,6rem) 0}
.itw-section--alt{background:var(--bg,#f8fafc)}
.itw-section--dark{background:var(--cd,#0f172a);color:#fff}

/* Section Header */
.itw-section-head{text-align:center;margin-bottom:40px}
.itw-section-head--left{text-align:left}
.itw-kicker{display:inline-block;background:var(--cl);color:var(--c);padding:4px 14px;border-radius:50px;font-size:.75rem;font-weight:700;letter-spacing:.05em;margin-bottom:10px;text-transform:uppercase}
.itw-section--dark .itw-kicker{background:rgba(255,255,255,.12);color:#fff}
.itw-h2{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:900;margin-bottom:10px;color:var(--ink,#0f172a)!important}
.itw-section--dark .itw-h2{color:#fff}
.itw-lead{color:var(--dim);font-size:.97rem;max-width:620px;margin-bottom:0;line-height:1.6}
.itw-section-head .itw-lead{margin-left:auto;margin-right:auto}
.itw-section--dark .itw-lead{color:rgba(255,255,255,.8)}

/* ══════════════════════════════════════════════════════════════
   HERO WIDGETS
   ══════════════════════════════════════════════════════════════ */

/* Hero: Full bleed with gradient overlay — ALLE tekst altijd wit */
.itw-hero{position:relative;padding:clamp(5rem,10vw,9rem) 0;color:#fff!important;overflow:hidden;min-height:420px;display:flex;align-items:center;background:linear-gradient(135deg,var(--cd,#1e3a8a),var(--c,#2563eb))!important}
.itw-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.itw-hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.55) 0%,rgba(0,0,0,.35) 40%,rgba(0,0,0,.15) 100%)}
.itw-hero-content{position:relative;z-index:2;color:#fff!important}
.itw-hero-badge{display:inline-block;background:rgba(255,255,255,.15)!important;border:1px solid rgba(255,255,255,.25);padding:5px 16px;border-radius:50px;font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:1.2rem;color:#fff!important}
.itw-hero h1{font-size:clamp(2rem,5vw,3.4rem);font-weight:900;line-height:1.08;margin-bottom:14px;max-width:700px;color:#fff!important}
.itw-hero p{font-size:1.05rem;max-width:560px;color:rgba(255,255,255,.9)!important;margin-bottom:2rem;line-height:1.6}
.itw-hero a{color:#fff!important}
.itw-hero .itw-btn--white,.itw-hero a.itw-btn--white{background:#fff!important;color:var(--cd,#1e293b)!important}
.itw-hero .itw-breadcrumb,.itw-hero .itw-breadcrumb a,.itw-hero .itw-breadcrumb span{color:rgba(255,255,255,.75)!important;background:none!important;background-color:transparent!important;border:none!important;box-shadow:none!important}
.itw-hero .itw-breadcrumb a:hover{color:#fff!important}
/* Alle tekst in hero: wit, geen achtergrond */
.itw-hero *{background-color:transparent}
.itw-hero .itw-hero-badge{background:rgba(255,255,255,.15)!important}

/* Hero: Compact (subpages) */
.itw-hero--compact{min-height:220px;padding:clamp(3rem,5vw,4rem) 0}
.itw-hero--compact h1{font-size:clamp(1.6rem,3.5vw,2.4rem)}

/* Hero: Split (text + visual) */
.itw-hero--split .itw-hero-content{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:768px){.itw-hero--split .itw-hero-content{grid-template-columns:1fr}}

/* ══════════════════════════════════════════════════════════════
   CARD WIDGETS
   ══════════════════════════════════════════════════════════════ */

/* Grid */
.itw-grid{display:grid;gap:24px}
.itw-grid--2{grid-template-columns:repeat(2,1fr)}
.itw-grid--3{grid-template-columns:repeat(3,1fr)}
.itw-grid--4{grid-template-columns:repeat(4,1fr)}
.itw-grid--auto{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
@media(max-width:900px){.itw-grid--3,.itw-grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.itw-grid--2,.itw-grid--3,.itw-grid--4,.itw-grid--auto{grid-template-columns:1fr}}

/* Card: Standard */
.itw-card{background:#fff;border:1px solid var(--bdr,#e2e8f0);border-radius:var(--radius,16px);overflow:hidden;transition:all .3s;display:flex;flex-direction:column}
.itw-card:hover{border-color:var(--c);transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08)}

/* Card: With accent stripe */
.itw-card--accent::before{content:'';display:block;height:4px;background:linear-gradient(90deg,var(--c),var(--cd));opacity:0;transition:opacity .3s}
.itw-card--accent:hover::before{opacity:1}

/* Card: Glass */
.itw-card--glass{background:rgba(255,255,255,.6);backdrop-filter:blur(12px);border-color:rgba(255,255,255,.2)}

/* Card: Dark */
.itw-card--dark{background:#1e293b;border-color:#334155;color:#e2e8f0}
.itw-card--dark:hover{border-color:var(--c)}
.itw-card--dark .itw-card-title{color:#fff}
.itw-card--dark .itw-card-desc{color:#94a3b8}

/* Card inner */
.itw-card-head{padding:22px 24px 0;display:flex;align-items:flex-start;gap:16px}
.itw-card-icon{width:52px;height:52px;border-radius:14px;background:var(--cl);color:var(--c);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;transition:all .3s}
.itw-card:hover .itw-card-icon{background:var(--c);color:#fff;transform:scale(1.05)}
.itw-card-body{padding:14px 24px 24px;flex:1;display:flex;flex-direction:column}
.itw-card-title{font-size:1.05rem;font-weight:800;color:var(--ink,#111827)!important;margin-bottom:6px;line-height:1.25}
.itw-card-desc{font-size:.88rem;color:var(--dim,#374151)!important;line-height:1.65;margin-bottom:auto}

/* Card image */
.itw-card-img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.itw-card-img--sq{aspect-ratio:1/1}

/* Card link (text-style, not button) */
.itw-card-link{display:inline-flex;align-items:center;gap:6px;color:var(--c);font-weight:700;font-size:.84rem;margin-top:16px;transition:gap .2s,color .2s;text-decoration:none}
.itw-card-link:hover{gap:10px;color:var(--cd)}
.itw-card-link i{font-size:.7rem;transition:transform .2s}
.itw-card-link:hover i{transform:translateX(3px)}

/* Card: Featured (wide, 2 columns) */
.itw-card--featured{grid-column:1 / -1}
.itw-card--featured .itw-card-inner{display:grid;grid-template-columns:1fr 1fr;gap:0}
@media(max-width:768px){.itw-card--featured .itw-card-inner{grid-template-columns:1fr}}

/* Card meta/chips */
.itw-card-meta{display:flex;gap:10px;margin-top:4px;font-size:.78rem;color:#4b5563}
.itw-card-meta i{color:var(--c);font-size:.7rem}
.itw-chips{display:flex;flex-wrap:wrap;gap:6px;padding:0 24px 20px;border-top:1px solid #f1f5f9;padding-top:14px}
.itw-chip{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;color:#1e293b;background:#f1f5f9;padding:4px 10px;border-radius:6px;border:1px solid #e2e8f0;font-weight:500}
.itw-chip i{color:var(--c);font-size:.6rem}

/* ══════════════════════════════════════════════════════════════
   SERVICE CARDS (diensten pagina)
   ══════════════════════════════════════════════════════════════ */
.itw-services{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}
@media(max-width:900px){.itw-services{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.itw-services{grid-template-columns:1fr}}

/* ══════════════════════════════════════════════════════════════
   STATS / COUNTERS
   ══════════════════════════════════════════════════════════════ */
.itw-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px;padding:36px 0}
.itw-stat{text-align:center}
.itw-stat-icon{font-size:1.3rem;color:var(--c);margin-bottom:6px}
.itw-stat-val{font-size:1.6rem;font-weight:900;color:var(--ink,#0f172a)!important}
.itw-stat-lbl{font-size:.78rem;color:var(--dim,#374151)!important;font-weight:500;margin-top:2px}
.itw-section--dark .itw-stat-val{color:#fff}
.itw-section--dark .itw-stat-lbl{color:rgba(255,255,255,.7)}

/* ══════════════════════════════════════════════════════════════
   STEPS / PROCESS
   ══════════════════════════════════════════════════════════════ */
.itw-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;counter-reset:step}
.itw-step{position:relative;padding:28px 24px 24px;background:#fff;border-radius:var(--radius,16px);border:1px solid var(--bdr)}
.itw-step::before{counter-increment:step;content:counter(step);position:absolute;top:-14px;left:20px;width:32px;height:32px;border-radius:50%;background:var(--c);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem}
.itw-step h4{margin-top:6px;font-weight:800;font-size:.95rem;margin-bottom:6px;color:var(--ink,#0f172a)!important}
.itw-step p{font-size:.84rem;color:var(--dim,#374151)!important;line-height:1.5}

/* ══════════════════════════════════════════════════════════════
   FAQ / ACCORDION
   ══════════════════════════════════════════════════════════════ */
.itw-faq{max-width:760px;width:100%;margin-left:auto;margin-right:auto;box-sizing:border-box}
.itw-faq-item{border:1px solid var(--bdr);border-radius:12px;margin-bottom:10px;overflow:hidden;background:#fff}
.itw-faq-item summary{padding:16px 20px;font-weight:700;font-size:.92rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:flex-start;gap:12px;color:var(--ink,#0f172a)!important;transition:color .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;line-height:1.45}
.itw-faq-item summary:hover{color:var(--c)}
.itw-faq-item summary::after{content:'\f078';font-family:'Font Awesome 6 Free';font-weight:900;font-size:.72rem;color:var(--dim);transition:transform .2s;flex-shrink:0;margin-top:3px;line-height:1.2}
.itw-faq-item[open] summary::after{transform:rotate(180deg)}
.itw-faq-item p{padding:0 20px 16px;font-size:.88rem;color:var(--dim);line-height:1.65;margin:0;text-align:left}
@media(max-width:640px){
  .itw-faq{max-width:100%}
  .itw-faq-item{border-radius:14px;margin-bottom:12px}
  .itw-faq-item summary{padding:14px 16px;min-height:48px;align-items:center;font-size:.9rem}
  .itw-faq-item summary::after{margin-top:0}
  .itw-faq-item p{padding:0 16px 16px;font-size:.87rem;line-height:1.62}
}

/* ══════════════════════════════════════════════════════════════
   REVIEWS / TESTIMONIALS
   ══════════════════════════════════════════════════════════════ */
.itw-reviews{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.itw-review{background:#fff;border:1px solid var(--bdr);border-radius:var(--radius,16px);padding:24px}
.itw-review-stars{color:#f59e0b;font-size:.88rem;margin-bottom:10px}
.itw-review-text{font-size:.9rem;color:var(--ink,#0f172a)!important;line-height:1.6;margin-bottom:14px;font-style:italic}
.itw-review-author{display:flex;align-items:center;gap:10px}
.itw-review-avatar{width:38px;height:38px;border-radius:50%;background:var(--c);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;flex-shrink:0}
.itw-review-name{font-weight:700;font-size:.84rem}
.itw-review-loc{font-size:.75rem;color:var(--dim)}

/* ══════════════════════════════════════════════════════════════
   CTA BANNER
   ══════════════════════════════════════════════════════════════ */
.itw-cta{background:linear-gradient(135deg,var(--cd),var(--c))!important;color:#fff!important;padding:clamp(3rem,6vw,5rem) 0;text-align:center}
.itw-cta h2{font-size:clamp(1.4rem,3vw,2rem);font-weight:900;margin-bottom:8px;color:#fff!important}
.itw-cta p{color:rgba(255,255,255,.85)!important;margin-bottom:24px;font-size:.95rem;max-width:560px;margin-left:auto;margin-right:auto}
.itw-cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.itw-cta a,.itw-cta a:visited{color:#fff!important}
.itw-cta .itw-btn--white,.itw-cta a.itw-btn--white{background:#fff!important;color:var(--cd,#1e293b)!important}
.itw-cta .itw-btn--white:hover{background:var(--cl,#f1f5f9)!important;color:var(--cd,#1e293b)!important}
.itw-cta .itw-btn--ghost,.itw-cta a.itw-btn--ghost{border-color:rgba(255,255,255,.4)!important;color:#fff!important;background:transparent!important}
.itw-cta .itw-btn--ghost:hover{background:rgba(255,255,255,.15)!important;color:#fff!important}
.itw-cta .itw-btn--ghost i{color:#fff!important}

/* ══════════════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════════════ */
.itw-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:50px;font-weight:800;font-size:.88rem;transition:all .2s;cursor:pointer;text-decoration:none;border:none;font-family:inherit}
.itw-btn--primary,a.itw-btn--primary{background:var(--c)!important;color:#fff!important}
.itw-btn--primary:hover,a.itw-btn--primary:hover{opacity:.88;transform:translateY(-1px)}
.itw-btn--white{background:#fff!important;color:var(--cd,#1e293b)!important}
.itw-btn--white:hover{background:var(--cl)}
.itw-btn--outline,a.itw-btn--outline{background:transparent!important;border:2px solid var(--c)!important;color:var(--c)!important}
.itw-btn--outline:hover,a.itw-btn--outline:hover{background:var(--cl)!important;color:var(--cd)!important}
.itw-btn--ghost{background:transparent!important;border:2px solid rgba(255,255,255,.4)!important;color:#fff!important}
.itw-btn--ghost:hover{background:rgba(255,255,255,.15)!important;color:#fff!important}
.itw-btn--ghost i{color:#fff!important}

/* ══════════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════════ */
.itw-footer{background:#0f172a;color:#94a3b8;padding:48px 0 0}
/* Footer logo: wit maken via CSS filter (werkt op alle SVG/PNG logos) */
footer img[src*="logo"],footer img[alt*="logo"],.itw-footer img[src*="logo"]{filter:brightness(0) invert(1)!important;opacity:.85!important}
.itw-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:24px}
.itw-footer h4{color:#fff;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}
.itw-footer ul{list-style:none;padding:0;margin:0}
.itw-footer li{margin-bottom:7px}
.itw-footer li a{display:flex;align-items:center;gap:6px;font-size:.84rem;color:#94a3b8;transition:color .2s,padding-left .2s;text-decoration:none}
.itw-footer li a::before{content:'\f054';font-family:'Font Awesome 6 Free';font-weight:900;font-size:.5rem;color:var(--c);opacity:.7}
.itw-footer li a:hover{color:#fff;padding-left:4px}
.itw-footer-copy{text-align:center;padding:16px 0;border-top:1px solid #1e293b;font-size:.76rem;color:#4b5563}
.itw-footer-copy a{color:var(--c);font-weight:600}
@media(max-width:900px){.itw-footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.itw-footer-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════════════════════════════════
   TEAM
   ══════════════════════════════════════════════════════════════ */
.itw-team{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:28px}
.itw-team-card{text-align:center;background:#fff;border:1px solid var(--bdr);border-radius:20px;padding:32px 24px;transition:all .25s}
.itw-team-card:hover{border-color:var(--c);transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.07)}
.itw-team-avatar{width:88px;height:88px;border-radius:50%;background:var(--c);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:900;margin:0 auto 16px}
.itw-team-name{font-size:1.05rem;font-weight:800;margin-bottom:4px}
.itw-team-role{font-size:.82rem;color:var(--c);font-weight:600;margin-bottom:6px}

/* ══════════════════════════════════════════════════════════════
   TIMELINE
   ══════════════════════════════════════════════════════════════ */
.itw-timeline{position:relative;padding-left:36px;max-width:640px}
.itw-timeline::before{content:'';position:absolute;left:14px;top:0;bottom:0;width:2px;background:var(--bdr)}
.itw-tl-item{position:relative;margin-bottom:32px}
.itw-tl-dot{position:absolute;left:-29px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--c);border:3px solid #fff;box-shadow:0 0 0 2px var(--c)}
.itw-tl-year{font-size:.72rem;font-weight:700;color:var(--c);letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}
.itw-tl-title{font-size:1rem;font-weight:800;margin-bottom:4px;color:var(--ink,#0f172a)!important}
.itw-tl-desc{font-size:.87rem;color:var(--dim,#374151)!important;line-height:1.5}

/* ══════════════════════════════════════════════════════════════
   ABOUT BLOCK
   ══════════════════════════════════════════════════════════════ */
.itw-about-block{background:var(--cl);border-radius:20px;padding:40px;border-left:5px solid var(--c)}
.itw-about-block p{font-size:.97rem;color:var(--ink,#0f172a)!important;line-height:1.7;margin-bottom:12px}
.itw-about-block p:last-child{margin-bottom:0}

/* ══════════════════════════════════════════════════════════════
   USP LIST
   ══════════════════════════════════════════════════════════════ */
.itw-usps{display:flex;flex-direction:column;gap:10px}
.itw-usp{display:flex;align-items:center;gap:10px;font-size:.9rem;font-weight:600;color:var(--ink,#0f172a)!important}
.itw-usp i{color:var(--c);font-size:.85rem;width:16px;flex-shrink:0}

/* ══════════════════════════════════════════════════════════════
   BREADCRUMBS
   ══════════════════════════════════════════════════════════════ */
.itw-breadcrumb{display:flex;gap:6px;align-items:center;font-size:.79rem;color:rgba(255,255,255,.7);margin-bottom:14px;flex-wrap:wrap}
.itw-breadcrumb a{color:rgba(255,255,255,.75);text-decoration:none;transition:color .2s}
.itw-breadcrumb a:hover{color:#fff}
.itw-breadcrumb span{opacity:.5}

/* ══════════════════════════════════════════════════════════════
   VALUES GRID
   ══════════════════════════════════════════════════════════════ */
.itw-values{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.itw-value{background:#fff;border:1px solid var(--bdr);border-radius:var(--radius,16px);padding:28px;transition:all .25s}
.itw-value:hover{border-color:var(--c);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.07)}
.itw-value-icon{width:52px;height:52px;border-radius:14px;background:var(--cl);color:var(--c);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:14px}
.itw-value-title{font-size:1rem;font-weight:800;margin-bottom:6px;color:var(--ink,#0f172a)!important}
.itw-value-desc{font-size:.87rem;color:var(--dim,#374151)!important;line-height:1.55}

/* ══════════════════════════════════════════════════════════════
   NAVBAR / HEADER
   ══════════════════════════════════════════════════════════════ */
.itw-nav{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--bdr);box-shadow:0 1px 8px rgba(0,0,0,.04)}
.itw-nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:16px}
.itw-nav--dark{background:rgba(15,23,42,.95);backdrop-filter:blur(12px);border-color:rgba(255,255,255,.08)}
.itw-nav--dark .itw-nav-link{color:#cbd5e1}
.itw-nav--dark .itw-nav-link:hover,.itw-nav--dark .itw-nav-link.active{color:#fff}
.itw-nav--transparent{background:transparent;position:absolute;top:0;left:0;right:0;border:none;box-shadow:none}
.itw-nav--transparent .itw-nav-link{color:rgba(255,255,255,.85)}
.itw-nav--transparent .itw-nav-link:hover{color:#fff}
.itw-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.itw-logo-mark{width:42px;height:42px;border-radius:10px;background:var(--c);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:900;flex-shrink:0}
.itw-logo-text{display:flex;flex-direction:column;line-height:1.1}
.itw-logo-l1{font-size:.72rem;font-weight:600;color:var(--dim);letter-spacing:.06em;text-transform:uppercase}
.itw-logo-l2{font-size:1.05rem;font-weight:900;color:var(--c);text-transform:uppercase}
.itw-nav-links{display:flex;gap:24px;align-items:center}
.itw-nav-link{font-weight:600;font-size:.9rem;color:var(--ink);transition:color .2s;text-decoration:none}
.itw-nav-link:hover,.itw-nav-link.active{color:var(--c)}
.itw-nav-cta{background:var(--c);color:#fff!important;padding:10px 22px;border-radius:50px;font-weight:700;font-size:.88rem;text-decoration:none}
.itw-nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border:none;background:none}
.itw-nav-hamburger span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px}
.itw-nav--dark .itw-nav-hamburger span{background:#fff}
@media(max-width:768px){.itw-nav-links{display:none!important}.itw-nav-hamburger{display:flex}}

/* ══════════════════════════════════════════════════════════════
   TOPBAR / ANNOUNCEMENT
   ══════════════════════════════════════════════════════════════ */
.itw-topbar{background:var(--cd);color:#fff;font-size:13px;padding:8px 0;text-align:center;font-weight:500}
.itw-topbar a{color:#fff;font-weight:700;text-decoration:underline}
.itw-topbar--light{background:var(--cl);color:var(--ink)}
.itw-topbar--light a{color:var(--c)}
.itw-topbar--accent{background:var(--c);color:#fff}

/* ══════════════════════════════════════════════════════════════
   HERO EXTRA VARIANTS
   ══════════════════════════════════════════════════════════════ */
/* Hero: Centered */
.itw-hero--centered .itw-hero-content{text-align:center;display:flex;flex-direction:column;align-items:center}
.itw-hero--centered h1{max-width:800px}
.itw-hero--centered p{margin-left:auto;margin-right:auto}
.itw-hero--centered .itw-cta-btns{justify-content:center}

/* Hero: Minimal (no image, light bg) */
.itw-hero--minimal{background:linear-gradient(135deg,var(--cl),#fff);color:var(--ink);min-height:280px;padding:clamp(3rem,6vw,5rem) 0}
.itw-hero--minimal h1{color:var(--ink)}
.itw-hero--minimal p{color:var(--dim);opacity:1}
.itw-hero--minimal .itw-hero-badge{background:var(--cl);color:var(--c);border-color:var(--bdr)}

/* Hero: Video background */
.itw-hero--video{position:relative}
.itw-hero-video{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;z-index:0}

/* Hero: Gradient only (no image) */
.itw-hero--gradient{background:linear-gradient(135deg,var(--cd) 0%,var(--c) 100%)}

/* ══════════════════════════════════════════════════════════════
   CTA EXTRA VARIANTS
   ══════════════════════════════════════════════════════════════ */
/* CTA: Light */
.itw-cta--light{background:var(--cl);color:var(--ink)}
.itw-cta--light h2{color:var(--ink)}
.itw-cta--light p{color:var(--dim)}
.itw-cta--light .itw-btn--primary{background:var(--c);color:#fff}

/* CTA: Split (text left, form/image right) */
.itw-cta--split{text-align:left}
.itw-cta--split .itw-container{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.itw-cta--split p{margin-left:0;margin-right:0}
@media(max-width:768px){.itw-cta--split .itw-container{grid-template-columns:1fr}}

/* CTA: Banner (full width, compact) */
.itw-cta--banner{padding:clamp(1.5rem,3vw,2.5rem) 0}
.itw-cta--banner .itw-container{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.itw-cta--banner h2{font-size:clamp(1.1rem,2vw,1.4rem);margin-bottom:0}
.itw-cta--banner p{display:none}

/* ══════════════════════════════════════════════════════════════
   PRICING / TARIEVEN
   ══════════════════════════════════════════════════════════════ */
/* Desktop: grid 3 kolommen, featured kaart uitgelicht */
.itw-pricing{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;align-items:start}
.itw-price-card{background:#fff;border:1px solid var(--bdr);border-radius:var(--radius,20px);padding:32px 28px;text-align:center;transition:all .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.itw-price-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.1)}

/* Featured card: opvallend, hoger, gradient accent */
.itw-price-card--featured{border-color:var(--c);border-width:2px;position:relative;transform:scale(1.04);box-shadow:0 12px 40px rgba(0,0,0,.1);z-index:1;background:linear-gradient(180deg,#fff 85%,var(--cl) 100%)}
.itw-price-card--featured:hover{transform:scale(1.06) translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.14)}
.itw-price-card--featured::before{content:'Populair';position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--c),var(--cd));color:#fff;padding:5px 20px;border-radius:50px;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;box-shadow:0 4px 12px rgba(0,0,0,.15)}

/* Card content */
.itw-price-name{font-size:1.1rem;font-weight:800;margin-bottom:8px;color:var(--ink,#111827)}
.itw-price-amount{font-size:2.6rem;font-weight:900;color:var(--c);margin-bottom:4px;letter-spacing:-.02em}
.itw-price-period{font-size:.82rem;color:var(--dim,#374151);margin-bottom:20px}
.itw-price-features{list-style:none;padding:0;margin:0 0 24px;text-align:left}
.itw-price-features li{padding:9px 0;border-bottom:1px solid var(--bdr,#f1f5f9);font-size:.88rem;color:var(--ink,#111827);display:flex;align-items:center;gap:10px}
.itw-price-features li:last-child{border-bottom:none}
.itw-price-features li::before{content:'\f00c';font-family:'Font Awesome 6 Free';font-weight:900;color:var(--c);font-size:.72rem;flex-shrink:0}
.itw-price-cta{margin-top:auto;padding-top:8px}

/* Tarieven disclaimer */
.itw-tarieven-note{text-align:center;font-size:.82rem;color:var(--dim,#374151);max-width:580px;margin:0 auto 32px;padding:12px 20px;background:var(--bg,#f8fafc);border-radius:12px;border:1px solid var(--bdr,#e2e8f0);font-style:italic}

/* Mobile: horizontal scroll slider */
@media(max-width:768px){
  .itw-pricing{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:16px;padding:4px 4px 16px;scrollbar-width:none}
  .itw-pricing::-webkit-scrollbar{display:none}
  .itw-price-card{min-width:280px;max-width:320px;flex:0 0 auto;scroll-snap-align:center}
  .itw-price-card--featured{transform:none}
  .itw-price-card--featured:hover{transform:translateY(-4px)}
}

/* ══════════════════════════════════════════════════════════════
   CONTACT FORM
   ══════════════════════════════════════════════════════════════ */
.itw-form{max-width:600px}
.itw-form-row{margin-bottom:16px}
.itw-form-label{display:block;font-size:.84rem;font-weight:700;color:var(--ink);margin-bottom:6px}
.itw-form-input,.itw-form-textarea,.itw-form-select{width:100%;padding:12px 16px;border:1px solid var(--bdr);border-radius:10px;font-size:.9rem;font-family:inherit;transition:border-color .2s;background:#fff;color:var(--ink)}
.itw-form-input:focus,.itw-form-textarea:focus,.itw-form-select:focus{outline:none;border-color:var(--c);box-shadow:0 0 0 3px rgba(var(--c),.1)}
.itw-form-textarea{min-height:120px;resize:vertical}
.itw-form-hint{font-size:.75rem;color:var(--dim);margin-top:4px}

/* Contact: Split (form + info) */
.itw-contact-split{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:start}
@media(max-width:900px){.itw-contact-split{grid-template-columns:1fr}}
.itw-contact-info{background:var(--cl);border-radius:var(--radius,16px);padding:32px}
.itw-contact-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px;font-size:.9rem;color:var(--ink)}
.itw-contact-item i{color:var(--c);font-size:1rem;margin-top:2px;width:20px;flex-shrink:0}

/* ══════════════════════════════════════════════════════════════
   GALLERY / PORTFOLIO
   ══════════════════════════════════════════════════════════════ */
.itw-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.itw-gallery--masonry{columns:3;column-gap:16px}
.itw-gallery-item{border-radius:12px;overflow:hidden;position:relative;cursor:pointer;break-inside:avoid;margin-bottom:16px}
.itw-gallery-item img{width:100%;display:block;transition:transform .3s}
.itw-gallery-item:hover img{transform:scale(1.05)}
.itw-gallery-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;padding:20px 16px 12px;font-size:.84rem;font-weight:600;opacity:0;transition:opacity .3s}
.itw-gallery-item:hover .itw-gallery-caption{opacity:1}
@media(max-width:768px){.itw-gallery--masonry{columns:2}.itw-gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.itw-gallery--masonry{columns:1}.itw-gallery{grid-template-columns:1fr}}

/* ══════════════════════════════════════════════════════════════
   TRUST / LOGO CLOUD
   ══════════════════════════════════════════════════════════════ */
.itw-trust{padding:40px 24px;border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);background:var(--bg,#fff)}
.itw-trust-label{text-align:center;font-size:.78rem;font-weight:800;color:var(--dim);text-transform:uppercase;letter-spacing:.12em;margin-bottom:24px}
.itw-trust-logos{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap}
.itw-trust-logos img{height:48px;opacity:.7;filter:grayscale(.5);transition:all .3s;padding:8px 16px;background:rgba(0,0,0,.02);border:1px solid var(--bdr);border-radius:10px}
.itw-trust-logos img:hover{opacity:1;filter:grayscale(0);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.08)}
.itw-trust--dark{background:#0f172a;border-color:#1e293b}
.itw-trust--dark .itw-trust-label{color:#4b5563}
.itw-trust--dark .itw-trust-logos img{filter:grayscale(1) brightness(2)}

/* ══════════════════════════════════════════════════════════════
   TABS
   ══════════════════════════════════════════════════════════════ */
.itw-tabs-nav{display:flex;gap:4px;border-bottom:2px solid var(--bdr);margin-bottom:24px;overflow-x:auto}
.itw-tab-btn{padding:12px 20px;font-weight:700;font-size:.88rem;color:var(--dim);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;white-space:nowrap}
.itw-tab-btn:hover{color:var(--c)}
.itw-tab-btn.active{color:var(--c);border-bottom-color:var(--c)}
.itw-tab-panel{display:none}
.itw-tab-panel.active{display:block}

/* ══════════════════════════════════════════════════════════════
   NEWSLETTER / SIGNUP
   ══════════════════════════════════════════════════════════════ */
.itw-newsletter{background:var(--cl);border-radius:var(--radius,16px);padding:40px;text-align:center}
.itw-newsletter h3{font-size:1.2rem;font-weight:900;margin-bottom:6px;color:var(--ink)}
.itw-newsletter p{font-size:.9rem;color:var(--dim);margin-bottom:20px}
.itw-newsletter-form{display:flex;gap:8px;max-width:440px;margin:0 auto}
.itw-newsletter-form input{flex:1;padding:12px 16px;border:1px solid var(--bdr);border-radius:50px;font-size:.88rem;font-family:inherit}
.itw-newsletter-form input:focus{outline:none;border-color:var(--c)}
.itw-newsletter-form button{padding:12px 24px;background:var(--c);color:#fff;border:none;border-radius:50px;font-weight:700;font-size:.88rem;cursor:pointer}
@media(max-width:480px){.itw-newsletter-form{flex-direction:column}.itw-newsletter-form button{width:100%}}

/* ══════════════════════════════════════════════════════════════
   SOCIAL ICONS
   ══════════════════════════════════════════════════════════════ */
.itw-social{display:flex;gap:12px;align-items:center}
.itw-social a{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:1rem;transition:all .2s;text-decoration:none}
.itw-social a:hover{background:var(--c);color:#fff;border-color:var(--c)}
.itw-social--light a{background:var(--cl);border-color:var(--bdr);color:var(--dim)}
.itw-social--light a:hover{background:var(--c);color:#fff}

/* ══════════════════════════════════════════════════════════════
   MAP EMBED
   ══════════════════════════════════════════════════════════════ */
.itw-map{border-radius:var(--radius,16px);overflow:hidden;border:1px solid var(--bdr)}
.itw-map iframe{width:100%;height:300px;border:none;display:block}
.itw-map--tall iframe{height:450px}

/* ══════════════════════════════════════════════════════════════
   BADGE / TAG
   ══════════════════════════════════════════════════════════════ */
.itw-badge{display:inline-block;padding:4px 12px;border-radius:50px;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.itw-badge--primary{background:var(--cl);color:var(--c)}
.itw-badge--success{background:#d1fae5;color:#065f46}
.itw-badge--warning{background:#fef3c7;color:#92400e}
.itw-badge--danger{background:#fee2e2;color:#991b1b}
.itw-badge--dark{background:rgba(255,255,255,.12);color:#fff}

/* ══════════════════════════════════════════════════════════════
   DIVIDER
   ══════════════════════════════════════════════════════════════ */
.itw-divider{height:1px;background:var(--bdr);margin:40px 0}
.itw-divider--accent{background:linear-gradient(90deg,transparent,var(--c),transparent);height:2px}

/* ══════════════════════════════════════════════════════════════
   FLOATING PHONE / WHATSAPP BUTTON
   ══════════════════════════════════════════════════════════════ */
.itw-float{position:fixed;bottom:24px;z-index:999;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;box-shadow:0 4px 24px rgba(0,0,0,.25);transition:transform .2s;text-decoration:none}
.itw-float:hover{transform:scale(1.1)}
.itw-float--phone{right:24px;background:var(--c)}
.itw-float--whatsapp{right:24px;background:#25d366}
.itw-float--chat{right:24px;background:var(--c)}

/* ══════════════════════════════════════════════════════════════
   BEFORE / AFTER SLIDER
   ══════════════════════════════════════════════════════════════ */
.itw-compare{position:relative;overflow:hidden;border-radius:var(--radius,16px);cursor:col-resize}
.itw-compare img{display:block;width:100%;pointer-events:none}
.itw-compare-after{position:absolute;inset:0;overflow:hidden;width:50%}
.itw-compare-slider{position:absolute;top:0;bottom:0;width:4px;background:#fff;left:50%;z-index:2;cursor:col-resize}
.itw-compare-slider::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border-radius:50%;background:#fff;box-shadow:0 2px 12px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center}

/* ══════════════════════════════════════════════════════════════
   WEBSHOP — Product cards, cart, quick view, toast
   Hoge specificiteit zodat theme-switcher het niet kan breken.
   ══════════════════════════════════════════════════════════════ */

/* Product card */
.p-card{border:1px solid var(--bdr,#e2e8f0)!important;border-radius:16px!important;overflow:hidden!important;background:#fff!important;transition:all .3s;position:relative}
.p-card:hover{border-color:var(--c)!important;transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08)}
.p-card-body{padding:18px 18px 20px;color:var(--ink,#0f172a)!important}
.p-card-cat{font-size:.72rem;font-weight:800;color:#0f172a!important;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;padding-bottom:2px;border-bottom:2px solid var(--c);display:inline-block;width:fit-content;max-width:100%}
.p-card-title{font-size:.98rem;font-weight:800;color:#020617!important;margin-bottom:6px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.55em;letter-spacing:-.01em}
.p-card-desc{font-size:.82rem;color:#334155!important;line-height:1.55;margin-bottom:12px}
.p-card-price{font-size:1.22rem;font-weight:900;color:#020617!important;letter-spacing:-.02em}
.p-card-price small{font-size:.72rem;font-weight:500;color:var(--dim,#4b5563)!important}
.p-card-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;background:var(--cl,#f1f5f9)!important}
.p-card-placeholder{width:100%;aspect-ratio:4/3;background:linear-gradient(145deg,#e2e8f0,#f1f5f9)!important;display:flex;align-items:center;justify-content:center}
.p-card-placeholder i{font-size:2.5rem;color:var(--c);opacity:.45}

/* Cart button */
.p-card-cart{display:inline-flex;align-items:center;gap:6px;background:var(--c)!important;color:#fff!important;padding:8px 16px;border-radius:50px;font-weight:700;font-size:.76rem;border:none;cursor:pointer;font-family:inherit;transition:all .2s}
.p-card-cart:hover{opacity:.88}
.p-card-view{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--bdr,#e2e8f0)!important;background:#fff!important;color:var(--dim,#374151)!important;font-size:.8rem;cursor:pointer}
.p-card-view:hover{border-color:var(--c)!important;color:var(--c)!important}
.p-card-wishlist{position:absolute;top:12px;right:12px;z-index:2;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.9)!important;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--dim,#374151)!important;border:none}
.p-card-wishlist:hover,.p-card-wishlist.liked{color:#ef4444!important}

/* Mini cart button */
.mini-cart-btn{position:relative;display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:50px;border:1px solid var(--bdr,#e2e8f0)!important;background:#fff!important;cursor:pointer;font-weight:700;font-size:.84rem;color:var(--ink,#0f172a)!important}
.mini-cart-btn i{color:var(--c)!important}
.cart-badge{position:absolute;top:-6px;right:-6px;width:22px;height:22px;border-radius:50%;background:#ef4444!important;color:#fff!important;font-size:.68rem;font-weight:800;display:flex;align-items:center;justify-content:center}

/* Cart drawer */
.cart-drawer{position:fixed;top:0;right:-400px;width:380px;max-width:90vw;height:100vh;background:#fff!important;box-shadow:-8px 0 40px rgba(0,0,0,.15);z-index:1000;transition:right .3s;display:flex;flex-direction:column}
.cart-drawer.open{right:0}
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:999;opacity:0;visibility:hidden;transition:all .3s}
.cart-overlay.open{opacity:1;visibility:visible}
.cart-header{padding:20px 24px;border-bottom:1px solid var(--bdr,#e2e8f0)!important;display:flex;align-items:center;justify-content:space-between;background:#fff!important}
.cart-header h3{font-size:1.05rem;font-weight:800;margin:0;color:var(--ink,#0f172a)!important}
.cart-close{background:none!important;border:none!important;font-size:1.2rem;cursor:pointer;color:var(--dim,#374151)!important}
.cart-items{flex:1;overflow-y:auto;padding:16px 24px;background:#fff!important}
.cart-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid #f1f5f9!important}
.cart-item-img{width:60px;height:60px;border-radius:10px;object-fit:cover;background:var(--cl,#f1f5f9)!important;flex-shrink:0}
.cart-item-title{font-size:.86rem;font-weight:700;color:var(--ink,#0f172a)!important}
.cart-item-price{font-size:.82rem;font-weight:800;color:var(--c)!important}
.cart-item-qty button{width:26px;height:26px;border-radius:6px;border:1px solid var(--bdr,#e2e8f0)!important;background:#fff!important;cursor:pointer;color:var(--ink)!important}
.cart-item-remove{background:none!important;border:none!important;color:#ef4444!important;cursor:pointer}
.cart-empty{text-align:center;padding:40px 20px;color:var(--dim,#4b5563)!important;background:#fff!important}
.cart-footer{padding:20px 24px;border-top:1px solid var(--bdr,#e2e8f0)!important;background:#f8fafc!important}
.cart-total{display:flex;justify-content:space-between;font-size:1.05rem;font-weight:800;margin-bottom:14px;color:var(--ink,#0f172a)!important}
.cart-checkout{display:block;width:100%;padding:14px 16px;background:var(--c)!important;color:#fff!important;border:none;border-radius:12px;font-weight:800;font-size:.92rem;cursor:pointer;text-align:center;text-decoration:none;margin-bottom:10px;box-shadow:0 4px 16px rgba(15,23,42,.12)}
.cart-continue{display:block;width:100%;padding:11px 14px;background:#fff!important;border:1.5px solid var(--bdr,#e2e8f0)!important;border-radius:12px;color:var(--c)!important;font-weight:700;cursor:pointer;text-align:center;text-decoration:none;margin-bottom:8px;transition:border-color .2s,background .2s}
a.cart-continue:hover{border-color:var(--c)!important;background:var(--cl,#f1f5f9)!important}
button.cart-continue{border-style:solid!important;background:transparent!important;color:var(--dim,#374151)!important;font-weight:600!important}
button.cart-continue:hover{color:var(--ink)!important;border-color:#cbd5e1!important}

/* Quick view modal */
.qv-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1001;opacity:0;visibility:hidden;transition:all .3s;display:flex;align-items:center;justify-content:center}
.qv-overlay.open{opacity:1;visibility:visible}
.qv-modal{background:#fff!important;border-radius:20px;max-width:720px;width:90vw;max-height:85vh;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;position:relative}
.qv-close{position:absolute;top:16px;right:16px;background:none!important;border:none!important;font-size:1.2rem;cursor:pointer;color:var(--dim,#374151)!important;z-index:2}
.qv-img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:20px 0 0 20px}
.qv-content{padding:32px 28px;display:flex;flex-direction:column;background:#fff!important}
.qv-cat{font-size:.72rem;font-weight:700;color:var(--c)!important;text-transform:uppercase;margin-bottom:6px}
.qv-title{font-size:1.3rem;font-weight:900;margin-bottom:8px;color:var(--ink,#0f172a)!important}
.qv-desc{font-size:.88rem;color:var(--dim,#374151)!important;line-height:1.6;margin-bottom:20px;flex:1}
.qv-price{font-size:1.5rem;font-weight:900;color:var(--c)!important;margin-bottom:20px}
.qv-add{flex:1;padding:14px;background:var(--c)!important;color:#fff!important;border:none;border-radius:12px;font-weight:800;cursor:pointer}
.qv-detail{padding:14px 20px;border:2px solid var(--bdr,#e2e8f0)!important;border-radius:12px;color:var(--ink,#0f172a)!important;font-weight:700;text-decoration:none;text-align:center;background:#fff!important}
@media(max-width:640px){.qv-modal{grid-template-columns:1fr}.qv-img{border-radius:20px 20px 0 0;aspect-ratio:16/9}}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(100px);background:#0f172a!important;color:#fff!important;padding:14px 24px;border-radius:12px;font-size:.88rem;font-weight:600;z-index:1100;display:flex;align-items:center;gap:10px;box-shadow:0 8px 32px rgba(0,0,0,.2);transition:transform .3s;opacity:0}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast i{color:#10b981!important}

/* Category pills */
.cat-pill{padding:8px 18px;border-radius:50px;border:1.5px solid var(--bdr,#e2e8f0)!important;background:#fff!important;font-weight:600;font-size:.82rem;cursor:pointer;color:var(--ink,#0f172a)!important;font-family:inherit;transition:all .2s}
.cat-pill:hover,.cat-pill.active{background:var(--c)!important;color:#fff!important;border-color:var(--c)!important}

/* Shop toolbar */
.shop-sort{padding:8px 14px;border:1px solid var(--bdr,#e2e8f0)!important;border-radius:10px;font-size:.82rem;font-family:inherit;background:#fff!important;color:var(--ink)!important}
.shop-view-btn{width:36px;height:36px;border:1px solid var(--bdr,#e2e8f0)!important;border-radius:8px;background:#fff!important;color:var(--dim)!important;cursor:pointer}
.shop-view-btn.active,.shop-view-btn:hover{background:var(--c)!important;color:#fff!important;border-color:var(--c)!important}

/* ══════════════════════════════════════════════════════════════
   BLOG CARDS — met !important voor theme-switcher bescherming
   ══════════════════════════════════════════════════════════════ */
.blog-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))!important;gap:24px!important}
.blog-card{background:#fff!important;border:1px solid var(--bdr,#e2e8f0)!important;border-radius:16px!important;overflow:hidden!important;transition:all .25s;display:flex!important;flex-direction:column!important}
.blog-card:hover{border-color:var(--c)!important;transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.08)}
.blog-card-img{height:180px!important;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--cl,#f1f5f9),#f1f5f9)!important;display:flex;align-items:center;justify-content:center}
.blog-card-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.blog-card-cat{position:absolute;top:12px;left:12px;background:var(--c)!important;color:#fff!important;padding:3px 10px;border-radius:50px;font-size:.68rem;font-weight:700;z-index:1}
.blog-card-body{padding:20px!important;flex:1;display:flex;flex-direction:column;background:#fff!important}
.blog-card-title{font-size:.95rem!important;font-weight:800!important;color:var(--ink,#0f172a)!important;margin-bottom:6px;line-height:1.35}
.blog-card-excerpt{font-size:.82rem!important;color:var(--dim,#374151)!important;line-height:1.55;margin-bottom:14px;flex:1}
.blog-card-meta{display:flex;gap:12px;font-size:.74rem!important;color:var(--dim,#4b5563)!important;flex-wrap:wrap;margin-bottom:12px}
.blog-card-link{display:inline-flex;align-items:center;gap:4px;font-size:.82rem;font-weight:700;color:var(--c)!important;text-decoration:none;margin-top:auto}
.blog-card-link:hover{gap:8px}
/* Blog featured */
.blog-featured{background:linear-gradient(135deg,var(--cd),var(--c))!important;color:#fff!important;border-radius:20px!important;padding:40px!important;margin-bottom:40px;position:relative;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.blog-featured h2{color:#fff!important;font-size:clamp(1.4rem,3.5vw,2rem)!important;font-weight:900!important;margin-bottom:12px!important;line-height:1.2!important}
.blog-featured p{color:rgba(255,255,255,.88)!important;font-size:clamp(.9rem,1.5vw,1.05rem)!important;line-height:1.6!important;margin-bottom:16px!important}
.blog-featured-meta{color:rgba(255,255,255,.7)!important;font-size:.82rem!important;display:flex!important;gap:14px!important;flex-wrap:wrap!important}
.blog-featured-badge{background:rgba(255,255,255,.2)!important;color:#fff!important;padding:5px 16px!important;border-radius:50px!important;font-size:.75rem!important;font-weight:700!important;display:inline-block!important;margin-bottom:14px!important}
.blog-featured-img{border-radius:14px!important;width:100%!important;aspect-ratio:16/10!important;object-fit:cover!important}
.blog-featured .itw-btn{margin-top:18px!important}
/* Blog sidebar */
.blog-sidebar .sidebar-box{background:#fff!important;border:1px solid var(--bdr,#e2e8f0)!important;border-radius:14px!important;padding:22px!important;margin-bottom:20px!important}
.blog-sidebar .sidebar-box h4{color:var(--dim,#374151)!important;font-size:.8rem!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.06em!important;margin-bottom:14px!important}
.blog-sidebar .sidebar-box h4 i{color:var(--c)!important;margin-right:6px}
.blog-sidebar .sidebar-topic{display:flex!important;align-items:center!important;gap:8px!important;padding:10px 0!important;border-bottom:1px solid var(--bdr,#f1f5f9)!important;font-size:.88rem!important;color:var(--ink,#1e293b)!important;text-decoration:none!important;transition:color .2s}
.blog-sidebar .sidebar-topic:last-child{border-bottom:none!important}
.blog-sidebar .sidebar-topic:hover{color:var(--c)!important}
.blog-sidebar .sidebar-topic i{color:var(--c)!important;font-size:.7rem!important;width:12px!important;flex-shrink:0}
.blog-sidebar .sidebar-pill{display:inline-block!important;background:var(--cl,#f1f5f9)!important;color:var(--c)!important;padding:6px 14px!important;border-radius:50px!important;font-size:.78rem!important;font-weight:700!important;margin:3px!important}
/* Sidebar newsletter */
.sidebar-newsletter{background:var(--cl,#f1f5f9)!important;border-radius:14px!important;padding:22px!important;text-align:center!important;margin-bottom:20px!important}
.sidebar-newsletter h4{font-size:.95rem!important;font-weight:800!important;margin-bottom:6px!important;color:var(--ink,#0f172a)!important}
.sidebar-newsletter h4 i{color:var(--c)!important;margin-right:6px}
.sidebar-newsletter p{font-size:.82rem!important;color:var(--dim,#374151)!important;margin-bottom:14px!important}
.sidebar-newsletter input{width:100%!important;padding:11px 14px!important;border:1.5px solid var(--bdr,#e2e8f0)!important;border-radius:10px!important;font-family:inherit!important;font-size:.85rem!important;margin-bottom:10px!important;background:#fff!important;color:var(--ink)!important}
.sidebar-newsletter input:focus{outline:none!important;border-color:var(--c)!important}
.sidebar-newsletter .itw-btn{width:100%!important;justify-content:center!important}
/* Blog responsive */
.blog-layout{display:grid;grid-template-columns:1fr 280px;gap:40px;align-items:start}
@media(max-width:900px){.blog-layout{grid-template-columns:1fr!important}.blog-sidebar{position:static!important}.blog-featured{grid-template-columns:1fr!important}}
@media(max-width:640px){.blog-grid{grid-template-columns:1fr!important}}

/* ══════════════════════════════════════════════════════════════
   CONTACT PAGE — layout, info cards, form
   ══════════════════════════════════════════════════════════════ */
.contact-layout{display:grid!important;grid-template-columns:1fr 1fr!important;gap:48px!important;padding:56px 0;align-items:start}
.contact-card{background:#fff!important;border:1px solid var(--bdr,#e2e8f0)!important;border-radius:24px!important;padding:36px!important}
.contact-info-block{display:flex;flex-direction:column;gap:0}
.ci-item{display:flex!important;align-items:flex-start!important;gap:16px!important;padding:18px 0!important;border-bottom:1px solid var(--bdr,#f1f5f9)!important;color:var(--ink,#0f172a)!important;text-decoration:none!important}
.ci-item:last-child{border-bottom:none!important}
.ci-icon{width:48px!important;height:48px!important;border-radius:14px!important;background:var(--cl,#f1f5f9)!important;color:var(--c)!important;display:flex!important;align-items:center!important;justify-content:center!important;font-size:1.1rem!important;flex-shrink:0!important}
.ci-label{font-size:.75rem!important;font-weight:700!important;color:var(--dim,#4b5563)!important;text-transform:uppercase!important;letter-spacing:.05em!important;margin-bottom:2px!important}
.ci-value{font-size:1rem!important;font-weight:700!important;color:var(--ink,#0f172a)!important}
.ci-sub{font-size:.78rem!important;color:var(--dim,#4b5563)!important;margin-top:2px!important}
/* Contact form */
.contact-card h3,.contact-title{font-size:1.1rem!important;font-weight:800!important;color:var(--ink,#0f172a)!important;margin-bottom:20px!important}
.form-row{margin-bottom:16px!important}
.form-row label{display:block!important;font-size:.84rem!important;font-weight:700!important;color:var(--ink,#0f172a)!important;margin-bottom:6px!important}
.form-row input,.form-row textarea,.form-row select{width:100%!important;padding:12px 16px!important;border:1px solid var(--bdr,#e2e8f0)!important;border-radius:10px!important;font-size:.9rem!important;font-family:inherit!important;background:#fff!important;color:var(--ink,#0f172a)!important;transition:border-color .2s!important}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none!important;border-color:var(--c)!important}
.form-row textarea{min-height:120px!important;resize:vertical!important}
.form-half{display:grid!important;grid-template-columns:1fr 1fr!important;gap:16px!important}
.form-submit{display:flex!important;align-items:center!important;gap:8px!important;background:var(--c)!important;color:#fff!important;padding:14px 28px!important;border:none!important;border-radius:12px!important;font-weight:800!important;font-size:.92rem!important;cursor:pointer!important;font-family:inherit!important}
.form-submit:hover{opacity:.88!important}
/* Map placeholder */
.map-placeholder{width:100%!important;height:200px!important;border-radius:16px!important;background:var(--cl,#f1f5f9)!important;display:flex!important;align-items:center!important;justify-content:center!important;margin-top:24px!important;border:1px solid var(--bdr,#e2e8f0)!important;color:var(--dim)!important;font-size:.88rem!important}
.map-placeholder i{font-size:2rem!important;color:var(--c)!important;opacity:.5!important;margin-right:10px!important}
@media(max-width:800px){.contact-layout{grid-template-columns:1fr!important}.form-half{grid-template-columns:1fr!important}}

/* ══════════════════════════════════════════════════════════════
   FOOTER RESPONSIVE — alle varianten (footer-grid, wa-footer-grid, cb-footer-grid, mc-footer-grid)
   ══════════════════════════════════════════════════════════════ */
@media(max-width:900px){
  .footer-grid,[class*="footer-grid"]{grid-template-columns:1fr 1fr!important;gap:24px!important}
}
@media(max-width:640px){
  .footer-grid,[class*="footer-grid"]{grid-template-columns:1fr!important;gap:20px!important}
  footer{padding:32px 0 0!important}
  footer .footer-col,footer [class*="footer-col"],footer [class*="footer-links"]{margin-bottom:16px!important}
  footer .footer-col h4,footer [class*="footer-col"] h4{font-size:.85rem!important;margin-bottom:10px!important}
  footer .footer-col a,footer [class*="footer-col"] a,footer [class*="footer-links"] a{font-size:.88rem!important;padding:6px 0!important}
  footer .footer-col li,footer [class*="footer-col"] li{margin-bottom:8px!important}
  /* Footer brand */
  footer [class*="footer-brand"]{text-align:center!important;margin-bottom:16px!important}
  footer [class*="footer-tagline"]{font-size:.82rem!important;text-align:center!important}
  /* Footer copy centreren */
  footer [class*="footer-copy"]{text-align:center!important;padding:16px 0!important;font-size:.74rem!important}
  footer [class*="footer-copy"] span{display:block!important;margin-bottom:4px!important}
  /* Theme switcher compact */
  footer .footer-theme-switch,[class*="footer-theme"]{padding:14px 0!important;gap:6px!important}
  footer .fts-btn{padding:4px 10px!important;font-size:.68rem!important}
  footer .fts-label{font-size:.7rem!important}
  /* Legal links */
  footer .footer-legal,[class*="footer-legal"]{flex-direction:column!important;align-items:center!important;gap:8px!important;padding:12px 0!important}
  /* Logo in footer */
  footer [class*="logo-mark"]{width:32px!important;height:32px!important;font-size:.85rem!important}
  footer [class*="logo-l2"]{font-size:.88rem!important}
}

/* ══════════════════════════════════════════════════════════════
   DIENST DETAIL PAGE
   ══════════════════════════════════════════════════════════════ */
.detail-layout{display:grid!important;grid-template-columns:1fr 340px!important;gap:40px!important;padding:48px 0!important;align-items:start}
.detail-header{margin-bottom:24px!important}
.detail-cat{font-size:.75rem!important;font-weight:700!important;color:var(--c)!important;text-transform:uppercase!important;letter-spacing:.05em!important;margin-bottom:6px!important}
.detail-title{font-size:clamp(1.4rem,3vw,2rem)!important;font-weight:900!important;color:var(--ink,#0f172a)!important;margin-bottom:12px!important}
.detail-meta{display:flex!important;gap:16px!important;font-size:.82rem!important;color:var(--dim,#374151)!important;flex-wrap:wrap!important}
.detail-meta i{color:var(--c)!important}
.detail-body{font-size:.95rem!important;color:var(--ink,#334155)!important;line-height:1.75!important}
.detail-body h2,.detail-body h3{font-weight:800!important;color:var(--ink,#0f172a)!important;margin:24px 0 12px!important}
.detail-body ul,.detail-body ol{margin:12px 0!important;padding-left:20px!important}
.detail-body li{margin-bottom:8px!important;color:var(--ink,#374151)!important}
.detail-img{width:100%!important;border-radius:16px!important;margin-bottom:24px!important}
/* Sidebar cards in dienst detail */
.sidebar-card{background:#fff!important;border:1px solid var(--bdr,#e2e8f0)!important;border-radius:16px!important;padding:24px!important;margin-bottom:20px!important}
.sidebar-card h3,.sidebar-card h4{font-size:.92rem!important;font-weight:800!important;color:var(--ink,#0f172a)!important;margin-bottom:12px!important}
.sidebar-card p{font-size:.86rem!important;color:var(--dim,#374151)!important;line-height:1.55!important}
/* Dienst FAQ */
.dienst-faq{margin-top:32px!important}
.dienst-faq details{border:1px solid var(--bdr,#e2e8f0)!important;border-radius:12px!important;margin-bottom:10px!important;overflow:hidden!important}
.dienst-faq summary{padding:16px 20px!important;font-weight:700!important;font-size:.92rem!important;cursor:pointer!important;color:var(--ink,#0f172a)!important;list-style:none!important}
.dienst-faq summary:hover{color:var(--c)!important}
.dienst-faq p{padding:0 20px 16px!important;font-size:.88rem!important;color:var(--dim,#374151)!important;line-height:1.6!important;margin:0!important}
/* Inline contact form in dienst detail */
.dienst-form{background:var(--cl,#f1f5f9)!important;border-radius:16px!important;padding:28px!important;margin-top:20px!important}
.dienst-form h3{font-size:1rem!important;font-weight:800!important;color:var(--ink,#0f172a)!important;margin-bottom:16px!important}
@media(max-width:900px){.detail-layout{grid-template-columns:1fr!important}}

/* ══════════════════════════════════════════════════════════════
   OFFERTE / AFSPRAAK PAGE
   ══════════════════════════════════════════════════════════════ */
.offerte-layout{display:grid!important;grid-template-columns:1fr 340px!important;gap:40px!important;padding:48px 0!important;align-items:start}
.form-card{background:#fff!important;border:1px solid var(--bdr,#e2e8f0)!important;border-radius:20px!important;padding:32px!important}
.form-title{font-size:1.1rem!important;font-weight:800!important;color:var(--ink,#0f172a)!important;margin-bottom:4px!important}
.form-sub{font-size:.86rem!important;color:var(--dim,#374151)!important;margin-bottom:24px!important}
.form-inner .form-row{margin-bottom:16px!important}
.form-inner .form-row label{display:block!important;font-size:.84rem!important;font-weight:700!important;color:var(--ink,#0f172a)!important;margin-bottom:6px!important}
.form-inner .form-row input,.form-inner .form-row textarea,.form-inner .form-row select{width:100%!important;padding:12px 16px!important;border:1px solid var(--bdr,#e2e8f0)!important;border-radius:10px!important;font-size:.9rem!important;font-family:inherit!important;background:#fff!important;color:var(--ink,#0f172a)!important}
.form-inner .form-row input:focus,.form-inner .form-row textarea:focus,.form-inner .form-row select:focus{outline:none!important;border-color:var(--c)!important}
.form-inner .form-row textarea{min-height:120px!important;resize:vertical!important}
.form-half{display:grid!important;grid-template-columns:1fr 1fr!important;gap:16px!important}
.form-submit{display:inline-flex!important;align-items:center!important;gap:8px!important;background:var(--c)!important;color:#fff!important;padding:14px 28px!important;border:none!important;border-radius:12px!important;font-weight:800!important;font-size:.92rem!important;cursor:pointer!important;font-family:inherit!important}
.form-submit:hover{opacity:.88!important}
.form-note{font-size:.78rem!important;color:var(--dim,#4b5563)!important;margin-top:12px!important;display:flex!important;align-items:center!important;gap:6px!important}
.form-note i{color:#10b981!important}
.form-success{display:none;text-align:center!important;padding:40px!important}
.form-success i{font-size:3rem!important;color:#10b981!important;margin-bottom:12px!important}
.form-success h3{font-size:1.2rem!important;font-weight:900!important;color:var(--ink)!important;margin-bottom:8px!important}
.form-success p{color:var(--dim)!important}
/* Offerte steps sidebar */
.offerte-steps{display:flex!important;flex-direction:column!important;gap:16px!important;margin-bottom:24px!important}
.offerte-step{display:flex!important;gap:14px!important;align-items:flex-start!important}
.step-num{width:36px!important;height:36px!important;border-radius:50%!important;background:var(--c)!important;color:#fff!important;display:flex!important;align-items:center!important;justify-content:center!important;font-weight:800!important;font-size:.85rem!important;flex-shrink:0!important}
.step-text{font-size:.86rem!important;color:var(--ink,#374151)!important;line-height:1.5!important}
.step-text strong{color:var(--ink,#0f172a)!important;display:block!important;margin-bottom:2px!important}
@media(max-width:900px){.offerte-layout{grid-template-columns:1fr!important}.form-half{grid-template-columns:1fr!important}}

/* ══════════════════════════════════════════════════════════════
   SIDEBAR INFO WIDGET — contact, trust, steps
   ══════════════════════════════════════════════════════════════ */
.info-block{background:#fff!important;border:1px solid var(--bdr,#e2e8f0)!important;border-radius:20px!important;padding:28px!important;margin-bottom:20px!important;box-shadow:0 2px 12px rgba(0,0,0,.04)!important}
.info-block h3{font-size:1.05rem!important;font-weight:800!important;color:var(--ink,#0f172a)!important;margin-bottom:16px!important;display:flex!important;align-items:center!important;gap:8px!important}
.info-block h3 i{color:var(--c)!important}
/* Info items (telefoon, openingstijden, etc.) */
.info-item{display:flex!important;align-items:flex-start!important;gap:14px!important;margin-bottom:16px!important;font-size:.88rem!important;padding:12px!important;background:var(--bg,#f8fafc)!important;border-radius:12px!important;border:1px solid var(--bdr,#f1f5f9)!important}
.info-item i{color:var(--c)!important;width:20px!important;font-size:1rem!important;margin-top:2px!important;flex-shrink:0!important}
.info-item strong{display:block!important;font-weight:700!important;color:var(--ink,#0f172a)!important;margin-bottom:2px!important;font-size:.85rem!important}
.info-item span{color:var(--dim,#374151)!important;font-size:.82rem!important;line-height:1.5!important}
/* Trust badges */
.trust-row{display:flex!important;gap:8px!important;flex-wrap:wrap!important;margin-top:16px!important}
.trust-badge{background:var(--cl,#f1f5f9)!important;border:1px solid var(--bdr,#e2e8f0)!important;border-radius:10px!important;padding:10px 14px!important;font-size:.78rem!important;font-weight:700!important;display:flex!important;align-items:center!important;gap:6px!important;color:var(--ink,#0f172a)!important;flex:1!important;justify-content:center!important;min-width:0!important}
.trust-badge i{color:var(--c)!important;font-size:.85rem!important}
/* Bel-knop in sidebar */
.info-block .btn,.info-block .itw-btn,.info-block a[href^="tel"]{display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;width:100%!important;padding:14px!important;background:var(--c)!important;color:#fff!important;border:none!important;border-radius:12px!important;font-weight:800!important;font-size:.9rem!important;text-decoration:none!important;margin-top:12px!important;transition:opacity .2s!important}
.info-block .btn:hover,.info-block .itw-btn:hover,.info-block a[href^="tel"]:hover{opacity:.88!important}
/* Steps in sidebar */
.offerte-steps{counter-reset:step!important;display:flex!important;flex-direction:column!important;gap:14px!important;margin-top:16px!important}
.offerte-step{display:flex!important;align-items:flex-start!important;gap:14px!important;font-size:.87rem!important}
.step-num{width:32px!important;height:32px!important;border-radius:50%!important;background:var(--c)!important;color:#fff!important;display:flex!important;align-items:center!important;justify-content:center!important;font-weight:800!important;font-size:.82rem!important;flex-shrink:0!important;box-shadow:0 2px 8px rgba(0,0,0,.1)!important}
.step-text{flex:1!important}
.step-text strong{display:block!important;font-weight:700!important;color:var(--ink,#0f172a)!important;margin-bottom:2px!important;font-size:.86rem!important}
.step-text span{color:var(--dim,#374151)!important;font-size:.8rem!important;line-height:1.5!important}

/* Shop grid desktop default — ruimere kolommen + gap (sync met shop-template) */
.shop-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(268px,1fr))!important;gap:26px!important}
.shop-grid--list{grid-template-columns:1fr!important}
.shop-grid--list .p-card{display:grid!important;grid-template-columns:200px 1fr!important}

/* Shop responsive */
@media(max-width:900px){.shop-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))!important;gap:20px!important}}
@media(max-width:640px){
  .shop-grid{grid-template-columns:repeat(2,1fr)!important;gap:14px!important}
  .p-card-body{padding:14px 14px 16px!important}
  .p-card-title{font-size:.85rem!important}
  .p-card-cart{padding:6px 10px!important;font-size:.7rem!important}
  .p-card-view{width:30px!important;height:30px!important;font-size:.7rem!important}
  .cat-pills{overflow-x:auto;flex-wrap:nowrap!important;-webkit-overflow-scrolling:touch;padding-bottom:4px;gap:6px!important}
  .cat-pill{white-space:nowrap;flex-shrink:0;padding:6px 14px!important;font-size:.75rem!important}
  .shop-toolbar{flex-direction:column;align-items:stretch}
  .shop-actions{justify-content:space-between}
  .qv-modal{grid-template-columns:1fr!important}
  .qv-img{border-radius:20px 20px 0 0!important;aspect-ratio:16/9!important}
}
@media(max-width:380px){
  .shop-grid{grid-template-columns:1fr!important}
  .p-card-actions{flex-direction:column}
  .p-card-cart{width:100%;justify-content:center}
}

/* ══════════════════════════════════════════════════════════════
   MISSENDE WIDGETS — toegevoegd voor template kit completeness
   ══════════════════════════════════════════════════════════════ */

/* Blog Grid */
.itw-blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.itw-blog-card{background:#fff;border:1px solid var(--bdr,#e2e8f0);border-radius:16px;overflow:hidden;transition:all .25s}
.itw-blog-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(0,0,0,.08);border-color:var(--c,#2563eb)}
.itw-blog-card-img{height:180px;overflow:hidden;background:var(--cl,#f1f5f9)}
.itw-blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.itw-blog-card:hover .itw-blog-card-img img{transform:scale(1.05)}
.itw-blog-card-body{padding:20px}
.itw-blog-card-cat{font-size:.72rem;font-weight:700;color:var(--c,#2563eb);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.itw-blog-card-title{font-size:.95rem;font-weight:800;color:var(--ink,#0f172a);margin-bottom:6px;line-height:1.35}
.itw-blog-card-excerpt{font-size:.84rem;color:var(--dim,#374151);line-height:1.55}
.itw-blog-card-meta{display:flex;gap:12px;margin-top:12px;font-size:.72rem;color:var(--dim,#94a3b8)}

/* Product Grid */
.itw-product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.itw-product-card{background:#fff;border:1px solid var(--bdr,#e2e8f0);border-radius:14px;overflow:hidden;transition:all .25s}
.itw-product-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.07)}
.itw-product-card-img{aspect-ratio:1;overflow:hidden;background:var(--cl,#f8fafc)}
.itw-product-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.itw-product-card:hover .itw-product-card-img img{transform:scale(1.05)}
.itw-product-card-body{padding:14px}
.itw-product-card-title{font-size:.86rem;font-weight:700;color:var(--ink,#0f172a);margin-bottom:4px}
.itw-product-card-price{font-size:1.1rem;font-weight:900;color:var(--ink,#0f172a)}
.itw-product-card-price .old{text-decoration:line-through;color:var(--dim,#94a3b8);font-size:.85rem;font-weight:500;margin-right:6px}
.itw-product-card-btn{display:block;width:100%;padding:10px;border:none;border-radius:10px;background:var(--c,#2563eb);color:#fff;font-weight:700;font-size:.84rem;cursor:pointer;transition:all .2s;margin-top:10px;font-family:inherit;text-align:center}
.itw-product-card-btn:hover{filter:brightness(1.05)}

/* Category Pills */
.itw-category-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.itw-category-pill{padding:6px 16px;border:1px solid var(--bdr,#e2e8f0);border-radius:50px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s;background:#fff;color:var(--ink,#334155)}
.itw-category-pill:hover,.itw-category-pill.active{background:var(--c,#2563eb);color:#fff;border-color:var(--c,#2563eb)}

/* Cart Table */
.itw-cart-table{width:100%;border-collapse:collapse}
.itw-cart-table th{text-align:left;font-size:.72rem;color:var(--dim,#64748b);text-transform:uppercase;padding:10px 12px;border-bottom:2px solid var(--bdr,#e2e8f0)}
.itw-cart-table td{padding:12px;border-bottom:1px solid var(--bdr,#f1f5f9);font-size:.88rem}
.itw-cart-table .cart-img{width:60px;height:60px;border-radius:8px;object-fit:cover}
.itw-cart-table .cart-qty{display:flex;align-items:center;gap:8px}
.itw-cart-table .cart-qty button{width:28px;height:28px;border:1px solid var(--bdr,#e2e8f0);border-radius:6px;background:#fff;cursor:pointer;font-weight:700}
.itw-cart-table .cart-remove{color:#ef4444;cursor:pointer;font-size:.78rem}

/* Cart Summary */
.itw-cart-summary{background:var(--cl,#f8fafc);border:1px solid var(--bdr,#e2e8f0);border-radius:14px;padding:24px}
.itw-cart-summary-row{display:flex;justify-content:space-between;padding:8px 0;font-size:.88rem}
.itw-cart-summary-total{display:flex;justify-content:space-between;padding:12px 0;border-top:2px solid var(--bdr,#e2e8f0);font-size:1.1rem;font-weight:900}

/* Checkout Form */
.itw-checkout{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.itw-checkout-form label{display:block;font-size:.82rem;font-weight:600;margin-bottom:4px;margin-top:12px;color:var(--ink,#334155)}
.itw-checkout-form input,.itw-checkout-form select{width:100%;padding:10px 14px;border:1px solid var(--bdr,#cbd5e1);border-radius:8px;font-size:.88rem;font-family:inherit}
.itw-checkout-form input:focus{outline:none;border-color:var(--c,#2563eb);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.itw-checkout-payment{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.itw-checkout-payment label{display:flex;align-items:center;gap:8px;padding:12px;border:1px solid var(--bdr,#e2e8f0);border-radius:10px;cursor:pointer;font-size:.84rem}
.itw-checkout-payment input[type=radio]:checked + label,.itw-checkout-payment label:has(:checked){border-color:var(--c,#2563eb);background:rgba(37,99,235,.05)}

/* Service Cards (itw- variant) */
.itw-service-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}

/* Contact Form */
.itw-contact-form{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.itw-contact-form .full{grid-column:span 2}
.itw-contact-form label{display:block;font-size:.82rem;font-weight:600;margin-bottom:4px;color:var(--ink,#334155)}
.itw-contact-form input,.itw-contact-form textarea,.itw-contact-form select{width:100%;padding:10px 14px;border:1px solid var(--bdr,#cbd5e1);border-radius:8px;font-size:.88rem;font-family:inherit}
.itw-contact-form textarea{min-height:120px;resize:vertical}
.itw-contact-form input:focus,.itw-contact-form textarea:focus{outline:none;border-color:var(--c,#2563eb);box-shadow:0 0 0 3px rgba(37,99,235,.1)}

/* Counters (animated) */
.itw-counters{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px;text-align:center}
.itw-counter{padding:20px}
.itw-counter-val{font-size:2rem;font-weight:900;color:var(--c,#2563eb)}
.itw-counter-label{font-size:.78rem;color:var(--dim,#64748b);margin-top:4px}

/* Carousel */
.itw-carousel{position:relative;overflow:hidden;border-radius:14px}
.itw-carousel-track{display:flex;transition:transform .5s ease}
.itw-carousel-slide{min-width:100%;padding:20px}
.itw-carousel-nav{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.9);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.1)}
.itw-carousel-prev{left:12px}
.itw-carousel-next{right:12px}
.itw-carousel-dots{display:flex;gap:6px;justify-content:center;margin-top:12px}
.itw-carousel-dot{width:8px;height:8px;border-radius:50%;background:var(--bdr,#cbd5e1);cursor:pointer;transition:all .2s}
.itw-carousel-dot.active{background:var(--c,#2563eb);width:24px;border-radius:4px}

/* Icon List */
.itw-icon-list{display:grid;gap:12px}
.itw-icon-list-item{display:flex;align-items:start;gap:12px;padding:12px;background:#fff;border:1px solid var(--bdr,#e2e8f0);border-radius:10px}
.itw-icon-list-item i{color:var(--c,#2563eb);font-size:1.1rem;margin-top:2px;width:20px;text-align:center}
.itw-icon-list-item h4{font-size:.88rem;font-weight:700;color:var(--ink,#0f172a)}
.itw-icon-list-item p{font-size:.82rem;color:var(--dim,#475569);margin-top:2px}

/* Logo Cloud */
.itw-logo-cloud{display:flex;gap:24px;align-items:center;justify-content:center;flex-wrap:wrap;padding:24px 0}
.itw-logo-cloud img{height:36px;opacity:.5;filter:grayscale(1);transition:all .3s}
.itw-logo-cloud img:hover{opacity:1;filter:none}

/* Progress Bars */
.itw-progress-list{display:grid;gap:12px}
.itw-progress-item label{display:flex;justify-content:space-between;font-size:.82rem;font-weight:600;margin-bottom:4px}
.itw-progress-bar{height:8px;background:var(--cl,#e2e8f0);border-radius:4px;overflow:hidden}
.itw-progress-fill{height:100%;background:var(--c,#2563eb);border-radius:4px;transition:width .8s ease}

/* Video Embed */
.itw-video{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:16/9}
.itw-video iframe{width:100%;height:100%;border:none}
.itw-video-overlay{position:absolute;inset:0;background:rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .3s}
.itw-video-overlay:hover{background:rgba(0,0,0,.1)}
.itw-video-play{width:64px;height:64px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.2)}
.itw-video-play i{color:var(--c,#2563eb);font-size:1.5rem;margin-left:4px}

/* Animations */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* Hamburger active state */
.itw-nav-hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.itw-nav-hamburger.active span:nth-child(2){opacity:0}
.itw-nav-hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.nav-hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.active span:nth-child(2){opacity:0}
.nav-hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Tabs */
.itw-tabs{border:1px solid var(--bdr,#e2e8f0);border-radius:14px;overflow:hidden}
.itw-tab-btns{display:flex;border-bottom:1px solid var(--bdr,#e2e8f0);background:var(--cl,#f8fafc)}
.itw-tab-btn{flex:1;padding:12px;text-align:center;font-weight:700;font-size:.86rem;cursor:pointer;border:none;background:none;color:var(--dim,#64748b);transition:all .2s;border-bottom:2px solid transparent}
.itw-tab-btn:hover{color:var(--ink,#0f172a)}
.itw-tab-btn.active{color:var(--c,#2563eb);border-bottom-color:var(--c,#2563eb);background:#fff}
.itw-tab-panel{padding:20px;display:none}
.itw-tab-panel:first-of-type{display:block}

/* Gallery with lightbox support */
.itw-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}
.itw-gallery img{width:100%;height:200px;object-fit:cover;border-radius:10px;cursor:pointer;transition:all .3s}
.itw-gallery img:hover{transform:scale(1.03);box-shadow:0 8px 24px rgba(0,0,0,.12)}

/* Cookie Consent */
.itw-cookie-banner{position:fixed;bottom:0;left:0;right:0;background:#0f172a;color:#e2e8f0;padding:16px 24px;z-index:9999;display:flex;align-items:center;gap:16px;font-size:.84rem;box-shadow:0 -4px 20px rgba(0,0,0,.2);animation:slideUp .4s ease}
.itw-cookie-banner a{color:var(--c,#2563eb);text-decoration:underline}
.itw-cookie-btn{padding:8px 20px;border:none;border-radius:8px;font-weight:700;font-size:.82rem;cursor:pointer;font-family:inherit}
.itw-cookie-accept{background:var(--c,#2563eb);color:#fff}
.itw-cookie-reject{background:transparent;color:#94a3b8;border:1px solid #334155}

/* ══════════════════════════════════════════════════════════════
   Static builder (sbi-static-site-builder) — widget layer na hero
   ══════════════════════════════════════════════════════════════ */
.itw-static-widgets{max-width:1140px;margin:0 auto;padding:0 24px 48px}
.itw-static-widgets .itw-widget-root{margin-bottom:48px}
.itw-static-widgets .itw-widget-root:last-child{margin-bottom:0}
@media(max-width:640px){
  .itw-static-widgets{padding-bottom:32px}
}

/* ══════════════════════════════════════════════════════════════
   AGENT-3: reviews-carousel, comparison, before/after, testimonial-video, breadcrumbs, CTA sticky
   ══════════════════════════════════════════════════════════════ */
.itw-reviews-carousel-wrap{position:relative;margin:24px 0}
.itw-reviews-carousel{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-padding:24px;padding-bottom:8px;-webkit-overflow-scrolling:touch}
.itw-reviews-carousel::-webkit-scrollbar{height:6px}
.itw-reviews-carousel::-webkit-scrollbar-thumb{background:var(--bdr,#cbd5e1);border-radius:4px}
.itw-reviews-carousel-slide{flex:0 0 min(340px,88vw);scroll-snap-align:start}
.itw-reviews-carousel .itw-review{height:100%;margin:0}

.itw-comparison{margin:24px 0}
.itw-comparison-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:14px;border:1px solid var(--bdr,#e2e8f0)}
.itw-comparison-table{width:100%;min-width:520px;border-collapse:collapse;font-size:.86rem;background:#fff}
.itw-comparison-table thead th{background:var(--cl,#f8fafc);padding:14px 16px;text-align:left;font-weight:800;color:var(--ink,#0f172a);border-bottom:2px solid var(--bdr,#e2e8f0)}
.itw-comparison-table tbody th{text-align:left;padding:12px 16px;font-weight:700;color:var(--ink,#0f172a);border-bottom:1px solid var(--bdr,#f1f5f9);background:var(--bg,#fafafa)}
.itw-comparison-table td{padding:12px 16px;border-bottom:1px solid var(--bdr,#f1f5f9);color:var(--dim,#374151)}
.itw-comparison-table tbody tr:hover td{background:rgba(37,99,235,.04)}
.itw-comparison-table .itw-btn{margin:0}

.itw-beforeafter{margin:24px 0}
.itw-beforeafter-inner{display:grid;grid-template-columns:1fr 1fr;gap:12px;border-radius:16px;overflow:hidden;border:1px solid var(--bdr,#e2e8f0)}
.itw-beforeafter-col{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--cl,#f1f5f9)}
.itw-beforeafter-col img{width:100%;height:100%;object-fit:cover;display:block}
.itw-beforeafter-badge{position:absolute;top:12px;left:12px;z-index:2;background:rgba(15,23,42,.82);color:#fff;font-size:.72rem;font-weight:800;padding:6px 12px;border-radius:8px;text-transform:uppercase;letter-spacing:.04em}
.itw-beforeafter-badge--after{background:var(--c,#2563eb)}
.itw-beforeafter-caption{margin-top:12px;font-size:.84rem;color:var(--dim,#374151);text-align:center}

.itw-testvideo{border-radius:16px;border:1px solid var(--bdr,#e2e8f0);overflow:hidden;background:#fff;margin:24px 0}
.itw-testvideo-media .itw-video{border-radius:0}
.itw-testvideo-quote{margin:0;padding:20px 24px;border-left:4px solid var(--c,#2563eb);background:var(--bg,#f8fafc)}
.itw-testvideo-quote p{margin:0;font-size:1rem;line-height:1.55;color:var(--ink,#0f172a)}
.itw-testvideo-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:baseline;padding:16px 24px 20px}
.itw-testvideo-name{font-weight:800;color:var(--ink,#0f172a)}
.itw-testvideo-role{font-size:.84rem;color:var(--dim,#374151)}

.itw-breadcrumbs{padding:12px 0;font-size:.82rem}
.itw-breadcrumbs-list{display:flex;flex-wrap:wrap;align-items:center;gap:8px;list-style:none;margin:0;padding:0}
.itw-breadcrumbs-item{display:flex;align-items:center;color:var(--dim,#374151)}
.itw-breadcrumbs-item + .itw-breadcrumbs-item::before{content:'/';color:var(--bdr,#cbd5e1);margin:0 10px;font-weight:400}
.itw-breadcrumbs-item a{color:var(--c,#2563eb);text-decoration:none;font-weight:600}
.itw-breadcrumbs-item a:hover{text-decoration:underline}
.itw-breadcrumbs-current{color:var(--ink,#0f172a);font-weight:700}

.itw-cta--sticky{position:sticky;bottom:0;z-index:50;box-shadow:0 -8px 32px rgba(0,0,0,.12);margin-top:32px}

.itw-blog-grid--compact .itw-blog-card-img{height:140px}
.itw-blog-grid--compact .itw-blog-card-body{padding:16px}
.itw-blog-grid--featured .itw-blog-card:first-child{grid-column:span 2}
@media(max-width:768px){.itw-blog-grid--featured .itw-blog-card:first-child{grid-column:span 1}}

body.dark-mode .itw-comparison-table,body.dark-mode .itw-testvideo,body.dark-mode .itw-beforeafter-inner{background:#1e293b;border-color:#334155}
body.dark-mode .itw-comparison-table thead th{background:#0f172a;color:#f1f5f9}
body.dark-mode .itw-comparison-table tbody th{background:#1e293b;color:#e2e8f0}
body.dark-mode .itw-comparison-table td{color:#cbd5e1;border-color:#334155}
body.dark-mode .itw-testvideo-quote{background:#0f172a;border-color:var(--c,#2563eb)}
body.dark-mode .itw-testvideo-quote p,body.dark-mode .itw-testvideo-name{color:#f8fafc}
body.dark-mode .itw-breadcrumbs-current{color:#f1f5f9}

@media print{
  .itw-reviews-carousel{display:block}
  .itw-reviews-carousel-slide{flex:none;width:100%;page-break-inside:avoid}
  .itw-cta--sticky{position:static;box-shadow:none}
  .itw-comparison-scroll{overflow:visible}
}

/* Responsive missende widgets */
@media(max-width:640px){
  .itw-blog-grid{grid-template-columns:1fr}
  .itw-product-grid{grid-template-columns:repeat(2,1fr)}
  .itw-checkout{grid-template-columns:1fr}
  .itw-contact-form{grid-template-columns:1fr}
  .itw-contact-form .full{grid-column:span 1}
  .itw-checkout-payment{grid-template-columns:1fr}
}
