/* =====================================================================
   Meubelzoo — design system
   Tokens + components, extracted pixel-by-pixel from the design impressions.
   Green = action/reassurance · Orange = highlight/value. Roles never swap.
   ===================================================================== */

/* ---- Fonts (self-hosted Inter, latin subset, swap) ------------------ */
@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url("/assets/fonts/inter-400.woff2") format("woff2")}
@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url("/assets/fonts/inter-500.woff2") format("woff2")}
@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url("/assets/fonts/inter-600.woff2") format("woff2")}
@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url("/assets/fonts/inter-700.woff2") format("woff2")}

/* ---- Tokens --------------------------------------------------------- */
:root{
  --green:#4A9E2F; --green-dark:#3A8020; --green-light:#EBF5E6;
  /* Accessible text shades (the bright brand green/orange fail AA for small text on white).
     Used for green/orange TEXT links; bright --green/--orange stay for fills & icons. */
  --green-link:#3A8020;        /* green text on white  -> 4.9:1 AA */
  --green-ink:#2C661A;         /* green text on green-light -> 6:1 AA */
  --orange:#E8831A; --orange-light:#FFF3E8; --orange-text:#C65810;
  --orange-link:#A8480A;       /* orange text on white -> AA */
  --orange-badge:#B5500D;      /* white text on orange badge -> AA */
  --charcoal:#3D3D3D; --text:#2D2D2D; --muted:#6B7280; --light:#9CA3AF;
  --white:#fff; --off-white:#F9F8F6; --border:#E5E7EB; --error:#DC2626;
  --badge-grey-bg:#F3F4F6; --badge-grey-text:#374151;

  --font:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;

  --maxw:1280px; --gutter:clamp(16px,4vw,32px);
  --radius-card:12px; --radius-sm:8px; --radius-xs:6px; --radius-pill:999px;
  --shadow-card:0 1px 2px rgba(45,45,45,.04);
  --shadow-hover:0 12px 28px -12px rgba(45,45,45,.22);
  --shadow-pop:0 6px 20px -6px rgba(45,45,45,.25);

  --header-h:72px;
  --ease:cubic-bezier(.22,1,.36,1);            /* ease-out-quint */
  --t-fast:.16s; --t:.24s;

  --z-dropdown:100; --z-sticky:200; --z-backdrop:300; --z-modal:400; --z-toast:500;
}

/* ---- Reset ---------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--font);font-size:16px;line-height:1.65;color:var(--text);
  background:var(--white);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg,video{display:block;max-width:100%;height:auto}
img{object-fit:cover}
button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer;background:none;border:none}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none;padding:0}
h1,h2,h3,h4{line-height:1.22;color:var(--charcoal);font-weight:700;text-wrap:balance}
:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:3px}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}

/* ---- Layout helpers ------------------------------------------------- */
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);width:100%}
.section{padding-block:clamp(40px,6vw,64px)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-999px;top:0;z-index:var(--z-toast);background:var(--green);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;font-weight:600}
.skip-link:focus{left:0}

/* =====================================================================
   HEADER
   ===================================================================== */
.site-header{position:sticky;top:0;z-index:var(--z-sticky);background:var(--white)}
.header-main{border-bottom:1px solid var(--border)}
.header-main .container{display:flex;align-items:center;gap:clamp(16px,3vw,40px);min-height:var(--header-h)}

.brand{flex:0 0 auto;display:inline-flex;align-items:center}
.brand img{height:38px;width:auto}

/* Search pill */
.search{flex:1 1 auto;max-width:560px;position:relative;display:none}
.search input{
  width:100%;height:46px;border:1px solid var(--border);border-radius:var(--radius-pill);
  background:var(--off-white);padding:0 48px 0 20px;font-size:14.5px;color:var(--text);transition:border-color var(--t),background var(--t);
}
.search input::placeholder{color:var(--light)}
.search input:focus{outline:none;border-color:var(--green);background:#fff;box-shadow:0 0 0 3px var(--green-light)}
.search button{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:38px;height:38px;display:grid;place-items:center;border-radius:var(--radius-pill);color:var(--muted)}
.search button:hover{color:var(--green)}

/* Account / Favorieten / Winkelwagen */
.header-actions{flex:0 0 auto;margin-left:auto;display:flex;align-items:center;gap:clamp(8px,2vw,26px)}
.haction{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--charcoal);font-size:12px;font-weight:500;position:relative;padding:4px 6px;border-radius:10px;transition:color var(--t-fast)}
.haction svg{width:23px;height:23px;stroke-width:1.7}
.haction:hover{color:var(--green)}
.haction .label{display:none}
.cart-badge{
  position:absolute;top:-3px;right:-2px;min-width:18px;height:18px;padding:0 4px;border-radius:var(--radius-pill);
  background:var(--orange-badge);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;line-height:1;
}
.cart-badge[hidden]{display:none}
.icon-btn-mobile{display:flex;color:var(--charcoal)}
.icon-btn-mobile svg{width:26px;height:26px}

