/* =================================================================
   Malera NL — gedeeld design-systeem
   Gebruikt op: Homepage (front-page.php), Shop (woocommerce/archive-product.php)
   en Contact (page-contact.php) via template-parts/site-header.php + site-footer.php
   ================================================================= */

/* ===== RESET & TOKENS ===== */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#e2001a;--red-d:#b8001a;--red-l:#ff3344;
  --black:#0d0d0d;--dark:#1e1e1e;--mid:#555;--light:#999;
  --border:#e5e5e5;--bg:#f7f7f7;--white:#fff;--gold:#f0a500;
  --shadow:0 4px 24px rgba(0,0,0,.10);
  --shadow-lg:0 12px 48px rgba(0,0,0,.18);
  --radius:8px;--radius-sm:4px;
  --trans:.25s cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,sans-serif;font-size:14px;color:var(--dark);background:var(--white);overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;width:100%;height:100%;object-fit:cover}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ===== LAYOUT ===== */
.wrap{max-width:1440px;margin:0 auto;padding:0 28px}

/* ===== TOPBAR ===== */
.topbar{background:var(--black);color:#fff;height:38px;font-size:12px}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:100%}
.tb-left{display:flex;align-items:center;gap:0}
.tb-promo{
  background:var(--red);color:#fff;padding:0 16px;height:38px;
  display:flex;align-items:center;gap:7px;
  font-weight:700;font-size:11px;letter-spacing:.6px;text-transform:uppercase;
  transition:background var(--trans);margin-right:20px;
}
.tb-promo:hover{background:var(--red-d)}
.tb-promo svg{flex-shrink:0}
.tb-left a:not(.tb-promo){color:rgba(255,255,255,.65);transition:color var(--trans);padding:0 12px;height:38px;display:flex;align-items:center}
.tb-left a:not(.tb-promo):hover{color:#fff}
.tb-right{display:flex;align-items:center;gap:0}
.tb-right a{color:rgba(255,255,255,.55);font-size:11px;transition:color var(--trans);padding:0 10px;height:38px;display:flex;align-items:center;gap:5px}
.tb-right a:hover{color:#fff}
.tb-sep{width:1px;height:16px;background:rgba(255,255,255,.12);margin:0 2px}

/* ===== HEADER ===== */
.header{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200;box-shadow:0 2px 16px rgba(0,0,0,.06)}
.header .wrap{display:flex;align-items:center;gap:20px;height:76px}

/* Logo */
.logo{display:flex;align-items:center;gap:11px;flex-shrink:0}
.logo-img{height:50px;width:auto;display:block}
.logo-tag{font-size:9.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--light);margin-top:3px}

/* Search */
.search{flex:1;max-width:560px;display:flex;height:46px;border:2px solid var(--red);border-radius:var(--radius-sm);overflow:hidden;box-shadow:0 0 0 4px rgba(226,0,26,.06)}
.search input{flex:1;border:none;outline:none;padding:0 18px;font-size:14px;color:var(--dark);background:var(--white)}
.search input::placeholder{color:#bbb}
.search-btn,button.search-btn{background:var(--white);border:none;border-left:1.5px solid var(--border);padding:0 20px;display:flex;align-items:center;cursor:pointer;transition:background var(--trans)}
.search-btn:hover,button.search-btn:hover{background:var(--bg)}
.search-btn svg{width:18px;height:18px;stroke:var(--red);fill:none;stroke-width:2.5;stroke-linecap:round}

/* Header actions */
.h-actions{display:flex;align-items:center;margin-left:auto;gap:2px}
.h-action{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 12px;border-radius:var(--radius-sm);gap:3px;transition:background var(--trans);position:relative;color:var(--dark);min-width:58px}
.h-action:hover{background:var(--bg)}
.h-action svg{width:22px;height:22px;stroke:var(--dark);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.h-action span{font-size:10.5px;font-weight:600;color:var(--mid);white-space:nowrap}
.cart-count{position:absolute;top:7px;right:8px;background:var(--red);color:#fff;font-size:9px;font-weight:800;width:17px;height:17px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #fff}

/* ===== NAV ===== */
.mainnav{background:var(--white);border-bottom:1px solid var(--border)}
.mainnav .wrap{display:flex;height:48px;align-items:stretch}
.mainnav ul{display:flex;align-items:stretch;height:100%}
.mainnav li{display:flex;align-items:stretch;position:relative}
.mainnav li a{
  display:flex;align-items:center;padding:0 18px;
  font-size:13px;font-weight:700;color:var(--dark);white-space:nowrap;
  border-bottom:3px solid transparent;margin-bottom:-1px;
  transition:color var(--trans),border-color var(--trans),background var(--trans);
}
.mainnav li a:hover{color:var(--red);background:rgba(226,0,26,.06)}
.mainnav li a.active{color:var(--red);font-weight:800;border-bottom-color:var(--red)}
.mainnav li a.active:hover{color:var(--red-d);border-bottom-color:var(--red-d)}
.mainnav li.new-badge a::after{
  content:'NIEUW';background:var(--gold);color:#fff;
  font-size:8px;font-weight:800;letter-spacing:.8px;
  padding:1px 5px;border-radius:3px;margin-left:6px;
}

/* ===== HERO SLIDER ===== */
.hero{position:relative;overflow:hidden;height:580px;width:100%}
.hero-slides{
  display:flex;height:100%;
  transition:transform .6s cubic-bezier(.77,0,.175,1);
  will-change:transform;
}
.hero-slide{
  min-width:100vw;width:100vw;height:100%;
  position:relative;display:flex;align-items:center;
  flex-shrink:0;overflow:hidden;
}
.hero-slide img.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(10,10,10,.82) 0%,rgba(10,10,10,.45) 55%,rgba(10,10,10,.1) 100%);
}
.hero-content{position:relative;z-index:2;padding:0 28px;max-width:1440px;width:100%;margin:0 auto}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(226,0,26,.15);border:1px solid rgba(226,0,26,.4);
  color:rgba(255,255,255,.9);font-size:11px;font-weight:700;letter-spacing:1.8px;
  text-transform:uppercase;padding:6px 14px;border-radius:20px;margin-bottom:18px;
  backdrop-filter:blur(8px);
}
.hero-eyebrow::before{content:'';width:7px;height:7px;background:var(--red);border-radius:50%;animation:blink 1.4s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero-h1{font-size:58px;font-weight:900;color:#fff;line-height:1.04;letter-spacing:-1.5px;max-width:620px;margin-bottom:16px}
.hero-h1 em{color:var(--red);font-style:normal}
.hero-sub{font-size:17px;color:rgba(255,255,255,.72);max-width:480px;line-height:1.55;margin-bottom:32px}
.hero-btns{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
a.btn-primary,button.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--red);color:#fff;font-size:14px;font-weight:700;
  padding:14px 28px;border-radius:var(--radius-sm);border:none;
  box-shadow:0 6px 24px rgba(226,0,26,.45);
  transition:background var(--trans),transform var(--trans),box-shadow var(--trans);
}
a.btn-primary:hover,button.btn-primary:hover{background:var(--red-d);transform:translateY(-2px);box-shadow:0 10px 32px rgba(226,0,26,.5)}
.btn-outline-white{
  display:inline-flex;align-items:center;gap:10px;
  border:2px solid rgba(255,255,255,.45);color:#fff;font-size:14px;font-weight:700;
  padding:12px 24px;border-radius:var(--radius-sm);backdrop-filter:blur(4px);
  transition:border-color var(--trans),background var(--trans);
}
.btn-outline-white:hover{border-color:#fff;background:rgba(255,255,255,.12)}
/* discount badge */
.hero-badge-float{
  position:absolute;right:8%;top:50%;transform:translateY(-50%);
  width:138px;height:138px;border-radius:50%;
  background:var(--red);display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:#fff;box-shadow:0 0 0 8px rgba(226,0,26,.2),0 12px 40px rgba(226,0,26,.5);
  animation:floatBadge 3s ease-in-out infinite;z-index:3;
}
@keyframes floatBadge{0%,100%{transform:translateY(-50%) scale(1)}50%{transform:translateY(-54%) scale(1.04)}}
.hero-badge-float .b-pre{font-size:12px;font-weight:700;letter-spacing:1px;opacity:.85}
.hero-badge-float .b-pct{font-size:44px;font-weight:900;line-height:1;letter-spacing:-2px}
.hero-badge-float .b-off{font-size:13px;font-weight:800;letter-spacing:2px}
/* slider controls */
.hero-prev,.hero-next{
  position:absolute;top:50%;transform:translateY(-50%);z-index:10;
  width:50px;height:50px;border-radius:50%;
  background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.3);
  backdrop-filter:blur(8px);color:#fff;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--trans),border-color var(--trans);cursor:pointer;
}
.hero-prev:hover,.hero-next:hover{background:var(--red);border-color:var(--red)}
.hero-prev{left:24px}
.hero-next{right:24px}
.hero-prev svg,.hero-next svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round}
.hero-dots{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:10}
.hero-dot{width:8px;height:8px;border-radius:4px;background:rgba(255,255,255,.35);cursor:pointer;transition:all .3s}
.hero-dot.on{background:#fff;width:28px}

/* ===== USP BAR ===== */
.usp{background:var(--white);border-bottom:1px solid var(--border);padding:0}
.usp-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.usp-item{
  display:flex;align-items:center;gap:14px;padding:18px 24px;
  border-right:1px solid var(--border);transition:background var(--trans);cursor:default;
}
.usp-item:last-child{border-right:none}
.usp-item:hover{background:var(--bg)}
.usp-ico{
  width:44px;height:44px;border-radius:50%;background:rgba(226,0,26,.08);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background var(--trans);
}
.usp-item:hover .usp-ico{background:var(--red)}
.usp-ico svg{width:20px;height:20px;stroke:var(--red);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke var(--trans)}
.usp-item:hover .usp-ico svg{stroke:#fff}
.usp-t1{font-size:13px;font-weight:700;color:var(--dark)}
.usp-t2{font-size:11px;color:var(--light);margin-top:1px}

/* ===== SECTIONS ===== */
.sec{padding:56px 0}
.sec-alt{background:var(--bg)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:10px}
.sec-title{font-size:28px;font-weight:900;color:var(--black);letter-spacing:-.6px}
.sec-title::after{content:'';display:block;width:36px;height:3px;background:var(--red);margin-top:8px;border-radius:2px}
.sec-all{font-size:13px;font-weight:700;color:var(--red);display:flex;align-items:center;gap:5px;transition:gap var(--trans)}
.sec-all:hover{gap:8px}

/* ===== PROMO 2-UP ===== */
.promo2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pcard{
  position:relative;border-radius:var(--radius);overflow:hidden;
  min-height:280px;display:flex;align-items:flex-end;cursor:pointer;
}
.pcard img.pcard-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.pcard:hover img.pcard-bg{transform:scale(1.06)}
.pcard-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.78) 0%,rgba(0,0,0,.2) 60%,transparent 100%)}
.pcard-body{position:relative;z-index:2;padding:28px;color:#fff}
.pcard-tag{font-size:10px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:7px}
.pcard-title{font-size:28px;font-weight:900;line-height:1.1;margin-bottom:7px}
.pcard-title span{color:var(--gold)}
.pcard-sub{font-size:12px;opacity:.75;margin-bottom:18px;line-height:1.4}
.btn-pcard{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;color:var(--dark);font-size:12px;font-weight:700;
  padding:10px 20px;border-radius:var(--radius-sm);transition:background var(--trans),transform var(--trans);
}
.btn-pcard:hover{background:var(--red);color:#fff;transform:translateX(4px)}
.btn-pcard-ghost{background:transparent;border:2px solid rgba(255,255,255,.45);color:#fff}
.btn-pcard-ghost:hover{background:var(--red);border-color:var(--red)}

/* ===== PRODUCT GRID (homepage demo + WooCommerce shop) ===== */
.pgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.pc{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;transition:box-shadow var(--trans),transform var(--trans);
  position:relative;display:flex;flex-direction:column;
}
.pc:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}
.pc-badges{position:absolute;top:10px;left:10px;display:flex;flex-direction:column;gap:4px;z-index:3}
.pc-badge{display:inline-block;background:var(--red);color:#fff;font-size:9.5px;font-weight:800;padding:3px 8px;border-radius:3px;letter-spacing:.3px}
.pc-badge.gold{background:var(--gold)}
.pc-badge.dark{background:var(--dark)}
.pc-wish{
  position:absolute;top:10px;right:10px;z-index:3;
  width:32px;height:32px;border-radius:50%;background:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.12);transition:background var(--trans);
}
.pc-wish:hover{background:var(--red)}
.pc-wish svg{width:14px;height:14px;stroke:var(--mid);fill:none;stroke-width:2;stroke-linecap:round;transition:stroke var(--trans)}
.pc-wish:hover svg{stroke:#fff;fill:#fff}
.pc-img,a.pc-img-link{display:block}
.pc-img{
  aspect-ratio:1/1;overflow:hidden;background:#f0ece7;position:relative;
}
.pc-img img,.pc-img a{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.pc-img img{display:block}
.pc:hover .pc-img img{transform:scale(1.07)}
.pc-info{padding:14px;flex:1;display:flex;flex-direction:column}
.pc-brand{font-size:9.5px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--light);margin-bottom:4px}
.pc-name,h2.pc-name,.woocommerce-loop-product__title{font-size:12.5px;font-weight:600;color:var(--dark);line-height:1.35;margin-bottom:auto;padding-bottom:10px}
a.pc-name-link{color:inherit}
.pc-prices{display:flex;align-items:baseline;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.pc-old{font-size:11.5px;color:var(--light);text-decoration:line-through}
.pc-new{font-size:18px;font-weight:900;color:var(--red)}
.pc-new.plain{color:var(--dark)}
/* WooCommerce native price markup binnen .pc-prices */
.pc-prices .price{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.pc-prices .amount{font-size:18px;font-weight:900;color:var(--dark)}
.pc-prices del{text-decoration:line-through}
.pc-prices del .amount{font-size:11.5px;color:var(--light);font-weight:400}
.pc-prices ins{text-decoration:none}
.pc-prices ins .amount{color:var(--red);font-weight:900;font-size:18px}
.btn-cart{
  width:100%;background:var(--red);color:#fff;
  padding:10px 0;border-radius:var(--radius-sm);
  font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:6px;
  transition:background var(--trans);
}
.btn-cart:hover{background:var(--red-d);color:#fff}
.btn-cart svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round}
.btn-cart.loading{opacity:.6;pointer-events:none}
.btn-cart.added::before{content:'✓ ';}

/* ===== CATEGORIES GRID ===== */
.catgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.catcard{
  position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/2;cursor:pointer;
}
.catcard img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.catcard:hover img{transform:scale(1.08)}
.catcard-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.1) 60%,transparent 100%);
  transition:background var(--trans);
}
.catcard:hover .catcard-overlay{background:linear-gradient(to top,rgba(226,0,26,.75) 0%,rgba(0,0,0,.2) 70%,transparent 100%)}
.catcard-label{
  position:absolute;bottom:0;left:0;right:0;padding:14px 12px;
  color:#fff;font-size:13px;font-weight:700;line-height:1.2;
}
.catcard-arrow{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;background:var(--red);
  position:absolute;bottom:12px;right:12px;
  opacity:0;transform:scale(.7);transition:opacity var(--trans),transform var(--trans);
}
.catcard:hover .catcard-arrow{opacity:1;transform:scale(1)}
.catcard-arrow svg{width:11px;height:11px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round}

/* ===== 4-UP BANNERS ===== */
.b4grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.b4card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  min-height:210px;display:flex;align-items:flex-end;cursor:pointer;
}
.b4card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.b4card:hover img{transform:scale(1.07)}
.b4card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.3) 60%,transparent 100%)}
.b4card-body{position:relative;z-index:2;padding:20px;color:#fff}
.b4card-kicker{font-size:9.5px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:6px}
.b4card-title{font-size:17px;font-weight:900;line-height:1.2;margin-bottom:5px}
.b4card-title span{color:var(--gold)}
.b4card-sub{font-size:11px;opacity:.65;margin-bottom:14px}
.btn-xs{display:inline-flex;align-items:center;gap:5px;background:var(--red);color:#fff;font-size:11px;font-weight:700;padding:7px 14px;border-radius:3px;transition:background var(--trans)}
.btn-xs:hover{background:var(--red-d)}
.btn-xs-ghost{background:transparent;border:1.5px solid rgba(255,255,255,.4)}
.btn-xs-ghost:hover{background:var(--red);border-color:var(--red)}

/* ===== DEALS SECTION ===== */
.deals-sec{border-top:3px solid var(--red)}
.deals-head{display:flex;align-items:center;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.deals-title{font-size:28px;font-weight:900;color:var(--black);letter-spacing:-.5px}
.timer{display:flex;align-items:center;gap:6px}
.t-block{background:var(--red);color:#fff;border-radius:5px;padding:5px 8px;text-align:center;min-width:46px}
.t-num{display:block;font-size:20px;font-weight:900;line-height:1;letter-spacing:-1px}
.t-lab{display:block;font-size:8px;font-weight:700;letter-spacing:1px;opacity:.8;margin-top:1px}
.t-sep{font-size:22px;font-weight:900;color:var(--red);line-height:1}

/* ===== INSPIRATION ===== */
.inspgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.inspcard{cursor:pointer}
.inspcard-img{
  border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;position:relative;
}
.inspcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .55s}
.inspcard:hover .inspcard-img img{transform:scale(1.07)}
.inspcard-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 55%);opacity:0;transition:opacity var(--trans)}
.inspcard:hover .inspcard-overlay{opacity:1}
.inspcard-zoom{
  position:absolute;bottom:12px;right:12px;background:var(--red);color:#fff;
  font-size:10px;font-weight:700;padding:5px 10px;border-radius:3px;
  opacity:0;transform:translateY(6px);transition:opacity var(--trans),transform var(--trans);
}
.inspcard:hover .inspcard-zoom{opacity:1;transform:translateY(0)}
.inspcard-info{padding:12px 2px 0}
.inspcard-tag{font-size:10px;font-weight:800;color:var(--red);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:5px}
.inspcard-title{font-size:14px;font-weight:700;color:var(--dark);line-height:1.3;margin-bottom:3px}
.inspcard-meta{font-size:11px;color:var(--light)}

/* ===== WORLD TILES ===== */
.worldgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.worldcard{
  position:relative;border-radius:var(--radius);overflow:hidden;
  min-height:230px;display:flex;align-items:flex-end;cursor:pointer;
}
.worldcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s}
.worldcard:hover img{transform:scale(1.05)}
.worldcard-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.15) 60%,transparent 100%)}
.worldcard-body{position:relative;z-index:2;padding:24px;color:#fff}
.worldcard-title{font-size:20px;font-weight:900;margin-bottom:6px}
.worldcard-sub{font-size:12px;opacity:.7;margin-bottom:14px;line-height:1.4}
.btn-world{display:inline-flex;align-items:center;gap:7px;background:#fff;color:var(--dark);font-size:12px;font-weight:700;padding:9px 18px;border-radius:var(--radius-sm);transition:background var(--trans),color var(--trans)}
.btn-world:hover{background:var(--red);color:#fff}

/* ===== NEWSLETTER ===== */
.newsletter{background:var(--dark);position:relative;overflow:hidden;padding:64px 0}
.newsletter::before{
  content:'';position:absolute;top:-120px;right:-120px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(226,0,26,.18) 0%,transparent 70%);
  pointer-events:none;
}
.nl-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.nl-left{color:#fff}
.nl-kicker{font-size:10px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.nl-title{font-size:36px;font-weight:900;line-height:1.08;letter-spacing:-.8px;margin-bottom:14px}
.nl-title span{color:var(--red)}
.nl-sub{font-size:14px;opacity:.65;line-height:1.55;margin-bottom:24px}
.nl-perks{display:flex;flex-direction:column;gap:9px}
.nl-perk{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:rgba(255,255,255,.78)}
.nl-check{
  width:20px;height:20px;border-radius:50%;background:var(--red);flex-shrink:0;margin-top:1px;
  display:flex;align-items:center;justify-content:center;
}
.nl-check svg{width:10px;height:10px;stroke:#fff;fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.nl-form-wrap{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:36px}
.nl-form-title{font-size:20px;font-weight:800;color:#fff;margin-bottom:18px}
.nl-row{display:flex;gap:0;margin-bottom:12px}
.nl-input{
  flex:1;height:50px;background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.12);
  border-right:none;border-radius:var(--radius-sm) 0 0 var(--radius-sm);
  color:#fff;font-size:14px;padding:0 18px;outline:none;
  transition:border-color var(--trans);
}
.nl-input::placeholder{color:rgba(255,255,255,.3)}
.nl-input:focus{border-color:rgba(226,0,26,.6)}
.nl-btn{
  height:50px;background:var(--red);color:#fff;border:none;
  padding:0 24px;font-size:14px;font-weight:700;white-space:nowrap;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  cursor:pointer;transition:background var(--trans);
}
.nl-btn:hover{background:var(--red-d)}
.nl-legal{font-size:11px;color:rgba(255,255,255,.3);line-height:1.5}
.nl-legal a{color:rgba(255,255,255,.45);text-decoration:underline}

/* ===== TRUST BAR ===== */
.trustbar{background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:22px 0}
.trust-inner{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--mid);font-weight:600}
.trust-item svg{width:18px;height:18px;stroke:var(--gold);fill:var(--gold);flex-shrink:0}
.trust-sep{width:1px;height:28px;background:var(--border)}

/* ===== FOOTER ===== */
.footer{background:#111;color:rgba(255,255,255,.65)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:40px;padding:56px 0 48px}
.ft-logo-link{display:inline-flex}
.ft-logo-img{height:42px;width:auto;display:block;margin-bottom:2px}
.ft-brand .logo-tag{color:rgba(255,255,255,.35)}
.ft-brand p{font-size:12.5px;color:rgba(255,255,255,.4);line-height:1.6;margin:16px 0 20px;max-width:260px}
.ft-social{display:flex;gap:8px}
.ft-soc{
  width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.07);
  display:flex;align-items:center;justify-content:center;transition:background var(--trans);cursor:pointer;
}
.ft-soc:hover{background:var(--red)}
.ft-soc svg{width:15px;height:15px;fill:rgba(255,255,255,.6);transition:fill var(--trans)}
.ft-soc:hover svg{fill:#fff}
.ft-col-title{font-size:11px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#fff;margin-bottom:16px}
.ft-col ul{display:flex;flex-direction:column;gap:9px}
.ft-col ul li a{font-size:12.5px;color:rgba(255,255,255,.45);transition:color var(--trans)}
.ft-col ul li a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:20px 0}
.footer-bottom .wrap{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.ft-copy{font-size:11.5px;color:rgba(255,255,255,.25)}
.ft-copy a{color:rgba(255,255,255,.35);transition:color var(--trans)}
.ft-copy a:hover{color:#fff}
.ft-payment{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-start}
.pay-badge{height:30px;border-radius:5px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 1px 5px rgba(0,0,0,.5)}
.pay-badge svg{display:block;flex-shrink:0}

/* ===== MINI SCROLLBAR ===== */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:#f1f1f1}
::-webkit-scrollbar-thumb{background:var(--red);border-radius:3px}

/* ===== BOTTOM NAVIGATION BAR (mobile only) ===== */
.bottom-nav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:300;
  background:var(--white);
  border-top:1px solid var(--border);
  box-shadow:0 -4px 20px rgba(0,0,0,.10);
  padding-bottom:env(safe-area-inset-bottom,0px);
}
.bottom-nav-inner{display:flex;align-items:stretch;height:58px}
.bn-item{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:3px;
  border:none;background:none;cursor:pointer;
  color:var(--light);font-size:9.5px;font-weight:600;
  letter-spacing:.3px;text-transform:uppercase;
  transition:color var(--trans),background var(--trans);
  position:relative;padding:0 2px;text-decoration:none;
  -webkit-tap-highlight-color:transparent;
}
.bn-item:active{background:rgba(226,0,26,.05)}
.bn-item.active{color:var(--red)}
.bn-item svg{
  width:22px;height:22px;stroke:currentColor;fill:none;
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;
  transition:stroke var(--trans);
}
.bn-item.active svg{stroke:var(--red)}
.bn-item.active::after{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:28px;height:3px;background:var(--red);border-radius:0 0 3px 3px;
}
.bn-item.bn-cart{color:var(--dark)}
.bn-item.bn-cart svg{stroke:var(--dark)}
.bn-cart-wrap{position:relative}
.bn-cart-badge{
  position:absolute;top:-4px;right:-8px;
  background:var(--red);color:#fff;
  font-size:9px;font-weight:800;
  min-width:16px;height:16px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  padding:0 3px;border:2px solid var(--white);
  line-height:1;
}
@media(max-width:900px){
  body{padding-bottom:calc(58px + env(safe-area-inset-bottom,0px))}
  .bottom-nav{display:flex;flex-direction:column}
}

/* ===== MOLLIE BETAALSTRIP ===== */
.mollie-strip{background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:16px 0}
.mollie-strip-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.mollie-strip-left{display:flex;align-items:center;gap:16px}
.mollie-logo-big{display:flex;align-items:center;background:#f5f5f5;padding:8px 14px;border-radius:8px;border:1px solid #e5e5e5}
.mollie-strip-txt{display:flex;flex-direction:column;gap:2px}
.mollie-strip-txt strong{font-size:13.5px;font-weight:800;color:var(--dark)}
.mollie-strip-txt span{font-size:11.5px;color:var(--light)}
.mollie-strip-methods{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.ms-method{display:flex;align-items:center;cursor:default;transition:transform .15s}
.ms-method:hover{transform:translateY(-2px)}
.ms-more{font-size:11px;font-weight:700;color:var(--light);background:#f5f5f5;padding:3px 8px;border-radius:4px;border:1px solid var(--border);white-space:nowrap}

/* ===== LEVERING STRIP ===== */
.delivery-strip{background:linear-gradient(135deg,#fff8f5 0%,#fff 100%);border-bottom:1px solid var(--border);padding:18px 0}
.delivery-strip-inner{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.delivery-title{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--dark);white-space:nowrap;flex-shrink:0}
.delivery-options{display:flex;align-items:center;gap:12px;flex-wrap:wrap;flex:1}
.del-opt{display:flex;flex-direction:column;align-items:center;background:#fff;border:2px solid var(--border);border-radius:10px;padding:10px 18px;gap:2px;transition:border-color var(--trans),box-shadow var(--trans)}
.del-opt:hover{border-color:var(--red);box-shadow:0 2px 12px rgba(226,0,26,.12)}
.del-opt-badge{font-size:14px;font-weight:800;color:var(--dark)}
.del-fast .del-opt-badge{color:var(--red)}
.del-std .del-opt-badge{color:#1a7a3c}
.del-opt-label{font-size:11.5px;font-weight:700;color:var(--dark)}
.del-opt-sub{font-size:10.5px;color:var(--light)}
.del-opt-sep{font-size:13px;font-weight:700;color:var(--light);padding:0 4px}
.del-opt-info{font-size:11px;color:var(--light);max-width:220px;line-height:1.4;border-left:2px solid var(--border);padding-left:12px}

/* ===== PRODUCT CARD DELIVERY ===== */
.pc-delivery{font-size:10.5px;color:var(--light);display:flex;align-items:center;gap:4px;margin-bottom:6px;padding:4px 6px;background:#f9f9f9;border-radius:4px;flex-wrap:wrap}
.pc-delivery svg{flex-shrink:0}
.pc-delivery-generic{justify-content:center}
.pc-mollie{color:#555}
.pc-mollie strong{font-weight:900;color:#FF6600;letter-spacing:-.3px}

@media(max-width:900px){
  .mollie-strip-inner{gap:14px}
  .mollie-strip-methods{gap:4px}
  .delivery-strip-inner{gap:12px}
  .delivery-options{gap:8px}
  .del-opt{padding:8px 12px}
  .del-opt-info{border-left:none;padding-left:0;border-top:1px solid var(--border);padding-top:8px;width:100%}
}
@media(max-width:640px){
  .mollie-strip-left{flex-wrap:wrap;gap:10px}
  .delivery-title{white-space:normal}
}

/* ===== MOBILE SEARCH OVERLAY ===== */
.mob-search-btn{
  display:none;width:40px;height:40px;border-radius:6px;background:none;border:none;
  cursor:pointer;align-items:center;justify-content:center;flex-shrink:0;
}
.mob-search-btn svg{width:20px;height:20px;stroke:var(--dark);fill:none;stroke-width:2;stroke-linecap:round}
.mob-search-btn:hover{background:var(--bg)}

.search-overlay{
  display:none;position:fixed;top:0;left:0;right:0;z-index:500;
  background:var(--white);padding:14px 16px;
  box-shadow:0 4px 20px rgba(0,0,0,.15);
  transform:translateY(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);
}
.search-overlay.open{transform:translateY(0)}
.search-overlay-inner{display:flex;gap:10px;align-items:center}
.search-overlay input{
  flex:1;height:46px;border:2px solid var(--red);border-radius:var(--radius-sm);
  padding:0 16px;font-size:15px;outline:none;color:var(--dark);
}
.search-overlay input::placeholder{color:#bbb}
.search-overlay-close{
  width:42px;height:42px;border-radius:50%;background:var(--bg);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.search-overlay-close svg{width:18px;height:18px;stroke:var(--dark);fill:none;stroke-width:2;stroke-linecap:round}
.search-overlay-btn,button.search-overlay-btn{
  height:46px;background:var(--red);border:none;border-radius:var(--radius-sm);
  padding:0 18px;cursor:pointer;display:flex;align-items:center;
}
.search-overlay-btn svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round}

/* ===== HAMBURGER BUTTON ===== */
.mob-menu-btn{
  display:none;width:44px;height:44px;border-radius:6px;
  background:none;border:none;cursor:pointer;
  flex-direction:column;align-items:center;justify-content:center;gap:5px;
  margin-left:auto;flex-shrink:0;
}
.mob-menu-btn span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:all .3s}
.mob-menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mob-menu-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.mob-menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav drawer */
.mob-nav{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;
  background:var(--white);z-index:1000;overflow-y:auto;
  transform:translateX(-100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.mob-nav.open{transform:translateX(0)}
.mob-nav-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--border);
  background:var(--white);position:sticky;top:0;z-index:2;
}
.mob-nav-logo-img{height:28px;width:auto;display:block}
.mob-nav-close{
  width:40px;height:40px;border-radius:50%;background:var(--bg);
  border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.mob-nav-close svg{width:18px;height:18px;stroke:var(--dark);fill:none;stroke-width:2;stroke-linecap:round}
.mob-nav-body{padding:8px 0}
.mob-nav-body a{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;font-size:15px;font-weight:600;color:var(--dark);
  border-bottom:1px solid var(--border);transition:background .15s;
}
.mob-nav-body a:hover{background:var(--bg);color:var(--red)}
.mob-nav-body a.active{color:var(--red);font-weight:800;border-left:3px solid var(--red);padding-left:17px;background:rgba(226,0,26,.05)}
.mob-nav-body a svg{width:14px;height:14px;stroke:var(--light);fill:none;stroke-width:2;stroke-linecap:round}
.mob-nav-body .mob-sep{height:8px;background:var(--bg);border-bottom:1px solid var(--border)}

/* Overlay backdrop */
.mob-overlay{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999;
  opacity:0;transition:opacity .3s;
}
.mob-overlay.open{opacity:1}

/* ===== RESPONSIVE — 1200px ===== */
@media(max-width:1200px){
  .pgrid,.catgrid{grid-template-columns:repeat(4,1fr)}
  .footer-top{grid-template-columns:1fr 1fr 1fr;gap:28px}
  .b4grid{grid-template-columns:repeat(2,1fr)}
}

/* ===== RESPONSIVE — 1024px ===== */
@media(max-width:1024px){
  .hero-h1{font-size:46px}
  .mainnav li a{padding:0 11px;font-size:12.5px}
}

/* ===== RESPONSIVE — 900px ===== */
@media(max-width:900px){
  .wrap{padding:0 16px}
  .topbar{display:none}
  .header .wrap{gap:8px;height:60px}
  .logo-img{height:40px}
  .h-action span{display:none}
  .h-action{min-width:44px;padding:10px 8px}
  .search{display:none}
  .mob-search-btn{display:flex}
  .mainnav{display:none}
  .mob-menu-btn{display:flex}
  .mob-nav{display:block}
  .mob-overlay{display:block}
  .hero{height:480px}
  .hero-h1{font-size:38px;letter-spacing:-1px}
  .hero-sub{font-size:14px}
  .hero-badge-float{width:100px;height:100px;right:4%}
  .hero-badge-float .b-pct{font-size:32px}
  .usp-grid{grid-template-columns:repeat(2,1fr)}
  .usp-item{padding:14px 16px}
  .sec{padding:36px 0}
  .sec-title{font-size:22px}
  .pgrid{grid-template-columns:repeat(3,1fr)}
  .catgrid{grid-template-columns:repeat(3,1fr)}
  .b4grid{grid-template-columns:repeat(2,1fr)}
  .inspgrid{grid-template-columns:repeat(2,1fr)}
  .promo2{grid-template-columns:1fr}
  .pcard{min-height:220px}
  .worldgrid{grid-template-columns:repeat(2,1fr)}
  .nl-grid{grid-template-columns:1fr;gap:32px}
  .nl-title{font-size:28px}
  .newsletter{padding:44px 0}
  .footer-top{grid-template-columns:1fr 1fr;gap:24px;padding:36px 0 28px}
  .deals-head{flex-wrap:wrap;gap:10px}
  .deals-title{font-size:22px}
  .mollie-strip-inner{flex-direction:column;align-items:flex-start;gap:12px}
  .mollie-strip-methods{gap:5px}
  .delivery-strip-inner{flex-direction:column;align-items:flex-start;gap:10px}
  .delivery-options{gap:8px}
  .pc-delivery{font-size:10px;gap:3px}
  .footer-bottom .wrap{flex-direction:column;align-items:flex-start;gap:14px}
  .ft-payment{width:100%;gap:5px}
  .contact-grid{grid-template-columns:1fr;gap:28px}
  .shop-toolbar{flex-direction:column;align-items:flex-start}
}

/* ===== RESPONSIVE — 640px ===== */
@media(max-width:640px){
  .topbar{height:auto;padding:8px 16px}
  .topbar .wrap{flex-direction:column;gap:6px;align-items:flex-start}
  .tb-right{display:none}
  .tb-left{flex-wrap:wrap;gap:4px}
  .tb-left a:not(.tb-promo){padding:0 8px;font-size:11px}
  .header .wrap{height:56px;gap:6px}
  .logo-img{height:34px}
  .h-action{padding:8px 5px;min-width:36px}
  .h-action svg{width:19px;height:19px}
  .cart-count{width:15px;height:15px;font-size:8px;top:5px;right:3px}
  .hero{height:380px}
  .hero-eyebrow{font-size:10px;padding:5px 11px;margin-bottom:12px}
  .hero-h1{font-size:30px;letter-spacing:-.8px;margin-bottom:10px}
  .hero-sub{font-size:13px;margin-bottom:22px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .hero-badge-float{display:none}
  .hero-prev,.hero-next{width:38px;height:38px}
  .hero-prev svg,.hero-next svg{width:16px;height:16px}
  .btn-primary{padding:12px 20px;font-size:13px}
  .btn-outline-white{padding:10px 16px;font-size:13px}
  .hero-btns{gap:10px}
  .usp-grid{grid-template-columns:1fr 1fr}
  .usp-item{padding:12px 10px;gap:10px}
  .usp-ico{width:36px;height:36px}
  .usp-ico svg{width:17px;height:17px}
  .usp-t1{font-size:12px}
  .usp-t2{font-size:10px}
  .sec-head{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:18px}
  .sec-title{font-size:20px}
  .pgrid{grid-template-columns:repeat(2,1fr);gap:10px}
  .pc-name{font-size:11.5px}
  .pc-new{font-size:16px}
  .btn-cart{padding:9px 0;font-size:11px}
  .catgrid{grid-template-columns:repeat(2,1fr);gap:8px}
  .catcard{aspect-ratio:4/3}
  .catcard-label{font-size:12px;padding:10px}
  .b4grid{grid-template-columns:1fr 1fr;gap:10px}
  .b4card{min-height:160px}
  .b4card-title{font-size:14px}
  .b4card-body{padding:14px}
  .inspgrid{grid-template-columns:repeat(2,1fr);gap:10px}
  .inspcard-title{font-size:13px}
  .worldgrid{grid-template-columns:1fr}
  .worldcard{min-height:180px}
  .pcard-title{font-size:22px}
  .pcard-body{padding:20px}
  .deals-head{gap:8px}
  .deals-title{font-size:20px}
  .timer{flex-wrap:nowrap}
  .t-num{font-size:17px}
  .t-block{min-width:38px}
  .nl-title{font-size:24px}
  .nl-form-wrap{padding:24px 20px}
  .nl-row{flex-direction:column;gap:8px}
  .nl-input{border-right:1.5px solid rgba(255,255,255,.12);border-radius:var(--radius-sm)}
  .nl-btn{border-radius:var(--radius-sm);height:46px}
  .footer-top{grid-template-columns:1fr;gap:20px;padding:28px 0 20px}
  .ft-brand{border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:20px}
  .ft-col{border-bottom:1px solid rgba(255,255,255,.06);padding-bottom:16px}
  .footer-bottom .wrap{flex-direction:column;align-items:flex-start;gap:12px}
  .ft-payment{gap:5px;flex-wrap:wrap;width:100%}
  .pay-badge{height:24px;flex-shrink:0}
  .pay-badge svg{pointer-events:none}
  .mollie-strip{padding:12px 0}
  .mollie-strip-left{gap:10px}
  .mollie-logo-big{padding:6px 10px}
  .mollie-strip-txt strong{font-size:12.5px}
  .mollie-strip-txt span{font-size:10.5px}
  .ms-method svg{transform:scale(.85);transform-origin:left center}
  .ms-more{font-size:10px;padding:2px 6px}
  .delivery-strip{padding:12px 0}
  .delivery-strip-inner{gap:8px}
  .delivery-title{font-size:12.5px}
  .del-opt{padding:7px 12px}
  .del-opt-badge{font-size:12.5px}
  .del-opt-label{font-size:10.5px}
  .del-opt-sub{font-size:9.5px}
  .del-opt-info{font-size:10px;max-width:100%}
  .trust-inner{gap:14px;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}
  .trust-sep{display:none}
  .trust-item{white-space:nowrap;font-size:11px}
  .contact-form-wrap{padding:24px 20px}
}

/* ===== RESPONSIVE — 400px ===== */
@media(max-width:400px){
  .hero{height:340px}
  .hero-h1{font-size:26px}
  .logo-img{height:30px}
  .pgrid{grid-template-columns:repeat(2,1fr);gap:8px}
  .catgrid{grid-template-columns:repeat(2,1fr)}
  .b4grid{grid-template-columns:1fr}
  .inspgrid{grid-template-columns:1fr}
  .usp-grid{grid-template-columns:1fr}
  .usp-item{border-right:none;border-bottom:1px solid var(--border)}
  .usp-item:last-child{border-bottom:none}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .btn-primary,.btn-outline-white{width:100%;justify-content:center}
  .mollie-strip-methods{display:grid;grid-template-columns:repeat(4,auto);gap:4px;justify-content:start}
  .mollie-strip-left{flex-direction:column;align-items:flex-start;gap:8px}
  .delivery-options{flex-direction:column;align-items:flex-start;gap:6px}
  .del-opt{width:100%;flex-direction:row;justify-content:flex-start;gap:10px}
  .del-opt-sep{display:none}
  .del-opt-badge{min-width:70px}
  .pay-badge{height:22px}
  .pc-delivery{font-size:9.5px}
  .bottom-nav-inner{height:54px}
  .bn-item{font-size:8.5px}
  .bn-item svg{width:20px;height:20px}
}

/* ===== TOUCH IMPROVEMENTS ===== */
@media(hover:none){
  .pc:hover{box-shadow:none;transform:none}
  .catcard:hover img{transform:none}
  .pcard:hover img.pcard-bg{transform:none}
  .hero-badge-float{animation:none}
}

/* ===== SAFE AREA (iPhone notch) ===== */
@supports(padding:max(0px)){
  .topbar{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right))}
  .footer-bottom .wrap{padding-bottom:max(16px,env(safe-area-inset-bottom))}
}

/* =================================================================
   PAGE HERO — gedeelde donkere banner (zelfde visuele taal als de
   homepage-hero) voor Shop en Contact: achtergrondfoto + donkere
   gradient-overlay + eyebrow-badge + groot wit kopje.
   ================================================================= */
.page-hero{position:relative;overflow:hidden;min-height:320px;display:flex;align-items:center}
.page-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(13,13,13,.94) 0%,rgba(13,13,13,.8) 45%,rgba(13,13,13,.5) 100%)}
.page-hero-content{position:relative;z-index:2;padding:52px 0;width:100%}
.page-hero .hero-h1{font-size:44px;margin-bottom:12px}
.page-hero .hero-sub{margin-bottom:0;max-width:560px}
.page-hero .woocommerce-breadcrumb{color:rgba(255,255,255,.55)}
.page-hero .woocommerce-breadcrumb a{color:rgba(255,255,255,.85)}
.page-hero .woocommerce-breadcrumb a:hover{color:#fff}
@media(max-width:900px){.page-hero{min-height:260px}.page-hero .hero-h1{font-size:32px}}
@media(max-width:640px){.page-hero{min-height:220px}.page-hero-content{padding:36px 0}.page-hero .hero-h1{font-size:25px}}

/* =================================================================
   SHOP — WooCommerce archive (archive-product.php / content-product.php)
   ================================================================= */
.woocommerce-breadcrumb{font-size:12px;color:var(--light);margin-bottom:14px}
.woocommerce-breadcrumb a{color:var(--mid);transition:color var(--trans)}
.woocommerce-breadcrumb a:hover{color:var(--red)}

.shop-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.woocommerce-result-count{font-size:12.5px;color:var(--mid)}
.woocommerce-ordering{margin-left:auto}
.woocommerce-ordering select{
  border:1.5px solid var(--border);border-radius:var(--radius-sm);
  padding:9px 14px;font-size:12.5px;color:var(--dark);background:#fff;
  outline:none;cursor:pointer;transition:border-color var(--trans);
}
.woocommerce-ordering select:focus{border-color:var(--red)}

/* WooCommerce's native <ul class="products"> herstijld als onze .pgrid */
ul.products{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;list-style:none;margin:0 0 32px;padding:0}
ul.products li.product{list-style:none}
@media(max-width:1200px){ul.products{grid-template-columns:repeat(4,1fr)}}
@media(max-width:900px){ul.products{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){ul.products{grid-template-columns:repeat(2,1fr);gap:10px}}
@media(max-width:400px){ul.products{grid-template-columns:repeat(2,1fr);gap:8px}}

/* Pagination */
.woocommerce-pagination{display:flex;justify-content:center;margin-top:8px}
.woocommerce-pagination ul{display:flex;gap:6px;list-style:none}
.woocommerce-pagination .page-numbers{
  display:flex;align-items:center;justify-content:center;
  min-width:38px;height:38px;padding:0 6px;border-radius:var(--radius-sm);
  border:1.5px solid var(--border);color:var(--dark);font-size:13px;font-weight:600;
  transition:border-color var(--trans),background var(--trans),color var(--trans);
}
.woocommerce-pagination .page-numbers:hover{border-color:var(--red);color:var(--red)}
.woocommerce-pagination .page-numbers.current{background:var(--red);border-color:var(--red);color:#fff}

/* Lege shop / nog geen producten */
.shop-empty{
  text-align:center;padding:64px 24px;background:var(--bg);border-radius:var(--radius);
  border:1px dashed var(--border);
}
.shop-empty-icon{
  width:64px;height:64px;border-radius:50%;background:rgba(226,0,26,.08);
  display:flex;align-items:center;justify-content:center;margin:0 auto 18px;
}
.shop-empty-icon svg{width:28px;height:28px;stroke:var(--red);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.shop-empty h2{font-size:20px;font-weight:800;color:var(--black);margin-bottom:8px}
.shop-empty p{font-size:13.5px;color:var(--mid);max-width:420px;margin:0 auto 20px;line-height:1.6}

/* =================================================================
   CONTACT — page-contact.php
   ================================================================= */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:32px;align-items:start}

.form-eyebrow{
  display:inline-flex;align-items:center;gap:7px;
  font-size:11px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;
  color:var(--red);margin-bottom:10px;
}
.form-eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--red);flex-shrink:0}

.contact-cards-title{font-size:20px;font-weight:800;color:var(--black);margin-bottom:18px;letter-spacing:-.3px}

.contact-cards{display:flex;flex-direction:column;gap:14px}
.contact-card{
  display:flex;gap:16px;align-items:flex-start;background:var(--white);
  border:1px solid var(--border);border-radius:16px;padding:20px;
  box-shadow:0 2px 12px rgba(20,20,20,.04);
  transition:transform var(--trans),box-shadow var(--trans),border-color var(--trans);
}
.contact-card:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 36px rgba(20,20,20,.09);
  border-color:rgba(226,0,26,.2);
}
.contact-card-ico{
  width:46px;height:46px;border-radius:13px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(226,0,26,.12),rgba(226,0,26,.04));
  display:flex;align-items:center;justify-content:center;
}
.contact-card-ico svg{width:20px;height:20px;stroke:var(--red);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.contact-card h3{font-size:14px;font-weight:800;color:var(--black);margin-bottom:5px;letter-spacing:-.1px}
.contact-card p,.contact-card a{display:block;font-size:13px;color:var(--mid);line-height:1.6}
.contact-card a{font-weight:700;color:var(--dark);transition:color var(--trans)}
.contact-card a:hover{color:var(--red)}

.contact-map{
  border-radius:16px;overflow:hidden;border:1px solid var(--border);
  aspect-ratio:16/10;background:var(--bg);
  box-shadow:0 2px 12px rgba(20,20,20,.04);
}
.contact-map iframe{width:100%;height:100%;border:0;display:block}

.contact-form-wrap{
  position:relative;background:var(--white);border:1px solid var(--border);
  border-radius:20px;padding:42px;overflow:hidden;
  box-shadow:0 18px 48px rgba(20,20,20,.07);
}
.contact-form-wrap::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--red),var(--gold));
}
.contact-form-title{font-size:22px;font-weight:800;color:var(--black);margin-bottom:6px;letter-spacing:-.3px}
.contact-form-sub{font-size:13.5px;color:var(--mid);margin-bottom:28px;line-height:1.55}
.contact-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}
.contact-field{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.contact-field.full{grid-column:1/-1}
.contact-form-row .contact-field{margin-bottom:0}
.contact-field label{font-size:12px;font-weight:700;color:var(--dark);letter-spacing:.1px}
.contact-field input,.contact-field select,.contact-field textarea{
  height:50px;border:1.5px solid var(--border);border-radius:11px;
  padding:0 16px;font-size:14px;color:var(--dark);outline:none;font-family:inherit;
  background:var(--bg);
  transition:border-color var(--trans),background var(--trans),box-shadow var(--trans);
}
.contact-field textarea{height:auto;padding:14px 16px;resize:vertical;min-height:140px;line-height:1.5}
.contact-field input:focus,.contact-field select:focus,.contact-field textarea:focus{
  border-color:var(--red);background:#fff;box-shadow:0 0 0 4px rgba(226,0,26,.09);
}
.contact-field select{cursor:pointer}
.contact-form-wrap .btn-primary{
  border:none;width:100%;justify-content:center;
  box-shadow:0 10px 24px rgba(226,0,26,.26);
}
.contact-form-wrap .btn-primary:hover{box-shadow:0 14px 30px rgba(226,0,26,.34)}
.contact-form-legal{font-size:11.5px;color:var(--light);line-height:1.6;margin-top:16px}
.contact-form-legal a{color:var(--mid);text-decoration:underline}

.contact-notice{
  display:flex;align-items:center;gap:10px;
  padding:14px 18px;border-radius:12px;font-size:13px;font-weight:600;margin-bottom:22px;
}
.contact-notice svg{flex-shrink:0}
.contact-notice.success{background:rgba(26,122,60,.08);color:#1a7a3c;border:1px solid rgba(26,122,60,.22)}
.contact-notice.error{background:rgba(226,0,26,.06);color:var(--red-d);border:1px solid rgba(226,0,26,.2)}

.contact-hours-list{display:flex;flex-direction:column}
.contact-hours-row{
  display:flex;justify-content:space-between;font-size:13px;color:var(--mid);
  padding:6px 0;border-bottom:1px dashed var(--border);
}
.contact-hours-row:last-child{border-bottom:none;padding-bottom:0}
.contact-hours-row strong{color:var(--dark);font-weight:700}

@media(max-width:900px){
  .contact-form-row{grid-template-columns:1fr}
}

/* =================================================================
   WOOCOMMERCE NOTICES (used across all WC pages)
   ================================================================= */
.woocommerce-message,.woocommerce-error,.woocommerce-info{
  border-radius:10px;padding:14px 18px;font-size:13px;font-weight:600;
  display:flex;align-items:center;gap:10px;margin-bottom:20px;
}
.woocommerce-message{background:rgba(26,122,60,.08);color:#1a7a3c;border:1px solid rgba(26,122,60,.22)}
.woocommerce-error{background:rgba(226,0,26,.06);color:var(--red-d);border:1px solid rgba(226,0,26,.2);flex-direction:column;align-items:flex-start;gap:4px}
.woocommerce-error li{list-style:none}
.woocommerce-info{background:rgba(0,90,200,.07);color:#004fad;border:1px solid rgba(0,90,200,.18)}
.woocommerce-notices-wrapper{margin-bottom:16px}

/* =================================================================
   SINGLE PRODUCT — woocommerce/single-product.php
   ================================================================= */

/* Breadcrumb (white on hero variant already done; this is the white-bg inner-page version) */
.sp-breadcrumb{font-size:12px;color:var(--light);margin-bottom:20px}
.sp-breadcrumb a{color:var(--mid);transition:color var(--trans)}
.sp-breadcrumb a:hover{color:var(--red)}
.sp-breadcrumb span.sep{margin:0 6px;color:var(--border)}

/* Two-column layout */
.sp-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}

/* === Gallery (left column) === */
.sp-gallery{position:sticky;top:100px}
.sp-main-img{
  border-radius:var(--radius);overflow:hidden;background:#f5f0eb;
  aspect-ratio:1/1;position:relative;cursor:zoom-in;
}
.sp-main-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.sp-main-img:hover img{transform:scale(1.06)}
.sp-badges-overlay{position:absolute;top:14px;left:14px;display:flex;flex-direction:column;gap:5px;z-index:3}
.sp-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}
.sp-thumb{
  border-radius:6px;overflow:hidden;aspect-ratio:1/1;cursor:pointer;
  border:2px solid transparent;transition:border-color var(--trans),opacity var(--trans);
  background:#f0ece7;
}
.sp-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.sp-thumb.active,.sp-thumb:hover{border-color:var(--red)}
.sp-thumb:not(.active){opacity:.72}

/* === Info panel (right column) === */
.sp-info{}
.sp-meta-top{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.sp-category{font-size:10px;font-weight:800;letter-spacing:1.8px;text-transform:uppercase;color:var(--red)}
.sp-sku{font-size:11px;color:var(--light)}
.sp-sku span{color:var(--mid)}

.sp-title{font-size:30px;font-weight:900;color:var(--black);line-height:1.12;letter-spacing:-.5px;margin-bottom:12px}

/* Star rating */
.sp-rating{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.sp-stars{display:flex;gap:2px}
.sp-stars svg{width:14px;height:14px;fill:var(--gold);stroke:var(--gold);stroke-width:.5}
.sp-stars svg.empty{fill:none;stroke:var(--border);stroke-width:1.5}
.sp-rating-count{font-size:12px;color:var(--light);font-weight:600}
.sp-rating-count a{color:var(--mid);transition:color var(--trans)}
.sp-rating-count a:hover{color:var(--red)}

/* Price block */
.sp-price-block{background:var(--bg);border-radius:12px;padding:18px 20px;margin-bottom:20px;border:1px solid var(--border)}
.sp-price-row{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.sp-price-new{font-size:34px;font-weight:900;color:var(--red);line-height:1}
.sp-price-old{font-size:16px;color:var(--light);text-decoration:line-through}
.sp-price-save{background:var(--red);color:#fff;font-size:10px;font-weight:800;padding:3px 9px;border-radius:30px;letter-spacing:.3px}
.sp-price-vat{font-size:11px;color:var(--light);margin-top:5px}
/* WooCommerce native price inside .sp-price-row */
.sp-price-row .price{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.sp-price-row .price .amount{font-size:34px;font-weight:900;color:var(--dark);line-height:1}
.sp-price-row .price ins{text-decoration:none}
.sp-price-row .price ins .amount{color:var(--red)}
.sp-price-row .price del{text-decoration:none}
.sp-price-row .price del .amount{font-size:16px;color:var(--light);text-decoration:line-through;font-weight:400}

/* Short description */
.sp-short-desc{font-size:13.5px;color:var(--mid);line-height:1.65;margin-bottom:20px}
.sp-short-desc p{margin-bottom:6px}
.sp-short-desc ul{padding-left:16px;list-style:disc}
.sp-short-desc ul li{margin-bottom:3px}

/* Delivery badge */
.sp-delivery{
  display:flex;align-items:center;gap:10px;
  background:#fff;border:1px solid var(--border);border-radius:10px;
  padding:12px 16px;margin-bottom:20px;
}
.sp-delivery-ico{width:36px;height:36px;border-radius:50%;background:rgba(26,122,60,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sp-delivery-ico svg{width:16px;height:16px;stroke:#1a7a3c;fill:none;stroke-width:2;stroke-linecap:round}
.sp-delivery-text strong{display:block;font-size:13px;font-weight:700;color:#1a7a3c}
.sp-delivery-text span{font-size:11.5px;color:var(--light)}

/* Quantity + add to cart */
.sp-add-form{display:flex;gap:12px;margin-bottom:14px;align-items:center;flex-wrap:wrap}
.sp-qty{display:flex;align-items:center;gap:0;border:2px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}
.sp-qty button{width:42px;height:52px;background:#fff;border:none;cursor:pointer;font-size:18px;font-weight:700;color:var(--dark);transition:background var(--trans),color var(--trans);display:flex;align-items:center;justify-content:center}
.sp-qty button:hover{background:var(--red);color:#fff}
.sp-qty input{width:52px;height:52px;border:none;border-left:1.5px solid var(--border);border-right:1.5px solid var(--border);text-align:center;font-size:16px;font-weight:700;color:var(--dark);outline:none;background:#fff}
/* WooCommerce native quantity input */
.quantity .qty{width:52px;height:52px;border:none;text-align:center;font-size:16px;font-weight:700;color:var(--dark);outline:none;background:#fff}
.woocommerce-quantity{display:flex;align-items:center;border:2px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}

.sp-add-btn{
  flex:1;min-width:200px;height:52px;
  background:var(--red);color:#fff;border:none;border-radius:var(--radius-sm);
  font-size:15px;font-weight:800;display:flex;align-items:center;justify-content:center;gap:10px;
  cursor:pointer;box-shadow:0 6px 24px rgba(226,0,26,.35);
  transition:background var(--trans),transform var(--trans),box-shadow var(--trans);
}
.sp-add-btn:hover{background:var(--red-d);transform:translateY(-2px);box-shadow:0 10px 32px rgba(226,0,26,.45)}
.sp-add-btn svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2.2;stroke-linecap:round}

.sp-wish-btn{
  width:52px;height:52px;border-radius:var(--radius-sm);
  border:2px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:border-color var(--trans),background var(--trans);flex-shrink:0;
}
.sp-wish-btn:hover,.sp-wish-btn.active{border-color:var(--red);background:#fff8f8}
.sp-wish-btn svg{width:18px;height:18px;stroke:var(--mid);fill:none;stroke-width:2;stroke-linecap:round;transition:stroke var(--trans),fill var(--trans)}
.sp-wish-btn.active svg{stroke:var(--red);fill:var(--red)}

/* Mini payment strip */
.sp-payment-mini{
  display:flex;align-items:center;gap:8px;padding:12px 16px;
  background:var(--bg);border-radius:10px;border:1px solid var(--border);
  flex-wrap:wrap;margin-bottom:20px;
}
.sp-payment-mini-label{font-size:11px;font-weight:700;color:var(--light);letter-spacing:.5px;text-transform:uppercase;margin-right:4px;flex-shrink:0}

/* Product details / attributes */
.sp-attrs{margin-bottom:20px}
.sp-attr-row{display:flex;font-size:13px;padding:9px 0;border-bottom:1px solid var(--border)}
.sp-attr-row:first-child{border-top:1px solid var(--border)}
.sp-attr-label{width:130px;flex-shrink:0;font-weight:700;color:var(--dark)}
.sp-attr-value{color:var(--mid)}

/* Product tabs (description, reviews) */
.sp-tabs{margin-top:56px}
.sp-tabs-nav{display:flex;border-bottom:2px solid var(--border);gap:0;margin-bottom:28px}
.sp-tabs-nav button{
  padding:12px 24px;font-size:14px;font-weight:700;color:var(--mid);background:none;
  border:none;border-bottom:3px solid transparent;margin-bottom:-2px;cursor:pointer;
  transition:color var(--trans),border-color var(--trans);
}
.sp-tabs-nav button.active{color:var(--red);border-bottom-color:var(--red)}
.sp-tabs-nav button:hover{color:var(--dark)}
.sp-tab-content{display:none;font-size:14px;color:var(--mid);line-height:1.7}
.sp-tab-content.active{display:block}
.sp-tab-content h2,.sp-tab-content h3{font-size:18px;font-weight:800;color:var(--black);margin-bottom:10px;letter-spacing:-.2px}
.sp-tab-content p{margin-bottom:14px}
.sp-tab-content ul{padding-left:18px;list-style:disc;margin-bottom:14px}
.sp-tab-content ul li{margin-bottom:5px}
.sp-tab-content table{width:100%;border-collapse:collapse;font-size:13px}
.sp-tab-content table th,.sp-tab-content table td{padding:10px 14px;border-bottom:1px solid var(--border);text-align:left}
.sp-tab-content table th{font-weight:700;color:var(--dark);background:var(--bg)}

/* Related products */
.sp-related{margin-top:56px}

/* Responsive */
@media(max-width:900px){
  .sp-layout{grid-template-columns:1fr;gap:28px}
  .sp-gallery{position:static}
  .sp-title{font-size:24px}
  .sp-price-new{font-size:26px}
  .sp-price-row .price .amount{font-size:26px}
}
@media(max-width:640px){
  .sp-thumbs{grid-template-columns:repeat(4,1fr);gap:6px}
  .sp-title{font-size:20px}
  .sp-add-form{gap:8px}
  .sp-add-btn{font-size:14px;height:48px}
  .sp-qty button,.sp-qty input{height:48px}
}

/* =================================================================
   WINKELWAGEN (CART) — page-cart.php + woocommerce/cart/cart.php
   ================================================================= */
.cart-page-layout{display:grid;grid-template-columns:1fr 380px;gap:32px;align-items:start}

/* Cart items panel */
.cart-items-wrap{background:var(--white);border:1px solid var(--border);border-radius:var(--radius)}
.cart-items-head{display:flex;align-items:center;gap:10px;padding:18px 24px;border-bottom:1px solid var(--border)}
.cart-items-head h2{font-size:17px;font-weight:800;color:var(--black)}
.cart-items-head .cart-count-badge{background:var(--red);color:#fff;font-size:11px;font-weight:800;padding:2px 8px;border-radius:30px}

/* Cart row */
.cart-row{display:grid;grid-template-columns:80px 1fr auto auto auto;gap:16px;align-items:center;padding:18px 24px;border-bottom:1px solid var(--border)}
.cart-row:last-of-type{border-bottom:none}
.cart-item-img{width:80px;height:80px;border-radius:8px;overflow:hidden;background:#f5f0eb;flex-shrink:0}
.cart-item-img img{width:100%;height:100%;object-fit:cover;display:block}
.cart-item-name{font-size:13.5px;font-weight:700;color:var(--dark);line-height:1.35;margin-bottom:4px}
.cart-item-name a{color:inherit;transition:color var(--trans)}
.cart-item-name a:hover{color:var(--red)}
.cart-item-meta{font-size:11.5px;color:var(--light);line-height:1.5}
.cart-item-price{font-size:14px;color:var(--mid);white-space:nowrap;text-align:right}
.cart-item-qty{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:6px;overflow:hidden}
.cart-item-qty button{width:32px;height:36px;background:#fff;border:none;cursor:pointer;font-size:15px;font-weight:700;color:var(--dark);transition:background var(--trans),color var(--trans);display:flex;align-items:center;justify-content:center}
.cart-item-qty button:hover{background:var(--red);color:#fff}
.cart-item-qty input{width:42px;height:36px;border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);text-align:center;font-size:13px;font-weight:700;color:var(--dark);outline:none;background:#fff}
.cart-item-subtotal{font-size:15px;font-weight:900;color:var(--dark);white-space:nowrap;text-align:right;min-width:80px}
.cart-item-remove{width:30px;height:30px;border-radius:50%;background:none;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--trans),border-color var(--trans);flex-shrink:0}
.cart-item-remove:hover{background:var(--red);border-color:var(--red)}
.cart-item-remove svg{width:12px;height:12px;stroke:var(--mid);fill:none;stroke-width:2;stroke-linecap:round;transition:stroke var(--trans)}
.cart-item-remove:hover svg{stroke:#fff}
/* WooCommerce native remove link */
.woocommerce-cart-form .remove{
  display:flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;background:none;border:1.5px solid var(--border);
  font-size:18px;line-height:1;color:var(--light);transition:background var(--trans),border-color var(--trans),color var(--trans);
  text-decoration:none;
}
.woocommerce-cart-form .remove:hover{background:var(--red);border-color:var(--red);color:#fff}

/* Cart footer actions */
.cart-actions{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid var(--border);flex-wrap:wrap;gap:12px}
.cart-coupon{display:flex;gap:8px;align-items:center;flex:1;min-width:200px}
.cart-coupon input{height:42px;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:0 14px;font-size:13px;flex:1;outline:none;transition:border-color var(--trans)}
.cart-coupon input:focus{border-color:var(--red)}
.cart-coupon input::placeholder{color:#bbb}
.btn-coupon{height:42px;background:var(--dark);color:#fff;border:none;border-radius:var(--radius-sm);padding:0 18px;font-size:13px;font-weight:700;cursor:pointer;transition:background var(--trans);white-space:nowrap}
.btn-coupon:hover{background:var(--black)}
.btn-update-cart{height:42px;background:none;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:0 18px;font-size:13px;font-weight:700;color:var(--mid);cursor:pointer;transition:border-color var(--trans),color var(--trans),background var(--trans)}
.btn-update-cart:hover{border-color:var(--red);color:var(--red)}

/* WooCommerce native cart form styling */
.woocommerce-cart-form .shop_table{width:100%;border-collapse:collapse}
.woocommerce-cart-form .shop_table thead tr th{padding:14px 16px;font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--light);border-bottom:1px solid var(--border)}
.woocommerce-cart-form .shop_table .cart_item td{padding:16px;border-bottom:1px solid var(--border);vertical-align:middle}
.woocommerce-cart-form .product-thumbnail img{width:72px;height:72px;object-fit:cover;border-radius:8px}
.woocommerce-cart-form .product-name a{font-weight:700;color:var(--dark);transition:color var(--trans)}
.woocommerce-cart-form .product-name a:hover{color:var(--red)}
.woocommerce-cart-form .product-price,.woocommerce-cart-form .product-subtotal{font-weight:700;color:var(--dark)}
.woocommerce-cart-form .product-subtotal{color:var(--red)}
.woocommerce-cart-form .quantity input.qty{width:58px;height:38px;border:1.5px solid var(--border);border-radius:6px;text-align:center;font-size:13px;font-weight:700;padding:0;outline:none;transition:border-color var(--trans)}
.woocommerce-cart-form .quantity input.qty:focus{border-color:var(--red)}
.woocommerce-cart-form .actions{padding:16px;border-top:1px solid var(--border)}
.woocommerce-cart-form .coupon{display:flex;gap:8px;align-items:center;float:left}
.woocommerce-cart-form .coupon .input-text{height:42px;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:0 14px;font-size:13px;width:200px;outline:none;transition:border-color var(--trans)}
.woocommerce-cart-form .coupon .input-text:focus{border-color:var(--red)}
.woocommerce-cart-form .coupon .button{height:42px;background:var(--dark);color:#fff;border:none;border-radius:var(--radius-sm);padding:0 18px;font-size:13px;font-weight:700;cursor:pointer;transition:background var(--trans)}
.woocommerce-cart-form .coupon .button:hover{background:var(--black)}
.woocommerce-cart-form button[name="update_cart"]{float:right;height:42px;background:none;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:0 18px;font-size:13px;font-weight:700;color:var(--mid);cursor:pointer;transition:border-color var(--trans),color var(--trans)}
.woocommerce-cart-form button[name="update_cart"]:hover{border-color:var(--red);color:var(--red)}

/* Cart totals sidebar */
.cart-sidebar{}
.cart-totals-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;position:sticky;top:100px;
}
.cart-totals-head{padding:18px 24px;border-bottom:1px solid var(--border);background:var(--black)}
.cart-totals-head h3{font-size:16px;font-weight:800;color:#fff}

/* WooCommerce native cart_totals table */
.cart_totals h2{display:none}
.cart_totals .shop_table{width:100%;border-collapse:collapse}
.cart_totals .shop_table tr th{padding:14px 24px;font-size:13px;font-weight:700;color:var(--dark);border-bottom:1px solid var(--border);text-align:left;width:45%}
.cart_totals .shop_table tr td{padding:14px 24px;font-size:13px;color:var(--mid);border-bottom:1px solid var(--border);text-align:right}
.cart_totals .shop_table .cart-subtotal td,.cart_totals .shop_table .cart-subtotal th{border-bottom:none}
.cart_totals .shop_table .order-total th{font-size:15px;font-weight:900;color:var(--black);border-top:2px solid var(--border);border-bottom:none;padding-top:16px}
.cart_totals .shop_table .order-total td{font-size:20px;font-weight:900;color:var(--red);border-top:2px solid var(--border);border-bottom:none;padding-top:16px}
.cart_totals .wc-proceed-to-checkout{padding:20px 24px 24px}
.cart_totals .wc-proceed-to-checkout a,.cart_totals .checkout-button{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;height:54px;background:var(--red);color:#fff;
  font-size:15px;font-weight:800;border-radius:var(--radius-sm);
  text-decoration:none;box-shadow:0 6px 24px rgba(226,0,26,.35);
  transition:background var(--trans),transform var(--trans),box-shadow var(--trans);
}
.cart_totals .wc-proceed-to-checkout a:hover,.cart_totals .checkout-button:hover{
  background:var(--red-d);transform:translateY(-2px);box-shadow:0 10px 32px rgba(226,0,26,.45);
}
.cart-secure-note{
  display:flex;align-items:center;justify-content:center;gap:6px;
  font-size:11.5px;color:var(--light);padding:12px 24px;border-top:1px solid var(--border);
}
.cart-secure-note svg{width:13px;height:13px;stroke:var(--light);fill:none;stroke-width:2;flex-shrink:0}
.cart-empty-state{
  text-align:center;padding:64px 24px;
}
.cart-empty-icon{width:72px;height:72px;border-radius:50%;background:rgba(226,0,26,.08);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.cart-empty-icon svg{width:30px;height:30px;stroke:var(--red);fill:none;stroke-width:1.8;stroke-linecap:round}
.cart-empty-title{font-size:22px;font-weight:800;color:var(--black);margin-bottom:8px}
.cart-empty-sub{font-size:14px;color:var(--mid);max-width:380px;margin:0 auto 24px;line-height:1.6}

/* Cross-sells */
.cart-cross-sells{margin-top:48px}
.cart-cross-sells .sp-related-title{font-size:22px}
.cross-sells-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:20px}

/* Shipping calculator */
.shipping-calculator-button{color:var(--red);font-weight:700;font-size:13px;text-decoration:underline;cursor:pointer}
.shipping-calculator-form{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.shipping-calculator-form select,.shipping-calculator-form input{
  height:42px;border:1.5px solid var(--border);border-radius:var(--radius-sm);
  padding:0 12px;font-size:13px;outline:none;background:#fff;
  transition:border-color var(--trans);
}
.shipping-calculator-form select:focus,.shipping-calculator-form input:focus{border-color:var(--red)}
.shipping-calculator-form .button{
  height:42px;background:var(--dark);color:#fff;border:none;
  border-radius:var(--radius-sm);padding:0 18px;font-size:13px;font-weight:700;
  cursor:pointer;transition:background var(--trans);align-self:flex-start;
}
.shipping-calculator-form .button:hover{background:var(--black)}

@media(max-width:1100px){
  .cart-page-layout{grid-template-columns:1fr 320px}
}
@media(max-width:900px){
  .cart-page-layout{grid-template-columns:1fr;gap:24px}
  .cart-totals-card{position:static}
  .cart-row{grid-template-columns:68px 1fr auto;gap:12px}
  .cart-item-price,.cart-item-subtotal{display:none}
  .cart-cross-sells .pgrid,.cross-sells-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .cart-row{grid-template-columns:60px 1fr auto;padding:14px 16px}
  .cart-items-head{padding:14px 16px}
  .cart-actions{padding:12px 16px}
  .cart-coupon{min-width:0}
  .woocommerce-cart-form .shop_table thead{display:none}
  .woocommerce-cart-form .shop_table .cart_item td{display:block;padding:8px 16px;border-bottom:none}
  .woocommerce-cart-form .shop_table .cart_item td.product-remove{padding-bottom:0}
  .woocommerce-cart-form .shop_table .cart_item{border-bottom:1px solid var(--border)}
}

/* =================================================================
   INLOGGEN / MY ACCOUNT — page-my-account.php
   ================================================================= */
.account-page{padding:56px 0}
.account-page-inner{max-width:960px;margin:0 auto}
.account-split{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.account-card{
  background:var(--white);border:1px solid var(--border);border-radius:20px;
  padding:40px;overflow:hidden;position:relative;
  box-shadow:0 12px 40px rgba(20,20,20,.06);
}
.account-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),var(--gold))}
.account-card-title{font-size:22px;font-weight:900;color:var(--black);margin-bottom:6px;letter-spacing:-.3px}
.account-card-sub{font-size:13.5px;color:var(--mid);margin-bottom:28px;line-height:1.5}
.account-divider{text-align:center;position:relative;margin:20px 0}
.account-divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border)}
.account-divider span{position:relative;background:#fff;padding:0 12px;font-size:12px;color:var(--light);font-weight:600}

/* Form fields */
.account-field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.account-field label{font-size:12px;font-weight:700;color:var(--dark);letter-spacing:.1px}
.account-field input{
  height:50px;border:1.5px solid var(--border);border-radius:11px;
  padding:0 16px;font-size:14px;color:var(--dark);outline:none;font-family:inherit;
  background:var(--bg);transition:border-color var(--trans),background var(--trans),box-shadow var(--trans);
}
.account-field input:focus{border-color:var(--red);background:#fff;box-shadow:0 0 0 4px rgba(226,0,26,.09)}
.account-field input::placeholder{color:#bbb}
.account-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.account-forgot{font-size:12px;color:var(--mid);text-align:right;margin-top:-8px;margin-bottom:16px}
.account-forgot a{color:var(--red);font-weight:700;transition:color var(--trans)}
.account-forgot a:hover{color:var(--red-d)}
.account-btn{
  width:100%;height:50px;background:var(--red);color:#fff;border:none;border-radius:11px;
  font-size:15px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 6px 24px rgba(226,0,26,.3);
  transition:background var(--trans),transform var(--trans),box-shadow var(--trans);
}
.account-btn:hover{background:var(--red-d);transform:translateY(-2px);box-shadow:0 10px 32px rgba(226,0,26,.4)}
.account-social-login{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.account-social-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  height:46px;border:1.5px solid var(--border);border-radius:11px;
  font-size:13.5px;font-weight:600;color:var(--dark);background:#fff;
  cursor:pointer;transition:border-color var(--trans),background var(--trans);
}
.account-social-btn:hover{border-color:var(--mid);background:var(--bg)}
.account-benefits{display:flex;flex-direction:column;gap:10px;margin-top:20px}
.account-benefit{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--mid)}
.account-benefit-ico{width:22px;height:22px;border-radius:50%;background:rgba(226,0,26,.1);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px}
.account-benefit-ico svg{width:10px;height:10px;stroke:var(--red);fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.account-checkbox{display:flex;align-items:flex-start;gap:10px;font-size:12.5px;color:var(--mid);margin-bottom:18px;cursor:pointer;line-height:1.5}
.account-checkbox input[type="checkbox"]{width:16px;height:16px;accent-color:var(--red);flex-shrink:0;margin-top:2px}

/* WooCommerce native login/register forms */
.woocommerce-form-login,.woocommerce-form-register{display:flex;flex-direction:column}
.woocommerce-form-login .form-row,.woocommerce-form-register .form-row{margin-bottom:16px}
.woocommerce-form-login .form-row label,.woocommerce-form-register .form-row label{font-size:12px;font-weight:700;color:var(--dark);display:block;margin-bottom:6px;letter-spacing:.1px}
.woocommerce-form-login .form-row input,.woocommerce-form-register .form-row input{
  width:100%;height:50px;border:1.5px solid var(--border);border-radius:11px;
  padding:0 16px;font-size:14px;color:var(--dark);outline:none;font-family:inherit;
  background:var(--bg);transition:border-color var(--trans),background var(--trans),box-shadow var(--trans);
}
.woocommerce-form-login .form-row input:focus,.woocommerce-form-register .form-row input:focus{border-color:var(--red);background:#fff;box-shadow:0 0 0 4px rgba(226,0,26,.09)}
.woocommerce-form-login .button,.woocommerce-form-register .button{
  width:100%;height:50px;background:var(--red);color:#fff;border:none;border-radius:11px;
  font-size:15px;font-weight:800;cursor:pointer;box-shadow:0 6px 24px rgba(226,0,26,.3);
  transition:background var(--trans),transform var(--trans);
}
.woocommerce-form-login .button:hover,.woocommerce-form-register .button:hover{background:var(--red-d);transform:translateY(-2px)}
.woocommerce-form-login .woocommerce-form__label-for-checkbox,.woocommerce-form-register .woocommerce-form__label-for-checkbox{
  display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--mid);cursor:pointer;margin-bottom:16px;
}
.woocommerce-form-login .lost_password{font-size:12.5px;text-align:right;margin-bottom:16px}
.woocommerce-form-login .lost_password a{color:var(--red);font-weight:700;transition:color var(--trans)}
.woocommerce-form-login .lost_password a:hover{color:var(--red-d)}
.woocommerce-account .woocommerce{max-width:100%}

/* Logged-in dashboard */
.account-dashboard{display:grid;grid-template-columns:220px 1fr;gap:28px;align-items:start}
.account-nav-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.account-nav-user{padding:20px;border-bottom:1px solid var(--border);text-align:center}
.account-nav-avatar{width:60px;height:60px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:22px;font-weight:900;color:#fff}
.account-nav-name{font-size:14px;font-weight:700;color:var(--dark)}
.account-nav-email{font-size:11.5px;color:var(--light)}
.woocommerce-account .woocommerce-MyAccount-navigation{padding:8px 0}
.woocommerce-account .woocommerce-MyAccount-navigation ul{list-style:none}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a{
  display:block;padding:11px 20px;font-size:13px;font-weight:600;color:var(--mid);
  transition:background var(--trans),color var(--trans);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover{background:var(--bg);color:var(--red)}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a{color:var(--red);background:rgba(226,0,26,.05);font-weight:800;border-left:3px solid var(--red);padding-left:17px}
.woocommerce-account .woocommerce-MyAccount-content{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:28px}

@media(max-width:900px){
  .account-split{grid-template-columns:1fr;gap:20px}
  .account-card{padding:28px 24px}
  .account-dashboard{grid-template-columns:1fr}
}
@media(max-width:640px){
  .account-page{padding:36px 0}
  .account-field-row{grid-template-columns:1fr}
}

/* =================================================================
   VERLANGLIJST (WISHLIST) — page-verlanglijst.php
   ================================================================= */
.wishlist-page{padding:48px 0}
.wishlist-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.wishlist-count{font-size:14px;color:var(--mid);font-weight:600}
.wishlist-count strong{color:var(--dark)}
.btn-clear-wishlist{
  font-size:12.5px;font-weight:700;color:var(--light);background:none;border:1.5px solid var(--border);
  border-radius:var(--radius-sm);padding:8px 14px;cursor:pointer;display:flex;align-items:center;gap:6px;
  transition:border-color var(--trans),color var(--trans);
}
.btn-clear-wishlist:hover{border-color:var(--red);color:var(--red)}
.btn-clear-wishlist svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}
.wishlist-empty{
  text-align:center;padding:80px 24px;background:var(--bg);border-radius:var(--radius);
  border:1px dashed var(--border);
}
.wishlist-empty-icon{width:80px;height:80px;border-radius:50%;background:rgba(226,0,26,.08);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.wishlist-empty-icon svg{width:34px;height:34px;stroke:var(--red);fill:none;stroke-width:1.6;stroke-linecap:round}
.wishlist-empty h2{font-size:24px;font-weight:800;color:var(--black);margin-bottom:10px}
.wishlist-empty p{font-size:14px;color:var(--mid);max-width:380px;margin:0 auto 28px;line-height:1.6}

@media(max-width:900px){
  .wishlist-page{padding:32px 0}
}

/* =================================================================
   CART STEP INDICATOR — .cart-steps-bar (page-cart.php)
   ================================================================= */
.cart-steps-bar{background:var(--white);border-bottom:1px solid var(--border);padding:14px 0}
.cart-steps-inner{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}
.cart-steps-inner::-webkit-scrollbar{display:none}
.cart-step{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--light);white-space:nowrap;flex-shrink:0}
.cart-step--active{font-weight:800;color:var(--red)}
.cart-step-num{
  width:26px;height:26px;border-radius:50%;
  border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:900;flex-shrink:0;
}
.cart-step--active .cart-step-num{background:var(--red);border-color:var(--red);color:#fff}
.cart-step-line{width:60px;height:2px;background:var(--border);margin:0 12px;flex-shrink:0}
@media(max-width:480px){
  .cart-step-line{width:32px;margin:0 6px}
  .cart-step{font-size:11.5px;gap:6px}
  .cart-step-num{width:23px;height:23px;font-size:10px}
}
@media(max-width:360px){
  .cart-step-label{display:none}
  .cart-step-line{width:20px;margin:0 4px}
  .cart-step-num{width:22px;height:22px}
}

/* =================================================================
   HOVER VERBETERINGEN — knoppen, selects en attributen
   ================================================================= */

/* Zeker stellen dat .btn-cart altijd wit tekst + donkerrood bij hover heeft */
a.btn-cart,button.btn-cart,.btn-cart{color:#fff}
a.btn-cart:hover,button.btn-cart:hover,.btn-cart:hover{background:var(--red-d);color:#fff}

/* Ordering dropdown */
.woocommerce-ordering select:hover{border-color:var(--red);background:#fff8f8}
.woocommerce-ordering select{transition:border-color var(--trans),background var(--trans)}

/* WooCommerce variation / attribute selects */
table.variations select,.variations td select,select.attribute_values{
  width:100%;height:46px;border:1.5px solid var(--border);border-radius:var(--radius-sm);
  padding:0 14px;font-size:14px;color:var(--dark);background:#fff;
  outline:none;cursor:pointer;
  transition:border-color var(--trans),background var(--trans),box-shadow var(--trans);
}
table.variations select:hover,.variations td select:hover,select.attribute_values:hover{
  border-color:var(--red);background:#fff8f8;
}
table.variations select:focus,.variations td select:focus{
  border-color:var(--red);background:#fff;
  box-shadow:0 0 0 4px rgba(226,0,26,.09);
}

/* Contact & shipping selects */
.contact-field select:hover,.shipping-calculator-form select:hover{border-color:var(--red);background:#fff8f8}

/* WooCommerce native .button override (add to cart, coupon, etc.) */
.woocommerce .button:hover,
.woocommerce button.button:hover,
.woocommerce a.button:hover,
.woocommerce input.button:hover{
  color:#fff;
}
.woocommerce .button.alt:hover,
.woocommerce button.button.alt:hover{
  background:var(--red-d);color:#fff;
}

/* Coupon button */
.btn-coupon:hover{background:var(--black);color:#fff}

/* =================================================================
   GROTE SCHERMEN — 1600px en groter (wide desktop, 2K)
   ================================================================= */
@media(min-width:1600px){
  .wrap{max-width:1600px;padding:0 44px}
  .hero{height:640px}
  .hero-h1{font-size:66px;letter-spacing:-2px}
  .hero-sub{font-size:18px;max-width:520px}
  body{font-size:15px}
  .sec{padding:72px 0}
  .sec-title{font-size:32px}
  .header .wrap{height:84px}
  .logo-img{height:54px}
  .mainnav li a{font-size:14px;padding:0 20px}
  .mainnav .wrap{height:52px}
  .nl-title{font-size:40px}
  .page-hero{min-height:360px}
  .page-hero .hero-h1{font-size:52px}
  .sp-title{font-size:34px}
  .sp-add-btn{height:56px;font-size:16px}
  .cart-page-layout{grid-template-columns:1fr 400px}
  .footer-top{padding:68px 0 56px}
}

/* =================================================================
   4K SCHERMEN — 1920px en groter (FHD+, 4K monitors)
   ================================================================= */
@media(min-width:1920px){
  .wrap{max-width:1900px;padding:0 64px}
  .hero{height:760px}
  .hero-h1{font-size:80px;letter-spacing:-3px;max-width:720px}
  .hero-sub{font-size:20px;max-width:580px}
  body{font-size:16px}
  .sec{padding:88px 0}
  .sec-title{font-size:36px}
  .header .wrap{height:96px}
  .logo-img{height:62px}
  .search{max-width:680px;height:52px}
  .mainnav li a{font-size:15px;padding:0 24px}
  .mainnav .wrap{height:58px}
  .pc-name,h2.pc-name,.woocommerce-loop-product__title{font-size:14.5px}
  .pc-new{font-size:20px}
  .btn-cart{font-size:13.5px;padding:12px 0}
  .nl-title{font-size:44px}
  .nl-grid{gap:80px}
  .footer-top{padding:80px 0 68px}
  .page-hero{min-height:420px}
  .page-hero .hero-h1{font-size:60px}
  .sp-title{font-size:38px}
  .sp-price-new{font-size:42px}
  .sp-add-btn{height:60px;font-size:17px}
  .cart-page-layout{grid-template-columns:1fr 440px}
  .usp-grid{gap:0}
  .trust-inner{gap:40px}
  .footer-top{grid-template-columns:2fr 1fr 1fr 1fr 1fr}
}

/* =================================================================
   RESPONSIVE — 480px (grote telefoons: Pro Max, S23 Ultra)
   ================================================================= */
@media(max-width:480px){
  /* Single product — add-to-cart rij */
  .sp-add-form{flex-wrap:wrap}
  .sp-add-btn{min-width:100%;order:2}
  .sp-wish-btn{order:1;flex:1;min-width:0;height:50px;justify-content:center}
  /* Tabs scrollen horizontaal */
  .sp-tabs-nav{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}
  .sp-tabs-nav::-webkit-scrollbar{display:none}
  .sp-tabs-nav button{white-space:nowrap;flex-shrink:0}
  /* Cart */
  .cart-row{grid-template-columns:62px 1fr auto;gap:10px;padding:14px 14px}
  .cart-item-img{width:62px;height:62px}
  .cart-totals-head{padding:14px 18px}
  .cart_totals .shop_table tr th,.cart_totals .shop_table tr td{padding:12px 16px}
  .cart_totals .wc-proceed-to-checkout{padding:14px 18px 18px}
  /* Account */
  .account-card{padding:26px 22px}
  .account-card-title{font-size:20px}
  /* Newsletter */
  .nl-form-wrap{padding:22px 18px}
  /* Wishlist */
  .wishlist-toolbar{flex-direction:column;align-items:flex-start;gap:10px}
  .wishlist-empty{padding:56px 20px}
}

/* =================================================================
   RESPONSIVE — 360px (kleinere telefoons: Galaxy A, Pixel 4a)
   ================================================================= */
@media(max-width:360px){
  .wrap{padding:0 12px}
  .hero{height:300px}
  .hero-h1{font-size:22px;letter-spacing:-.5px}
  .hero-sub{font-size:12px;margin-bottom:18px}
  .hero-btns{flex-direction:column;align-items:flex-start;gap:8px}
  a.btn-primary,button.btn-primary,.btn-primary,.btn-outline-white{width:100%;justify-content:center;font-size:13px}
  .logo-img{height:26px}
  .h-action{padding:8px 3px;min-width:30px}
  .h-action svg{width:18px;height:18px}
  /* Productgrid */
  .pgrid{gap:6px}
  ul.products{gap:6px}
  .pc-info{padding:10px 10px 12px}
  .pc-name,h2.pc-name,.woocommerce-loop-product__title{font-size:11px}
  .pc-new{font-size:15px}
  .btn-cart{font-size:10.5px;padding:8px 0}
  /* Page hero */
  .page-hero .hero-h1{font-size:19px;letter-spacing:-.3px}
  .page-hero{min-height:170px}
  .page-hero-content{padding:22px 0}
  /* Single product */
  .sp-title{font-size:17px;letter-spacing:-.3px}
  .sp-price-new{font-size:22px}
  .sp-price-row .price .amount{font-size:22px}
  .sp-tabs-nav button{padding:10px 12px;font-size:12px}
  .sp-tabs{margin-top:36px}
  .sp-related{margin-top:36px}
  .sp-payment-mini{gap:4px;padding:10px 12px}
  .sp-add-btn{font-size:13px;height:46px}
  .sp-qty button,.sp-qty input{height:46px;width:38px}
  /* Cart */
  .cart-row{grid-template-columns:52px 1fr auto;padding:10px 12px;gap:8px}
  .cart-item-img{width:52px;height:52px}
  .cart-items-head{padding:12px 14px}
  .cart-actions{padding:10px 12px}
  .cart_totals .shop_table tr th,.cart_totals .shop_table tr td{padding:10px 12px;font-size:12px}
  .cart_totals .shop_table .order-total td{font-size:17px}
  .cart-empty-state{padding:44px 14px}
  .cart-empty-title{font-size:18px}
  /* Account */
  .account-card{padding:18px 14px}
  .account-card-title{font-size:18px}
  .account-card-sub{font-size:12.5px;margin-bottom:20px}
  .account-btn{font-size:13.5px;height:46px}
  .account-field input{height:46px;font-size:13px}
  .woocommerce-form-login .form-row input,.woocommerce-form-register .form-row input{height:46px;font-size:13px}
  .woocommerce-account .woocommerce-MyAccount-content{padding:18px 14px}
  /* Wishlist */
  .wishlist-empty{padding:40px 14px}
  .wishlist-empty h2{font-size:19px}
  .wishlist-empty p{font-size:13px}
  /* Footer */
  .nl-form-wrap{padding:18px 14px}
  .footer-top{gap:14px}
}

/* =================================================================
   RESPONSIVE — 320px (allerkleinst: iPhone SE 1e gen, kleine Android)
   ================================================================= */
@media(max-width:320px){
  .wrap{padding:0 10px}
  .hero{height:270px}
  .hero-h1{font-size:19px}
  .logo-img{height:24px}
  .h-action{padding:6px 2px;min-width:26px}
  .h-action svg{width:17px;height:17px}
  .cart-count{width:14px;height:14px;font-size:7px;top:4px;right:2px}
  .pgrid{grid-template-columns:1fr 1fr;gap:5px}
  ul.products{grid-template-columns:1fr 1fr;gap:5px}
  .pc-info{padding:8px 8px 10px}
  .pc-name,h2.pc-name,.woocommerce-loop-product__title{font-size:10.5px}
  .btn-cart{font-size:10px;padding:7px 0}
  .page-hero .hero-h1{font-size:16px}
  .page-hero{min-height:150px}
  .sp-title{font-size:15px}
  .account-card{padding:14px 12px}
  .cart-row{grid-template-columns:46px 1fr auto;gap:6px;padding:8px 10px}
  .cart-item-img{width:46px;height:46px}
  .wishlist-empty{padding:32px 10px}
  .wishlist-empty h2{font-size:16px}
}
