﻿/* Zyro Electric — Light Premium · Design Tokens */
:root {
  --bg:#F5F5F2;
  --bg-2:#EFEFEA;
  --paper:#FFFFFF;
  --ink:#111111;
  --ink-soft:#1A1A1A;
  --ink-dim:#555555;
  --ink-mute:#8A8A8A;
  --line:#DDDDDD;
  --line-soft:#E8E8E4;
  --accent:#006BFF;
  --accent-hover:#0057D9;
  --accent-soft:rgba(0,107,255,0.08);
  --accent-glow:rgba(0,107,255,0.18);
  --ok:#1f9d55;
  --warn:#c97a10;
  --bad:#d23a4b;
  --whatsapp:#25D366;
  --whatsapp-deep:#128C7E;
  --r-sm:6px; --r:10px; --r-md:14px; --r-lg:20px; --r-xl:28px;
  --f-display:"Space Grotesk",system-ui,sans-serif;
  --f-body:"Inter",system-ui,sans-serif;
  --f-mono:"JetBrains Mono",ui-monospace,monospace;
  --shadow-sm: 0 1px 2px rgba(17,17,17,.04);
  --shadow: 0 2px 8px rgba(17,17,17,.06);
  --shadow-lg: 0 8px 32px rgba(17,17,17,.08);
  --nav-h: 72px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--f-body);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{position:relative;min-height:100vh;overflow-x:hidden}