/* Category nav */
.header-cats{border-bottom:1px solid var(--border);display:none}
.header-cats .container{display:flex;align-items:center;gap:clamp(14px,2vw,30px);height:48px}
.cat-link{display:inline-flex;align-items:center;gap:5px;font-size:14px;font-weight:500;color:var(--charcoal);height:100%;position:relative;transition:color var(--t-fast)}
.cat-link svg{width:13px;height:13px;color:var(--light);transition:transform var(--t-fast),color var(--t-fast)}
.cat-link::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform var(--t) var(--ease)}
.cat-link:hover{color:var(--green)}
.cat-link:hover svg{color:var(--green)}
.cat-link:hover::after{transform:scaleX(1)}
.cat-link--deal{margin-left:auto;color:var(--orange-link);font-weight:600}
.cat-link--deal:hover{color:var(--orange-link);text-decoration:underline;text-underline-offset:3px}
.cat-link--deal::after{background:var(--orange)}

/* Mobile menu toggle */
.nav-toggle{display:flex;color:var(--charcoal);margin-right:4px}
.nav-toggle svg{width:26px;height:26px}

@media (min-width:640px){ .search{display:block} }
@media (min-width:880px){
  .haction .label{display:block}
  .nav-toggle{display:none}
}
@media (min-width:1000px){ .header-cats{display:block} }

/* =====================================================================
   BUTTONS
   ===================================================================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font);font-weight:600;border-radius:var(--radius-pill);border:1.5px solid transparent;cursor:pointer;transition:background var(--t),border-color var(--t),color var(--t),transform var(--t-fast),box-shadow var(--t);white-space:nowrap;text-align:center}
.btn:active{transform:translateY(1px)}
.btn svg{width:18px;height:18px;flex:0 0 auto}
.btn--primary{background:var(--green-dark);color:#fff;padding:14px 26px;font-size:.9375rem;box-shadow:0 1px 1px rgba(46,107,25,.3)}
.btn--primary:hover{background:#2E6B19}
.btn--lg{padding:15px 28px;font-size:1rem;width:100%}
.btn--outline{background:#fff;border-color:var(--green-link);color:var(--green-link);border-radius:var(--radius-xs);padding:8px 14px;font-size:.8125rem;font-weight:600;gap:6px}
.btn--outline:hover{background:var(--green-light)}
.btn--outline svg{width:15px;height:15px}
.icon-square{flex:0 0 auto;width:52px;height:52px;border:1.5px solid var(--border);border-radius:var(--radius-sm);display:grid;place-items:center;color:var(--charcoal);transition:border-color var(--t),color var(--t),background var(--t)}
.icon-square svg{width:22px;height:22px;transition:fill var(--t)}
.icon-square:hover{border-color:var(--green);color:var(--green)}
.icon-square[aria-pressed="true"]{color:var(--orange);border-color:var(--orange)}
.icon-square[aria-pressed="true"] svg{fill:var(--orange)}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative}
.hero-track{display:flex;overflow:hidden}
.hero-slide{position:relative;flex:0 0 100%;min-width:100%}
.hero-slide__media{position:relative;height:clamp(340px,46vw,500px)}
.hero-slide__media img{width:100%;height:100%;object-fit:cover;object-position:center 58%}
.hero-slide__media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(248,247,244,.92) 0%,rgba(248,247,244,.55) 32%,rgba(248,247,244,0) 60%)}
.hero-slide__inner{position:absolute;inset:0;display:flex;align-items:center}
.hero-slide__inner .container{width:100%}
.hero-content{max-width:min(46%,460px);position:relative;z-index:1}
.hero-content h1{font-size:clamp(2rem,5.2vw,2.85rem);color:var(--charcoal);letter-spacing:-.02em;line-height:1.08}
.hero-content p{margin-top:16px;font-size:clamp(1rem,1.5vw,1.075rem);color:#4a4a46;max-width:34ch}
.hero-content .btn{margin-top:26px}
.hero-dots{position:absolute;left:0;right:0;bottom:18px;display:flex;justify-content:center;gap:9px;z-index:2}
.hero-dot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.65);border:1.5px solid rgba(61,61,61,.35);transition:background var(--t),transform var(--t)}
.hero-dot[aria-current="true"]{background:#fff;border-color:var(--charcoal);transform:scale(1.15)}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.9);box-shadow:var(--shadow-pop);display:grid;place-items:center;color:var(--charcoal);opacity:0;transition:opacity var(--t),background var(--t)}
.hero:hover .hero-arrow{opacity:1}
.hero-arrow:hover{background:#fff}
.hero-arrow--prev{left:14px}.hero-arrow--next{right:14px}
.hero-arrow svg{width:20px;height:20px}
@media (max-width:640px){
  .hero-content{max-width:none}
  .hero-slide__media::after{background:linear-gradient(180deg,rgba(248,247,244,.2) 0%,rgba(248,247,244,.85) 78%)}
  .hero-slide__inner{align-items:flex-end;padding-bottom:38px}
  .hero-arrow{display:none}
}

/* =====================================================================
   USP STRIP
   ===================================================================== */
.usp{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#fff}
.usp .container{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 8px;padding-block:20px}
.usp-item{display:flex;align-items:center;gap:12px;justify-content:flex-start;position:relative}
.usp-item svg{flex:0 0 auto;width:27px;height:27px;color:var(--green);stroke-width:1.7}
.usp-item__t{font-size:14px;font-weight:600;color:var(--charcoal);line-height:1.3}
.usp-item__s{font-size:12.5px;color:var(--muted);line-height:1.3}
@media (min-width:740px){
  .usp .container{grid-template-columns:repeat(4,1fr);gap:0}
  .usp-item{justify-content:center}
  .usp-item+.usp-item::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);height:34px;width:1px;background:var(--border)}
}

/* =====================================================================
   SECTION HEADERS
   ===================================================================== */
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:22px}
.section-head h2{font-size:clamp(1.3rem,2.4vw,1.6rem);color:var(--charcoal)}
.link-green{color:var(--green-link);font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.link-green svg{width:15px;height:15px}
.link-green:hover{text-decoration:underline;text-underline-offset:3px}

/* =====================================================================
   CATEGORY TILES
   ===================================================================== */
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 12px}
@media (min-width:560px){.cat-grid{grid-template-columns:repeat(4,1fr)}}
@media (min-width:1000px){.cat-grid{grid-template-columns:repeat(7,1fr);gap:16px}}
.cat-tile{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}
.cat-tile__media{position:relative;width:100%;aspect-ratio:4/3;border-radius:var(--radius-card);overflow:visible}
.cat-tile__media img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-card);transition:transform var(--t) var(--ease)}
.cat-tile__badge{position:absolute;left:50%;bottom:-18px;transform:translateX(-50%);width:46px;height:46px;border-radius:50%;background:#fff;box-shadow:var(--shadow-pop);display:grid;place-items:center;color:var(--green);transition:transform var(--t) var(--ease)}
.cat-tile__badge svg{width:24px;height:24px;stroke-width:1.6}
.cat-tile__label{margin-top:8px;font-size:14px;font-weight:500;color:var(--charcoal)}
.cat-tile:hover .cat-tile__media img{transform:scale(1.04)}
.cat-tile:hover .cat-tile__badge{transform:translateX(-50%) translateY(-3px)}

/* =====================================================================
   INSPIRATIE / SHOWROOM BANNER
   ===================================================================== */
.showroom{position:relative;border-radius:16px;overflow:hidden;min-height:clamp(280px,36vw,420px);display:flex;align-items:center}
.showroom img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.showroom::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(38,38,36,.72) 0%,rgba(38,38,36,.42) 42%,rgba(38,38,36,.05) 70%,transparent 100%)}
.showroom__content{position:relative;z-index:1;color:#fff;max-width:460px;padding:clamp(26px,5vw,56px)}
.showroom__content h2{color:#fff;font-size:clamp(1.5rem,3.2vw,2.1rem);letter-spacing:-.01em}
.showroom__content p{margin-top:14px;font-size:1.05rem;line-height:1.55;color:rgba(255,255,255,.92);max-width:36ch}
.showroom__content .btn{margin-top:24px}
.showroom .btn--light{background:#fff;color:var(--green-link)}
.showroom .btn--light:hover{background:var(--off-white)}
@media (max-width:560px){
  .showroom::after{background:linear-gradient(180deg,rgba(38,38,36,.2) 0%,rgba(38,38,36,.78) 80%)}
  .showroom{align-items:flex-end}
}

/* =====================================================================
   PRODUCT CARDS (listing / featured)
   ===================================================================== */
.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media (min-width:760px){.product-grid{grid-template-columns:repeat(4,1fr);gap:18px}}
.pcard{background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow var(--t),transform var(--t) var(--ease)}
.pcard:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}
.pcard__media{position:relative;aspect-ratio:1;background:var(--off-white)}
.pcard__media img{width:100%;height:100%}
.pcard__fav{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;color:var(--charcoal);box-shadow:var(--shadow-card)}
.pcard__fav svg{width:18px;height:18px}
.pcard__fav[aria-pressed="true"]{color:var(--orange)}
.pcard__fav[aria-pressed="true"] svg{fill:var(--orange)}
.pcard__body{padding:14px 14px 16px;display:flex;flex-direction:column;gap:4px;flex:1}
.pcard__name{font-size:14px;font-weight:600;color:var(--charcoal)}
.pcard__variant{font-size:13px;color:var(--muted)}
.pcard__price{font-size:16px;font-weight:700;color:var(--charcoal);margin-top:6px}
.pcard__price del{color:var(--muted);font-weight:500;margin-left:6px}

/* =====================================================================
   BADGES
   ===================================================================== */
.badge{display:inline-block;font-size:.75rem;font-weight:600;padding:4px 11px;border-radius:var(--radius-pill);line-height:1.4}
.badge--bestseller{background:var(--badge-grey-bg);color:var(--badge-grey-text)}
.badge--nieuw{background:var(--green-light);color:var(--green-ink)}
.badge--sale{background:var(--orange-light);color:var(--orange-link)}
.badge--abs{position:absolute;top:14px;left:14px;z-index:1}

/* =====================================================================
   STAR RATING
   ===================================================================== */
.stars{display:inline-flex;align-items:center;gap:8px}
.stars__icons{position:relative;display:inline-flex;line-height:0}
.stars__track{display:inline-flex;color:#DADCE0}
.stars__fill{position:absolute;inset:0;display:inline-flex;overflow:hidden;white-space:nowrap;color:var(--orange)}
.stars__icons svg{width:17px;height:17px;flex:0 0 auto}
.stars__val{font-size:14px;color:var(--charcoal);font-weight:600}
.stars__count{font-size:14px;color:var(--green-link);font-weight:500}
.stars__count:hover{text-decoration:underline;text-underline-offset:2px}

/* =====================================================================
   PRODUCT DETAIL PAGE
   ===================================================================== */
.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:7px;font-size:13px;color:var(--muted);padding-block:18px 6px}
.breadcrumb a{color:var(--muted);display:inline-flex;align-items:center;gap:7px}
.breadcrumb a:hover{color:var(--green)}
.breadcrumb svg{width:14px;height:14px;color:var(--light)}
.breadcrumb .sep{color:var(--light)}
.breadcrumb [aria-current]{color:var(--charcoal);font-weight:500}

.pdp{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,48px);padding-top:8px}
@media (min-width:920px){.pdp{grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);align-items:start}}