/* Subtle paper grain background */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.4;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.04 0'/></filter><rect width='400' height='400' filter='url(%23n)'/></svg>");
}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg-2)}
::-webkit-scrollbar-thumb{background:#bbb;border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:#999}

/* ============ Layout ============ */
.wrap{max-width:1320px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
.wrap-narrow{max-width:980px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
.section{padding:96px 0}
.section-sm{padding:56px 0}
.dark{background:var(--ink-soft);color:#fff}
.dark .ink-dim{color:#9a9a9a}
.dark a{color:#fff}

/* ============ Type ============ */
.eyebrow{font-family:var(--f-mono);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.eyebrow.muted{color:var(--ink-mute)}
.h-display{font-family:var(--f-display);font-weight:700;letter-spacing:-.02em;line-height:.95;text-wrap:balance;text-transform:uppercase}
.h-display.case{text-transform:none}
.mono{font-family:var(--f-mono)}
.accent{color:var(--accent)}

/* ============ Nav ============ */
.nav{position:sticky;top:0;z-index:50;background:rgba(245,245,242,0.85);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;gap:24px;height:var(--nav-h);max-width:1320px;margin:0 auto;padding:0 28px}
.logo{display:flex;align-items:center;gap:10px;cursor:pointer;flex-shrink:0}
.logo-mark{width:34px;height:34px;display:grid;place-items:center;background:var(--ink);color:#fff;border-radius:8px;font-family:var(--f-display);font-weight:800;font-size:18px;letter-spacing:-.05em;position:relative;overflow:hidden}
.logo-mark::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(0,107,255,.4),transparent 60%)}
.logo-mark span{position:relative;z-index:1}
.logo-text{font-family:var(--f-display);font-weight:700;font-size:16px;letter-spacing:.02em;line-height:1}
.logo-text small{display:block;font-family:var(--f-mono);font-size:9.5px;font-weight:500;color:var(--ink-mute);letter-spacing:.18em;margin-top:3px}
.nav-links{display:flex;gap:2px;margin-left:8px}
.nav-links button{padding:8px 14px;font-size:14px;color:var(--ink-dim);border-radius:8px;font-weight:500;transition:color .12s,background .12s}
.nav-links button:hover{color:var(--ink);background:rgba(17,17,17,.04)}
.nav-links button.active{color:var(--ink);background:rgba(17,17,17,.06)}
.nav-actions{display:flex;align-items:center;gap:4px;margin-left:auto}
.icon-btn{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;color:var(--ink);position:relative;transition:background .12s}
.icon-btn:hover{background:rgba(17,17,17,.05)}
.cart-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 5px;background:var(--accent);color:#fff;border-radius:10px;font-size:10.5px;font-weight:700;display:grid;place-items:center;font-family:var(--f-mono);box-shadow:0 0 0 2px var(--bg)}
.mobile-toggle{display:none}

@media (max-width:900px){
  .nav-links{display:none}
  .mobile-toggle{display:grid}
  .logo-text small{display:none}
  .nav-inner{gap:12px;padding:0 18px}
}

/* Mobile nav overlay */
.mob-overlay{position:fixed;inset:0;background:rgba(17,17,17,.55);z-index:90;animation:fadeIn .2s}
.mob-panel{position:fixed;top:0;right:0;bottom:0;width:min(360px,90vw);background:var(--paper);z-index:91;display:flex;flex-direction:column;animation:slideR .25s ease}
.mob-panel header{padding:20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line)}
.mob-panel nav{padding:16px;display:flex;flex-direction:column;gap:4px;flex:1;overflow:auto}
.mob-panel nav button{text-align:left;padding:14px 16px;border-radius:10px;font-size:16px;font-weight:500;color:var(--ink)}
.mob-panel nav button:hover,.mob-panel nav button.active{background:var(--bg-2);color:var(--accent)}
.mob-panel footer{padding:20px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
@keyframes slideR{from{transform:translateX(100%)}to{transform:translateX(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ============ Buttons ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:46px;padding:0 22px;font-family:var(--f-display);font-weight:600;font-size:14.5px;letter-spacing:.01em;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:transform .1s,background .15s,border-color .15s,box-shadow .15s;white-space:nowrap;text-transform:uppercase}
.btn:active{transform:translateY(1px)}
.btn-sm{height:38px;padding:0 14px;font-size:12.5px;border-radius:8px}
.btn-lg{height:56px;padding:0 28px;font-size:15px;border-radius:12px}
.btn-block{width:100%}

.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:#000}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.18) inset}
.btn-accent:hover{background:var(--accent-hover);box-shadow:0 6px 20px -6px var(--accent-glow),0 1px 0 rgba(255,255,255,.18) inset}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{background:rgba(17,17,17,.04);border-color:#bbb}
.btn-light{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-light:hover{background:var(--bg-2)}
.btn-whats{background:var(--whatsapp);color:#06281a}
.btn-whats:hover{background:#1ec25d}
.btn-dark{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-dark:hover{background:#000}
.dark .btn-ghost{border-color:rgba(255,255,255,.15);color:#fff}
.dark .btn-ghost:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.3)}

/* ============ Card / Tag ============ */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-sm)}
.tag{display:inline-flex;align-items:center;gap:6px;height:24px;padding:0 9px;font-family:var(--f-mono);font-size:10.5px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;border-radius:4px;background:var(--bg-2);color:var(--ink-dim);border:1px solid var(--line)}
.tag.accent{background:var(--accent-soft);color:var(--accent);border-color:rgba(0,107,255,.2)}
.tag.ok{background:rgba(31,157,85,.1);color:var(--ok);border-color:rgba(31,157,85,.25)}
.tag.warn{background:rgba(201,122,16,.1);color:var(--warn);border-color:rgba(201,122,16,.25)}
.tag.bad{background:rgba(210,58,75,.1);color:var(--bad);border-color:rgba(210,58,75,.25)}
.tag.dark-tag{background:var(--ink);color:#fff;border-color:var(--ink)}
.tag .dot{width:6px;height:6px;border-radius:50%;background:currentColor}

/* ============ Bike stage ============ */
.bike-stage{position:relative;width:100%;aspect-ratio:16/10;border-radius:var(--r-lg);overflow:hidden;background:linear-gradient(180deg,#fafaf8 0%,#ececea 100%);display:grid;place-items:center}
.bike-stage.tall{aspect-ratio:4/3}
.bike-stage .glow{position:absolute;left:50%;top:65%;transform:translate(-50%,-50%);width:65%;height:35%;background:radial-gradient(ellipse,var(--accent-glow) 0%,transparent 70%);filter:blur(40px)}
.bike-stage svg{position:relative;width:88%;height:auto;z-index:1}
.bike-stage::after{content:"";position:absolute;left:6%;right:6%;bottom:6%;height:1px;background:linear-gradient(90deg,transparent,#bcbcbc 50%,transparent)}

/* concrete grunge accent backdrop */
.bike-stage.grunge{background:
  radial-gradient(ellipse at 30% 30%, rgba(255,255,255,.6), transparent 60%),
  linear-gradient(180deg,#e8e7e3 0%,#dad9d4 100%);
}
.bike-stage.grunge::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.55' numOctaves='3'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.08 0'/></filter><rect width='400' height='400' filter='url(%23n)'/></svg>");
  pointer-events:none;
}

/* ============ Spec row ============ */
.spec-row{display:grid;grid-template-columns:170px 1fr;gap:24px;padding:14px 0;border-bottom:1px dashed var(--line);align-items:baseline}
.spec-row:last-child{border-bottom:0}
.spec-row .key{font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute)}
.spec-row .val{color:var(--ink);font-size:14px}

/* ============ Form ============ */
.input,.textarea,.select{width:100%;height:48px;padding:0 14px;background:#fff;border:1px solid var(--line);border-radius:10px;color:var(--ink);font:inherit;transition:border .15s,box-shadow .15s}
.textarea{height:auto;padding:12px 14px;min-height:120px;resize:vertical;line-height:1.5}
.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.input::placeholder,.textarea::placeholder{color:var(--ink-mute)}
.field-label{display:block;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:8px;font-weight:500}
.field{display:flex;flex-direction:column}

/* ============ Section header ============ */
.sec-head{display:flex;justify-content:space-between;align-items:end;gap:32px;margin-bottom:48px;flex-wrap:wrap}
.sec-head h2{font-family:var(--f-display);font-size:54px;font-weight:700;letter-spacing:-.025em;line-height:1;text-wrap:balance;max-width:18ch;text-transform:uppercase}
.sec-head p{color:var(--ink-dim);max-width:46ch;font-size:15px}

@media (max-width:700px){
  .section{padding:64px 0}
  .section-sm{padding:40px 0}
  .sec-head h2{font-size:38px}
  .wrap, .wrap-narrow{padding:0 18px}
}

/* ============ Footer ============ */
.footer{background:var(--ink-soft);color:#bbb;padding:64px 0 24px;font-size:13.5px;position:relative;z-index:2}
.footer h4{font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#777;font-weight:500;margin-bottom:14px}
.footer a{display:block;padding:5px 0;color:#bbb;cursor:pointer}
.footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid #333}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-family:var(--f-mono);font-size:11px;color:#666;letter-spacing:.06em;flex-wrap:wrap;gap:16px;text-transform:uppercase}
.pay-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.pay-chip{background:#fff;color:#111;border-radius:5px;height:24px;padding:0 8px;display:grid;place-items:center;font-family:var(--f-display);font-size:10px;font-weight:700;letter-spacing:.04em}
.pay-chip.ideal{color:#CC0066}
.pay-chip.mollie{background:#1c5dff;color:#fff}
.pay-chip.applepay{background:#111;color:#fff;border:1px solid #fff}
.social-row{display:flex;gap:10px;margin-top:10px}
.social-row a{width:34px;height:34px;border-radius:8px;background:#222;display:grid;place-items:center;color:#bbb;padding:0}
.social-row a:hover{background:var(--accent);color:#fff}

@media (max-width:900px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}

/* ============ Cart drawer ============ */
.cart-overlay{position:fixed;inset:0;background:rgba(17,17,17,.55);z-index:90;animation:fadeIn .2s}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:min(440px,100vw);background:var(--paper);z-index:91;display:flex;flex-direction:column;box-shadow:-12px 0 32px rgba(0,0,0,.1);animation:slideR .28s ease}
.cart-head{padding:20px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line)}
.cart-head h3{font-family:var(--f-display);font-size:20px;text-transform:uppercase}
.cart-items{flex:1;overflow:auto;padding:8px}
.cart-row{display:grid;grid-template-columns:80px 1fr auto;gap:14px;padding:14px;border-bottom:1px solid var(--line-soft);align-items:center}
.cart-row:last-child{border-bottom:0}
.cart-thumb{width:80px;height:80px;border-radius:8px;background:linear-gradient(180deg,#fafaf8,#ebebe6);display:grid;place-items:center;overflow:hidden}
.cart-thumb svg{width:90%;height:auto}
.cart-row h4{font-family:var(--f-display);font-size:14px;font-weight:600;line-height:1.2;margin-bottom:4px}
.cart-row .meta{font-size:11.5px;color:var(--ink-mute);font-family:var(--f-mono);letter-spacing:.05em;margin-bottom:8px}
.qty-stepper{display:inline-flex;align-items:center;background:var(--bg);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.qty-stepper button{width:28px;height:28px;color:var(--ink-dim);font-size:14px;font-weight:600}
.qty-stepper span{width:28px;text-align:center;font-family:var(--f-mono);font-size:13px;font-weight:600}
.cart-foot{border-top:1px solid var(--line);padding:20px 24px;background:var(--bg);display:flex;flex-direction:column;gap:14px}
.cart-totals{display:flex;flex-direction:column;gap:6px;font-size:13.5px}
.cart-totals .row{display:flex;justify-content:space-between}
.cart-totals .row.total{font-family:var(--f-display);font-size:20px;font-weight:700;padding-top:10px;border-top:1px dashed var(--line);text-transform:uppercase}
.empty-cart{padding:60px 24px;text-align:center;color:var(--ink-dim)}

/* ============ Mobile sticky buy bar ============ */
.sticky-buy{display:none}
@media (max-width:780px){
  .sticky-buy{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:50;background:#fff;border-top:1px solid var(--line);padding:10px 12px;gap:8px;align-items:center;box-shadow:0 -4px 12px rgba(0,0,0,.06)}
  .sticky-buy .price{font-family:var(--f-display);font-weight:700;font-size:18px;margin-right:auto}
  .sticky-buy .btn{flex:1;height:48px}
  body.has-sticky-buy{padding-bottom:80px}
}

/* ============ Marquee ============ */
.marquee-wrap{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink);color:#fff;padding:18px 0;overflow:hidden}
.marquee{display:flex;gap:48px;color:#ddd;font-family:var(--f-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;white-space:nowrap;animation:slide 40s linear infinite}
.marquee .dot{color:var(--accent)}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-33.33%)}}

/* page fade */
.page{animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* product grid */
.prod-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:24px}
@media (max-width:1100px){.prod-grid{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:640px){.prod-grid{grid-template-columns:1fr;gap:16px}}

.prod-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s,border-color .15s;cursor:pointer}
.prod-card:hover{border-color:#bbb;box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.prod-card .stage{aspect-ratio:4/3;background:linear-gradient(180deg,#fafaf8,#ebebe6);position:relative;overflow:hidden;display:grid;place-items:center}
.prod-card .stage svg{width:90%;height:auto}
.prod-card .body{padding:20px;display:flex;flex-direction:column;gap:10px;flex:1}
.prod-card .body h3{font-family:var(--f-display);font-size:22px;text-transform:uppercase;letter-spacing:-.01em}
.prod-card .body .desc{font-size:13px;color:var(--ink-dim);min-height:38px}
.prod-card .body .price-row{display:flex;align-items:baseline;gap:10px;margin-top:auto;padding-top:8px}
.prod-card .body .price{font-family:var(--f-display);font-size:24px;font-weight:700}
.prod-card .body .old{font-size:13px;color:var(--ink-mute);text-decoration:line-through}
.prod-card .body .ctas{display:flex;gap:8px;margin-top:14px}

/* hero number list */
.stat-num{font-family:var(--f-display);font-size:28px;font-weight:700;letter-spacing:-.01em}
.stat-lbl{font-family:var(--f-mono);font-size:11px;color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase;margin-top:3px}

/* compliance strip */
.compliance{background:var(--ink);color:#ccc;font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;padding:7px 28px;text-align:center;border-bottom:1px solid #000}
.compliance .accent{color:var(--accent)}

/* Floating Whatsapp */
.fab{position:fixed;bottom:24px;right:24px;width:58px;height:58px;border-radius:50%;background:var(--whatsapp);display:grid;place-items:center;box-shadow:0 12px 32px rgba(37,211,102,.4);z-index:60;cursor:pointer;color:#fff;transition:transform .15s}
.fab:hover{transform:scale(1.06)}
@media (max-width:780px){.fab{bottom:84px}}

/* ============ Bike photo placeholder (image-slot wrapper) ============ */
.bike-photo{
  position:relative;width:100%;aspect-ratio:4/3;
  background:linear-gradient(180deg,#ffffff 0%,#eeede9 100%);
  border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;
  display:grid;place-items:center;
}
.bike-photo image-slot{ --img-bg: transparent; width:100% !important; height:100% !important; }
/* Subtle floor shadow */
.bike-photo::after{
  content:"";position:absolute;left:10%;right:10%;bottom:8%;height:14px;
  background:radial-gradient(ellipse at 50% 0,rgba(0,0,0,.15),transparent 70%);
  z-index:0;pointer-events:none;
}
.bike-photo-badge{
  position:absolute;top:14px;left:14px;z-index:3;pointer-events:none;
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 9px;background:rgba(17,17,17,0.9);color:#fff;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;border-radius:4px;
}
.bike-photo-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}

/* Verberg het gele demo-label */
.demo-badge{
  display:none !important;
  visibility:hidden !important;
  opacity:0 !important;
}

/* ============ Bike Gallery ============ */
.bike-gallery{display:flex;flex-direction:column;gap:12px}
.gallery-stage{
  position:relative;width:100%;aspect-ratio:4/3;border-radius:var(--r-md);overflow:hidden;
  background:linear-gradient(180deg,#ffffff 0%,#eeede9 100%);
  border:1px solid var(--line);
}
.gallery-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:contain;padding:5%;
  opacity:0;transition:opacity .35s ease;
  user-select:none;-webkit-user-drag:none;
  pointer-events:none;
}
.gallery-img.is-active{opacity:1;pointer-events:auto}
.gallery-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,0.92);
  border:1px solid var(--line);
  display:grid;place-items:center;cursor:pointer;
  box-shadow:0 4px 14px rgba(0,0,0,.08);
  transition:background .15s, transform .12s;
  color:var(--ink);z-index:4;
}
.gallery-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.06)}
.gallery-arrow:active{transform:translateY(-50%) scale(.96)}
.gallery-arrow.prev{left:14px}
.gallery-arrow.next{right:14px}
.gallery-counter{
  position:absolute;bottom:12px;left:12px;z-index:3;
  padding:5px 10px;background:rgba(17,17,17,.85);color:#fff;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;border-radius:4px;
}
.gallery-thumbs{
  display:grid;grid-template-columns:repeat(auto-fill, minmax(72px, 1fr));gap:8px;
}
.gallery-thumb{
  aspect-ratio:1/1;background:linear-gradient(180deg,#fafaf8,#ebebe6);
  border:1px solid var(--line);border-radius:8px;
  padding:6px;cursor:pointer;overflow:hidden;
  transition:border-color .12s, transform .12s;
}
.gallery-thumb img{width:100%;height:100%;object-fit:contain}
.gallery-thumb:hover{border-color:#aaa}
.gallery-thumb.is-active{border:2px solid var(--accent);padding:5px}
@media (max-width:780px){
  .gallery-thumbs{grid-template-columns:repeat(auto-fill, minmax(60px, 1fr))}
  .gallery-arrow{width:42px;height:42px;left:8px}
  .gallery-arrow.next{right:8px;left:auto}
}
/* Variant: large hero */
.bike-photo.hero{aspect-ratio:16/11}
.bike-photo.tall{aspect-ratio:4/5}
.bike-photo.thumb{aspect-ratio:1/1}
.bike-photo.thumb .bike-photo-badge{display:none}

/* ============ Quantity stepper (product page) ============ */
.qty-big{display:inline-flex;align-items:center;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;height:54px}
.qty-big button{width:46px;height:54px;color:var(--ink);font-size:18px;font-weight:600;transition:background .12s}
.qty-big button:hover{background:var(--bg)}
.qty-big span{width:34px;text-align:center;font-family:var(--f-display);font-weight:700;font-size:17px}
/* utility */

.gap-12{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.gap-8{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4, 1fr);gap:16px}
@media (max-width:900px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr 1fr;gap:16px}}
@media (max-width:560px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* Hide on mobile / desktop */
.hide-mobile{display:initial}
.show-mobile{display:none}
@media (max-width:780px){.hide-mobile{display:none}.show-mobile{display:initial}}
/* Demo-label extra verbergen */
.demo-badge{
  display:none !important;
  visibility:hidden !important;
  opacity:0 !important;
}

/* ============ DARK THEME ============ */
/* Activated via [data-theme="dark"] on <html>. All design tokens flip;
   component styles using var(--…) inherit the new palette automatically. */
:root[data-theme="dark"] {
  --bg:#0f1012;
  --bg-2:#161719;
  --paper:#1c1d20;
  --ink:#f1f1ef;
  --ink-soft:#e8e8e6;
  --ink-dim:#b9b9b6;
  --ink-mute:#888885;
  --line:#2b2c30;
  --line-soft:#222328;
  --accent:#3d8bff;
  --accent-hover:#5fa3ff;
  --accent-soft:rgba(61,139,255,0.12);
  --accent-glow:rgba(61,139,255,0.25);
  --ok:#3ad07b;
  --warn:#ffb648;
  --bad:#ff6273;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.40);
  --shadow: 0 2px 10px rgba(0,0,0,.45);
  --shadow-lg: 0 10px 36px rgba(0,0,0,.55);
}
:root[data-theme="dark"] body::before{ opacity:.15 }
:root[data-theme="dark"] ::-webkit-scrollbar-track{background:#16171a}
:root[data-theme="dark"] ::-webkit-scrollbar-thumb{background:#3a3b3f}
:root[data-theme="dark"] ::-webkit-scrollbar-thumb:hover{background:#52535a}

/* Keep the existing inverted footer (`.dark` class) darker than the page
   in dark mode too, so it still reads as a separate band. */
:root[data-theme="dark"] .dark{background:#08080a;color:#e8e8e6}

/* Inputs, cards and form controls reference --paper/--line via tokens so they
   pick up dark automatically, but a few have hardcoded #fff backgrounds in
   inline styles. These rules catch the common cases. */
:root[data-theme="dark"] input,
:root[data-theme="dark"] select,
:root[data-theme="dark"] textarea{
  background:var(--paper);
  color:var(--ink);
  border-color:var(--line);
}
:root[data-theme="dark"] input::placeholder,
:root[data-theme="dark"] textarea::placeholder{ color:var(--ink-mute) }

/* Bike photo gradient backgrounds — soften them on dark so product photos
   on white backgrounds aren't blinding next to the dark UI. */
:root[data-theme="dark"] .gallery-stage,
:root[data-theme="dark"] .gallery-thumb{
  background:linear-gradient(180deg,#23252a 0%,#15161a 100%) !important;
  border-color:var(--line);
}

/* Compliance bar contrast on dark */
:root[data-theme="dark"] .compliance{ color:var(--ink-dim) }

/* Pay chips, tags — make sure plain "white" backgrounds become paper. */
:root[data-theme="dark"] .pay-chip{ background:#2a2b2f; color:var(--ink) }
:root[data-theme="dark"] .pay-chip.ideal{ background:#cc0066; color:#fff }
:root[data-theme="dark"] .pay-chip.mollie{ background:#1c5dff; color:#fff }
:root[data-theme="dark"] .pay-chip.applepay{ background:#000; color:#fff }

/* Cart overlay slightly more transparent so dark cards still stand out */
:root[data-theme="dark"] .cart-overlay,
:root[data-theme="dark"] .mob-overlay{ background:rgba(0,0,0,.65) }

/* Tags */
:root[data-theme="dark"] .tag.dark-tag{ background:#000; color:#fff }
:root[data-theme="dark"] .tag.ok{ background:rgba(58,208,123,.18); color:#9be3b6 }
:root[data-theme="dark"] .tag.warn{ background:rgba(255,182,72,.18); color:#ffd58a }

/* Theme & language toggle buttons in nav */
.nav-toggle-btn{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 10px; border-radius:8px;
  font-size:12.5px; font-weight:600; line-height:1;
  background:transparent; color:var(--ink);
  border:1px solid var(--line);
  transition:background .12s, border-color .12s, color .12s;
  cursor:pointer;
}
.nav-toggle-btn:hover{ background:var(--bg-2); border-color:var(--ink-mute) }
.nav-toggle-btn .flag{ font-size:14px; line-height:1 }
:root[data-theme="dark"] .nav-toggle-btn{ background:var(--paper) }
:root[data-theme="dark"] .nav-toggle-btn:hover{ background:var(--bg-2) }

/* ============ DARK THEME — Button/Input/Card contrast fixes ============ */
/* Light-mode btn-primary uses var(--ink) for background. In dark mode,
   --ink becomes light → light background + white text = unreadable. The
   rules below explicitly set legible color pairs for each button class
   when dark theme is active. */
:root[data-theme="dark"] .btn-primary{
  background:#f1f1ef; color:#0f1012; border-color:#f1f1ef;
}
:root[data-theme="dark"] .btn-primary:hover{
  background:#ffffff; border-color:#ffffff;
}
:root[data-theme="dark"] .btn-light{
  background:var(--paper); color:var(--ink); border-color:var(--line);
}
:root[data-theme="dark"] .btn-light:hover{
  background:var(--bg-2); border-color:var(--ink-mute);
}
:root[data-theme="dark"] .btn-dark{
  background:#000; color:#fff; border-color:#000;
}
:root[data-theme="dark"] .btn-dark:hover{
  background:#161617;
}
/* btn-accent: same blue accent, slightly brighter on dark for contrast */
:root[data-theme="dark"] .btn-accent{
  background:var(--accent); color:#fff;
}
:root[data-theme="dark"] .btn-accent:hover{
  background:var(--accent-hover);
}
:root[data-theme="dark"] .btn-ghost{
  background:transparent; color:var(--ink); border-color:var(--line);
}
:root[data-theme="dark"] .btn-ghost:hover{
  background:rgba(255,255,255,.06); border-color:var(--ink-mute);
}
:root[data-theme="dark"] .btn-whats{
  background:var(--whatsapp); color:#06281a;
}
/* nav-link buttons (in header) */
:root[data-theme="dark"] .nav-links button{ color:var(--ink) }
:root[data-theme="dark"] .nav-links button:hover,
:root[data-theme="dark"] .nav-links button.active{ color:var(--accent) }
/* icon buttons */
:root[data-theme="dark"] .icon-btn{ color:var(--ink) }
:root[data-theme="dark"] .icon-btn:hover{ background:var(--bg-2) }
/* mobile menu */
:root[data-theme="dark"] .mob-panel{ background:var(--paper); color:var(--ink) }
:root[data-theme="dark"] .mob-panel header,
:root[data-theme="dark"] .mob-panel footer{ border-color:var(--line) }
:root[data-theme="dark"] .mob-panel nav button{ color:var(--ink) }
:root[data-theme="dark"] .mob-panel nav button:hover,
:root[data-theme="dark"] .mob-panel nav button.active{ background:var(--bg-2); color:var(--accent) }
/* Cart drawer */
:root[data-theme="dark"] .cart-drawer{ background:var(--paper); color:var(--ink); box-shadow:-12px 0 32px rgba(0,0,0,.55) }
:root[data-theme="dark"] .cart-drawer .cart-head,
:root[data-theme="dark"] .cart-drawer .cart-foot{ border-color:var(--line) }
:root[data-theme="dark"] .cart-row{ border-color:var(--line) }
:root[data-theme="dark"] .qty-stepper,
:root[data-theme="dark"] .qty-big{ background:var(--paper); border-color:var(--line); color:var(--ink) }
:root[data-theme="dark"] .qty-stepper button,
:root[data-theme="dark"] .qty-big button{ color:var(--ink) }
:root[data-theme="dark"] .qty-stepper button:hover,
:root[data-theme="dark"] .qty-big button:hover{ background:var(--bg-2) }
/* Cards */
:root[data-theme="dark"] .card{ background:var(--paper); border-color:var(--line); color:var(--ink) }
/* Inputs / textarea / select */
:root[data-theme="dark"] .input,
:root[data-theme="dark"] .textarea,
:root[data-theme="dark"] .select{
  background:var(--paper); color:var(--ink); border-color:var(--line);
}
:root[data-theme="dark"] .input:focus,
:root[data-theme="dark"] .textarea:focus,
:root[data-theme="dark"] .select:focus{
  border-color:var(--accent); box-shadow:0 0 0 4px var(--accent-soft);
}
:root[data-theme="dark"] .input::placeholder,
:root[data-theme="dark"] .textarea::placeholder{ color:var(--ink-mute) }
:root[data-theme="dark"] .field-label{ color:var(--ink-dim) }
/* Tags */
:root[data-theme="dark"] .tag{
  background:var(--bg-2); color:var(--ink-dim); border-color:var(--line);
}
:root[data-theme="dark"] .tag.accent{
  background:rgba(61,139,255,.18); color:#7cb0ff; border-color:rgba(61,139,255,.32);
}
:root[data-theme="dark"] .tag.bad{
  background:rgba(255,98,115,.18); color:#ff9aa6; border-color:rgba(255,98,115,.32);
}
/* Section backgrounds: a few pages use background:"var(--paper)" inline.
   Compliance bar etc inherit OK. The body::before noise overlay is muted
   above. Ensure breadcrumb, sticky-buy and other slabs read on dark. */
:root[data-theme="dark"] .sticky-buy{ background:var(--paper); border-color:var(--line); color:var(--ink); box-shadow:0 -8px 24px rgba(0,0,0,.5) }
/* Modal overlay used by login modal: keep dark but ensure card is paper */
:root[data-theme="dark"] [role="dialog"]{ background:var(--paper); color:var(--ink) }
/* Bike photo placeholder badge */
:root[data-theme="dark"] .bike-photo-badge{ background:rgba(0,0,0,.85); color:#fff }
/* Footer text already dark by design (.footer.dark style), but ensure
   in-dark-mode it doesn't get black-on-black */
:root[data-theme="dark"] .footer{ background:#08080a; color:#cfcfcd }
:root[data-theme="dark"] .footer a:hover{ color:#fff }
/* SecHead h2 reads --ink, fine. Ensure links inside cards stay visible. */
:root[data-theme="dark"] a.accent,
:root[data-theme="dark"] .accent{ color:var(--accent) }
/* Account / admin specific small text fixes */
:root[data-theme="dark"] .empty-cart{ color:var(--ink-dim) }
/* Eyebrow accent override for visibility on dark */
:root[data-theme="dark"] .eyebrow{ color:var(--accent) }
:root[data-theme="dark"] .eyebrow.muted{ color:var(--ink-mute) }