/* Gallery */
.gallery__main{position:relative;aspect-ratio:1;border-radius:var(--radius-card);overflow:hidden;background:var(--off-white)}
.gallery__main img{width:100%;height:100%;opacity:0;position:absolute;inset:0;transition:opacity var(--t) var(--ease)}
.gallery__main img.is-active{opacity:1;position:relative}
.gallery__nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.92);box-shadow:var(--shadow-pop);display:grid;place-items:center;color:var(--charcoal);transition:background var(--t)}
.gallery__nav:hover{background:#fff}
.gallery__nav svg{width:20px;height:20px}
.gallery__nav--next{right:14px}.gallery__nav--prev{left:14px}
.gallery__thumbs{display:flex;gap:10px;margin-top:14px;overflow-x:auto;scrollbar-width:thin;padding-bottom:2px}
.thumb{flex:0 0 auto;width:74px;height:74px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);background:var(--off-white);transition:border-color var(--t-fast)}
.thumb img{width:100%;height:100%}
.thumb.is-active{border:2px solid var(--orange)}

/* Info column */
.pinfo{display:flex;flex-direction:column}
.pinfo h1{font-size:clamp(1.4rem,3vw,1.65rem);color:var(--charcoal);margin-bottom:12px;letter-spacing:-.01em}
.pinfo__rating{margin-bottom:16px}
.pinfo__price{font-size:clamp(1.6rem,3vw,1.75rem);font-weight:700;color:var(--charcoal);line-height:1}
.pinfo__price del{font-size:1.1rem;color:var(--muted);font-weight:500;margin-left:10px}
.pinfo__taxline{font-size:14px;color:var(--muted);margin-top:8px}
.pinfo__taxline .ship{color:var(--green-link);font-weight:500}
.pinfo__taxline .sep{margin-inline:8px;color:var(--border)}
.pinfo__desc{font-size:15px;color:var(--text);margin-top:18px;max-width:48ch}
.feature-list{margin-top:18px;display:flex;flex-direction:column;gap:10px}
.feature-list li{display:flex;align-items:center;gap:10px;font-size:14.5px;color:var(--text)}
.feature-list svg{flex:0 0 auto;width:20px;height:20px;color:var(--green)}

.spec-block{margin-top:22px;border-top:1px solid var(--border);padding-top:18px}
.spec-row{display:flex;gap:12px;font-size:14px}
.spec-row dt{color:var(--muted);min-width:96px;font-weight:500}
.spec-row dd{color:var(--charcoal)}
.spec-toggle{margin-top:14px;display:inline-flex;align-items:center;gap:6px;color:var(--green-link);font-weight:600;font-size:14px}
.spec-toggle svg{width:16px;height:16px;transition:transform var(--t)}
.spec-toggle[aria-expanded="true"] svg{transform:rotate(180deg)}
.spec-table{margin-top:14px;display:grid;gap:10px}
.spec-table[hidden]{display:none}
.spec-table .spec-row{padding-bottom:10px;border-bottom:1px solid var(--border)}
.spec-table .spec-row:last-child{border-bottom:0}

/* Stock block */
.stock{margin-top:22px;background:var(--green-light);border-radius:var(--radius-sm);padding:13px 16px;display:flex;align-items:center;gap:11px}
.stock__icon{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center}
.stock__icon svg{width:13px;height:13px;stroke-width:2.6}
.stock__text{font-size:14px;color:var(--green-ink);line-height:1.4}
.stock__text strong{color:var(--green-ink);font-weight:700}
.stock__info{margin-left:auto;color:var(--green);opacity:.7}
.stock__info svg{width:16px;height:16px}
.stock--out{background:#FEF2F2}
.stock--out .stock__icon{background:var(--error)}
.stock--out .stock__text,.stock--out .stock__text strong{color:var(--error)}

/* Buy row */
.buy-row{margin-top:18px;display:flex;gap:12px;align-items:stretch}
.qty{flex:0 0 auto;display:inline-flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--radius-sm);height:52px;overflow:hidden}
.qty button{width:42px;height:100%;display:grid;place-items:center;color:var(--charcoal);font-size:20px;transition:background var(--t-fast)}
.qty button:hover{background:var(--off-white);color:var(--green)}
.qty input{width:40px;height:100%;text-align:center;border:none;border-inline:1px solid var(--border);font-size:15px;font-weight:600;-moz-appearance:textfield}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none}
.buy-row .btn--lg{flex:1}

/* Trust strip */
.trust{margin-top:22px;display:flex;flex-wrap:wrap;gap:18px 24px;padding-top:20px;border-top:1px solid var(--border)}
.trust-item{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--muted)}
.trust-item svg{flex:0 0 auto;width:20px;height:20px;color:var(--green)}
.trust-item strong{display:block;color:var(--charcoal);font-weight:600;font-size:13px;line-height:1.25}
.trust-item span{font-size:12px;color:var(--muted)}

/* =====================================================================
   BUNDLE — "Vaak samen gekocht"
   ===================================================================== */
.bundle{margin-top:clamp(40px,6vw,64px);border:1px solid var(--border);border-radius:var(--radius-card);padding:clamp(18px,3vw,26px)}
.bundle h2{font-size:1.1rem;margin-bottom:20px}
.bundle__grid{display:grid;grid-template-columns:1fr;gap:20px}
@media (min-width:760px){.bundle__grid{grid-template-columns:minmax(0,2.4fr) minmax(0,1fr);align-items:stretch}}
.bundle__items{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:18px}
.bmini{display:flex;flex-direction:column;gap:8px}
.bmini__media{width:84px;height:84px;border-radius:var(--radius-sm);overflow:hidden;background:var(--off-white);border:1px solid var(--border)}
.bmini__media img{width:100%;height:100%}
.bmini__name{font-size:13.5px;font-weight:600;color:var(--charcoal);line-height:1.3}
.bmini__variant{font-size:12px;color:var(--muted)}
.bmini__price{font-size:14px;font-weight:700;color:var(--charcoal)}
.bmini .btn--outline{align-self:flex-start;margin-top:2px}
.bundle__total{background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius-sm);padding:18px;display:flex;flex-direction:column;justify-content:center;gap:6px}
.bundle__total .lbl{font-size:13px;color:var(--muted)}
.bundle__total .amt{font-size:1.35rem;font-weight:700;color:var(--charcoal)}
.bundle__total .btn{margin-top:10px;width:100%}

/* =====================================================================
   FOOTER
   ===================================================================== */
.newsletter{background:var(--green-light);border-top:1px solid var(--border)}
.newsletter .container{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px;padding-block:34px}
.newsletter h3{font-size:1.2rem;color:var(--charcoal)}
.newsletter p{font-size:14px;color:var(--green-ink);margin-top:4px}
.newsletter form{display:flex;gap:10px;flex:1 1 320px;max-width:440px}
.newsletter input{flex:1;height:48px;border:1px solid var(--border);border-radius:var(--radius-pill);padding:0 20px;background:#fff;font-size:14px}
.newsletter input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(74,158,47,.18)}

.site-footer{background:var(--off-white);border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px 24px;padding-block:48px}
@media (min-width:780px){.footer-grid{grid-template-columns:1.6fr 1fr 1fr 1fr}}
.footer-col h4{font-size:14px;font-weight:700;color:var(--charcoal);margin-bottom:14px;text-transform:none}
.footer-col ul{display:flex;flex-direction:column;gap:9px}
.footer-col a{font-size:14px;color:var(--muted)}
.footer-col a:hover{color:var(--green)}
.footer-brand img{height:38px;margin-bottom:14px}
.footer-brand p{font-size:14px;color:var(--muted);max-width:34ch}
.footer-social{display:flex;gap:10px;margin-top:16px}
.footer-social a{width:38px;height:38px;border-radius:50%;border:1px solid var(--border);display:grid;place-items:center;color:var(--charcoal);transition:border-color var(--t),color var(--t)}
.footer-social a:hover{border-color:var(--green);color:var(--green)}
.footer-social svg{width:18px;height:18px}
.pay-methods{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.pay-methods span{height:30px;padding:0 9px;border:1px solid var(--border);border-radius:6px;background:#fff;display:inline-flex;align-items:center;font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.02em}
.footer-bottom{border-top:1px solid var(--border)}
.footer-bottom .container{display:flex;flex-wrap:wrap;gap:8px 18px;padding-block:18px;font-size:13px;color:var(--muted);align-items:center}
.footer-bottom a{color:var(--muted)}
.footer-bottom a:hover{color:var(--green)}
.footer-bottom .spacer{margin-left:auto}

/* =====================================================================
   MOBILE NAV DRAWER
   ===================================================================== */
.drawer-backdrop{position:fixed;inset:0;background:rgba(45,45,45,.45);z-index:var(--z-backdrop);opacity:0;visibility:hidden;transition:opacity var(--t),visibility var(--t)}
.drawer-backdrop.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;left:0;bottom:0;width:min(82vw,340px);background:#fff;z-index:var(--z-modal);transform:translateX(-100%);transition:transform var(--t) var(--ease);display:flex;flex-direction:column;padding:20px}
.drawer.open{transform:translateX(0)}
.drawer__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.drawer__head img{height:34px}
.drawer__close{color:var(--charcoal)}
.drawer__close svg{width:26px;height:26px}
.drawer nav a{display:flex;align-items:center;justify-content:space-between;padding:13px 4px;font-size:16px;font-weight:500;color:var(--charcoal);border-bottom:1px solid var(--border)}
.drawer nav a svg{width:16px;height:16px;color:var(--light)}
.drawer nav a.deal{color:var(--orange);font-weight:600}

/* toast */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--charcoal);color:#fff;padding:13px 20px;border-radius:var(--radius-pill);font-size:14px;font-weight:500;z-index:var(--z-toast);display:flex;align-items:center;gap:9px;opacity:0;pointer-events:none;transition:opacity var(--t),transform var(--t) var(--ease);box-shadow:var(--shadow-pop)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast svg{width:18px;height:18px;color:#fff}
