/* Kill v1 header zodra v2 bestaat */
.hv-header{ display:none !important; }
#site-header.hv-header{ display:none !important; }

/* Zorg dat v2 altijd zichtbaar is */
.hv2-header{ display:block; }

:root { 
--bg: #05070f; 
--panel: #0c1224; 
--surface: #0f172a; 
--card: #111a31; 
--muted: #9fb0d4; 
--text: #e9eefc; 
--accent: #FAB819; 
--accent-2: #f4a261; 
--border: rgba(255,255,255,0.08); 
--radius: 14px; --shadow: 0 30px 80px rgba(5, 9, 22, 0.6); 
--max: 1200px; 
--font: 'Manrope','Inter','Segoe UI','Helvetica Neue',Arial,sans-serif; 
--hv-header-h: 88px;
--hv-header-bg: rgba(8,14,26,0.75);
--hv-header-blur: 10px;
} 

* { box-sizing: border-box; } 
html { scroll-behavior: smooth; 
} 

:root {
  /* Header sizing (NIEUW) */
  --header-pad-y:16px;
  --header-pad-x:28px;
  --logo-h:98px;           /* jouw huidige waarde */
  --logo-pad:14px;
  --logo-radius:21px;

  /* Shrink op scroll (NIEUW) */
  --header-pad-y-scrolled:8px;
  --logo-h-scrolled:44px;

  /* Mobiel (NIEUW) */
  --header-pad-y-mobile:12px;
  --header-pad-x-mobile:14px;
  --logo-h-mobile:56px;

  --header-pad-y-mobile-scrolled:6px;
  --logo-h-mobile-scrolled:34px;
}

/* =========================
   Reset / global
========================= */
*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body { 
--hv2-header-h: 72px;
--hv2-header-gap: 12px;
--hv2-header-offset: calc(var(--hv2-header-h) + var(--hv2-header-gap));
scroll-padding-top: var(--hv2-header-offset);
margin: 0; 
font-family: var(--font); 
background: radial-gradient(circle at 10% 10%, rgba(88,213,255,0.08), transparent 30%), radial-gradient(circle at 80% 0%, rgba(244,162,97,0.08), transparent 35%), var(--bg); 
color: var(--text); 
line-height: 1.6; 
min-height: 100vh; 
} 

a { color: var(--accent); 
text-decoration: none; 
} 

a:hover { color: #c0e9ff; } 
img { max-width: 100%; display: block; 
} 

.wrap { width: min(100%, var(--max)); margin: 0 auto; padding: 0 20px; 
} 

section { padding: 64px 0; } 
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; 
padding: 12px 18px; border-radius: 999px; 
background: linear-gradient(120deg, var(--accent), #FAB819); 
color: #04101f; 
font-weight: 700; 
border: 1px solid transparent; 
cursor: pointer; transition: transform .15s ease, box-shadow .15s ease, background .15s ease; 
text-decoration: none; box-shadow: 0 12px 30px rgba(250,184,25,0.35); 
} 

.btn:hover { transform: translateY(-1px); } 

.btn:active { transform: translateY(0); } 

.btn.btn-ghost { 
background: transparent; 
color: var(--text); 
border: 1px solid var(--border); box-shadow: none; 
} 

.btn.btn-ghost:hover { 
border-color: rgba(255,255,255,0.3); 
} 

.eyebrow { display: inline-flex; align-items: center; gap: 8px; 
padding: 6px 12px; 
margin-top: 16px; 
margin-bottom: 16px; border-radius: 999px; 
background: rgba(88,213,255,0.12); 
color: #c8edff; 
text-transform: uppercase; 
font-size: 12px; 
letter-spacing: 0.12em; 
font-weight: 700; 
} 

h1, h2, h3, h4 { 
margin: 0 0 12px; 
line-height: 1.2; 
color: #f6f8ff; } p { 
margin: 0 0 16px; 
color: var(--muted); 
} 

h1 span { 
display: block; 
} 

/* Header */ 
.site-header { 
position: sticky; 
top: 0; 
z-index: 20; backdrop-filter: blur(14px); 
background: rgba(5, 7, 15, 0.75); 
border-bottom: 1px solid var(--border); 
} 

.nav-shell { 
width: 100%; 
padding: 16px 28px; 
display: grid; grid-template-columns: auto 1fr auto; gap: 18px; align-items: center; 
} 

.brand { 
display: inline-flex; gap: 12px; align-items: center; 
color: #f6f8ff; 
text-decoration: none; } 

.brand-logo { 
height: 98px; 
width: auto; border-radius: 21px; 
background: rgba(255,255,255,0.06); 
padding: 14px; } 

.nav { display: flex; align-items: center; justify-content: flex-start; } 

.nav-list { display: flex; gap: 20px; list-style: none; margin: 0; padding: 0; align-items: center; flex-wrap: nowrap; } 

.nav-link { color: #f6f8ff; padding: 18px 24px; border-radius: 12px; display: inline-flex; align-items: center; gap: 10px; font-weight: 700; white-space: nowrap; font-size: 1.0rem; } 

.nav-link:hover { background: rgba(255,255,255,0.06); } 

.nav-toggle-cta { background: rgba(255,255,255,0.06); border: 1px solid var(--border); color: #f6f8ff; cursor: pointer; } 

.nav-toggle-cta:hover { background: rgba(255,255,255,0.12); } 

.nav-item-mega { position: relative; } 

.mega-panel { 
position: absolute; 
top: calc(100% + 8px); 
left: 0; 
min-width: 820px; 
width: min(100vw - 32px, 980px); 
background: var(--surface); 
border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); 
padding: 18px; opacity: 0; pointer-events: none; transform: translateY(8px); transition: all .18s ease; 
z-index: 30; 
} 

.mega-panel[hidden] { display: none; } 

.mega-inner { display: block; } 

.mega-col h3 { margin: 0 0 8px; font-size: 14px; color: var(--muted); } 

.mega-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 6px; grid-template-columns: repeat(4, minmax(0, 1fr)); max-height: 320px; overflow: auto; } 

.mega-list a { color: #f6f8ff; display: block; padding: 8px 10px; border-radius: 8px; background: rgba(255,255,255,0.04); } 

.mega-list a.is-active { background: rgba(250, 184, 25, 0.2); color: #fff; } 

.mega-list a:hover { background: rgba(88,213,255,0.14); color: #eaf8ff; } 

.nav-item-mega.is-open .mega-panel { opacity: 1; pointer-events: auto; transform: translateY(0); } 

/* Force-close mega panels only when explicitly requested */
.site-header.nav-force-close .mega-panel,
.site-header.nav-force-close .hv-mega-panel{
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
}

@media (max-width: 1100px){
  .mega-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 720px){
  .mega-list { grid-template-columns: 1fr; }
}
.mega-list { grid-template-columns: repeat(2, minmax(0, 1fr)); } } @media (max-width: 720px) { 

.mega-list { grid-template-columns: 1fr; } } 

.nav-cta { display: flex; align-items: center; gap: 10px; justify-content: flex-end; }

.platebar { display: flex; align-items: center; gap: 10px; justify-self: end; }
.nav-shell .platebar { justify-self: end; }

/* =========================
   Header V2 – basis (fixed + offset)
   ========================= */
  .hv2-header{
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10020;
    backdrop-filter: blur(var(--hv-header-blur));
    -webkit-backdrop-filter: blur(var(--hv-header-blur));
    background: var(--hv-header-bg);
    border-bottom: 1px solid rgba(255,255,255,0.08);
    transition: padding .16s ease, min-height .16s ease, background .16s ease;
    --hv2-logo-h: 48px;
    --hv2-logo-h-scrolled: 32px;
  }
  .hv2-header.is-stuck{
    background: rgba(12,14,18,0.88);
  }
  
  #site-header{
    min-height: var(--hv-header-h, 88px);
    overflow: visible;
  }
  
  #site-header ~ main,
  #site-header ~ .page-main{
    padding-top: var(--hv-header-h, 88px);
  }
  
  .header-inner{
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 16px;
    padding: 12px 16px;
    min-height: 74px;
    transition: padding .16s ease, min-height .16s ease;
  }

  /* V1 logo + megamenu terug in hv2 */
  #site-header .hv2-header .brand{
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: #f6f8ff;
    text-decoration: none;
  }
  #site-header .hv2-header .brand-logo{
  width: auto;
  background: rgba(255,255,255,0.06);

  /* allow global calc() to drive these */
  height: auto;
  padding: 0;
  border-radius: 0;
}

  .hv2-drawer-close{
    position: absolute;
    top: 12px;
    right: 12px;
    width: 40px;
    height: 40px;
    border: 0;
    border-radius: 999px;
    background: rgba(255,255,255,0.08);
    color: #f6f8ff;
    display: grid;
    place-items: center;
    cursor: pointer;
    z-index: 2;
  }
  .hv2-drawer-close:hover{ background: rgba(255,255,255,0.16); }
  .hv2-drawer-close:focus-visible{
    outline: 2px solid var(--accent);
    outline-offset: 2px;
  }
  .hv2-drawer-close span{
    position: relative;
    width: 18px;
    height: 18px;
    display: block;
  }
  .hv2-drawer-close span::before,
  .hv2-drawer-close span::after{
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 18px;
    height: 2px;
    background: currentColor;
    transform-origin: center;
  }
  .hv2-drawer-close span::before{ transform: translate(-50%, -50%) rotate(45deg); }
  .hv2-drawer-close span::after{ transform: translate(-50%, -50%) rotate(-45deg); }

@media (min-width: 1024px){
  .hv2-drawer-close{ display: inline-flex; }
}
  .hv2-drawer-close{ display: none; }

  #site-header .hv2-header .nav-shell{
    width: 100%;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }
  #site-header .hv2-header .nav{
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
  }
  #site-header .hv2-header .nav-list{
    display: flex;
    gap: 12px;
    list-style: none;
    margin: 0;
    padding: 0;
    align-items: center;
    flex-wrap: wrap;
  }
  #site-header .hv2-header .nav-link{
    color: #f6f8ff;
    padding: 12px 16px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    white-space: nowrap;
    font-size: 0.98rem;
  }
  #site-header .hv2-header .nav-link:hover{
    background: rgba(255,255,255,0.06);
  }
  #site-header .hv2-header .nav-toggle-cta{
    background: rgba(255,255,255,0.06);
    border: 1px solid var(--border);
    cursor: pointer;
  }
  
  /* =========================
     Header zones
     ========================= */
  .header-left{
    display: flex;
    align-items: center;
    z-index: 3;
    flex: 0 0 auto;
  }

  .header-center{
    display: flex;
    justify-content: center;
    min-width: 0;
    z-index: 2;
  }

  .header-right{
    display: flex;
    align-items: center;
    z-index: 3;
    flex: 0 0 auto;
    gap: 12px;
  }

  .hv2-nav-wrap{
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    justify-content: center;
  }
  
  /* =========================
     Logo (V1-look)
     ========================= */
.hv2-logo{
  height: var(--hv2-logo-h);
  width: auto;
  max-height: var(--hv2-logo-h);
  object-fit: contain;
  transition: height .16s ease, max-height .16s ease;
}
  
  /* =========================
     Navigatie – desktop (V1-look)
     ========================= */
  .hv2-nav-layer{
    display: block;
    position: static;
    width: 100%;
    min-width: 0;
  }
  
  .nav-overlay{
    display: none;
  }
  
  .nav-drawer{
    position: static;
    transform: none;
    visibility: visible;
  }
  
  .hv2-nav{
    display: flex;
    min-width: 0;
    overflow: hidden;
  }

  .hv2-nav-link--utility{
    padding-inline: 10px;
    font-size: 0.95rem;
    font-weight: 500;
  }

  .hv2-top{
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: nowrap;
    white-space: nowrap;
  }
  
  .hv2-top > li > a{
    font-weight: 500;
    white-space: nowrap;
  }

  .hv2-nav a{
    white-space: nowrap;
  }
  
  /* =========================
     Burger alleen mobiel
     ========================= */
  .hv2-burger{
    display: none;
  }
  
  /* =========================
     Mobiel gedrag (V2 intact)
     ========================= */
  @media (max-width: 1024px){
    .header-inner{
      grid-template-columns: auto auto;
    }
  
    .header-center{
      display: none;
    }
  
    .hv2-burger{
      display: inline-flex;
    }
  }
  
/* Desktop nav: gewoon inline, geen drawer */
@media (min-width: 1024px){
  .hv2-nav-layer{ position: static; pointer-events: auto; }
  .nav-overlay{ display: none; }
  .nav-drawer{ position: static; background: transparent; padding: 0; box-shadow: none; border: 0; transform: none; }
  .hv2-nav{ display: flex; }
  .hv2-top{ display: flex; align-items: center; gap: 20px; }
}

.header-right{
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: flex-end;
}
.header-actions{
  display: flex;
  align-items: center;
  gap: 12px;
}
.hv2-plate{
  flex: 0 0 220px;
  max-width: 220px;
}
.hv2-header .plate-search{
  display: inline-flex;
  align-items: center;
  width: 100%;
  max-width: 220px;
  min-width: 0;
}
.hv2-header .plate-ui{
  display: inline-flex;
  align-items: center;
  gap: 0px;
  height: 44px;
  width: 100%;
  border-radius: 10px;
  background: #f2c200;
  border: 1px solid rgba(0,0,0,.18);
  box-shadow: 0 2px 10px rgba(0,0,0,.25);
  overflow: hidden;
  padding: 0;
}
.hv2-header .plate-eu{
  position: static;
  flex: 0 0 44px;
  width: 44px;
  height: 100%;
  background: #0b4ea2;
  color: #fff;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: .08em;
  font-size: 12px;
}
.hv2-header .plate-input{
  flex: 1 1 auto;
  min-width: 0;
  width: auto;
  height: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  font-weight: 800;
  font-size: 15px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #111;
  text-align: center;
  padding: 0 10px;
}
.hv2-header .plate-input::placeholder{
  color: rgba(0,0,0,.45);
  font-weight: 700;
  letter-spacing: .10em;
}
.hv2-header .plate-button{
  position: static;
  right: auto;
  top: auto;
  transform: none;
  flex: 0 0 auto;
  height: 100%;
  min-width: 36px;
  border: 0;
  border-radius: 0 10px 10px 0;
  background: rgba(0,0,0,.15);
  color: #111;
  font-weight: 700;
  font-size: 11px;
  padding: 0 8px;
  cursor: pointer;
}
.hv2-header .plate-button:hover{
  background: rgba(0,0,0,.22);
}
.hv2-cta-group{
  display: flex;
  align-items: center;
  gap: 10px;
  white-space: nowrap;
}
.hv2-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.06);
  color: #f6f8ff;
  font-weight: 600;
  font-size: 0.85rem;
  text-decoration: none;
  line-height: 1;
}
.hv2-btn:hover{ background: rgba(255,255,255,0.12); }
.hv2-btn:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.hv2-btn-primary{
  background: linear-gradient(120deg, var(--accent), #FAB819);
  color: #111;
  border-color: transparent;
  box-shadow: 0 10px 24px rgba(250,184,25,0.35);
}
.hv2-btn-primary:hover{
  background: linear-gradient(120deg, var(--accent), #FAB819);
  color: #fff;
}
.hv2-btn-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
}
.hv2-btn-icon svg{
  width: 18px;
  height: 18px;
  fill: currentColor;
}
.hv2-btn-label{ display: inline-flex; }
.hv2-btn-sub{
  display: inline-flex;
  font-weight: 600;
  color: #d7e7ff;
}
.hv2-burger{
  display: none;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.06);
  color: #f6f8ff;
  font-weight: 700;
  cursor: pointer;
}
.hv2-burger:hover{ background: rgba(255,255,255,0.12); }
.hv2-burger:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
body.nav-open{ overflow: hidden; }

@media (max-width: 1279px){
  body{
    --hv2-header-h: 68px;
    --hv2-header-gap: 10px;
  }
  .header-inner{ gap: 14px; padding: 10px 16px; }
  .hv2-top{ gap: 12px; }
  .hv2-plate{ flex-basis: 200px; max-width: 200px; }
  .hv2-header .plate-search{ max-width: 200px; }
  .hv2-cta-group .hv2-btn-label,
  .hv2-cta-group .hv2-btn-sub{ display: none; }
  .hv2-btn{ min-width: 36px; padding: 0 10px; }
}

@media (max-width: 1023px){
  body{
    --hv2-header-h: 64px;
    --hv2-header-gap: 8px;
  }
  .header-inner{ gap: 12px; padding: 8px 16px; }
  .header-left{
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .header-left .brand{
    display: inline-flex;
    align-items: center;
  }
  .hv2-burger{ display: inline-flex; }
  .hv2-cta-group{ display: none; }
  .hv2-plate{ flex-basis: 200px; max-width: 220px; width: 100%; }
  .hv2-header .plate-search{
    width: 100%;
    max-width: 220px;
  }
  .hv2-nav-layer{
    position: fixed;
    inset: 0;
    z-index: 12010;
    pointer-events: none;
    display: block;
  }
  .nav-overlay{
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(8, 12, 20, 0.75);
    opacity: 0;
    transition: opacity .2s ease;
    pointer-events: none;
    z-index: 12020;
  }
  .nav-drawer{
    position: fixed;
    top: 0;
    right: 0;
    left: auto;
    height: 100dvh;
    width: min(92vw, 380px);
    background: var(--surface);
    border-left: 1px solid var(--border);
    padding: 56px 16px 24px;
    transform: translateX(100%);
    transition: transform .22s ease;
    box-shadow: 0 20px 50px rgba(0,0,0,0.35);
    overflow-y: auto;
    overflow-x: hidden;
    z-index: 12030;
    visibility: hidden;
    display: flex;
    flex-direction: column;
  }
  .nav-drawer,
  .nav-drawer *{
    box-sizing: border-box;
  }
  .nav-drawer .nav-shell,
  .nav-drawer .hv2-nav,
  .nav-drawer .nav-list,
  .nav-drawer .mega-panel,
  .nav-drawer .mega-inner,
  .nav-drawer .mega-col{
    overflow-x: hidden;
    width: 100%;
    max-width: 100%;
  }
  .nav-drawer .nav-list a,
  .nav-drawer .nav-list button,
  .nav-drawer .mega-list a{
    width: 100%;
    max-width: 100%;
  }
  #site-header .hv2-header .nav-item,
  #site-header .hv2-header .nav-item-mega{
    width: 100%;
  }
  #site-header .hv2-header .nav-shell{
    width: 100%;
    padding: 0;
    justify-content: flex-start;
  }
  #site-header .hv2-header .nav-list{
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  #site-header .hv2-header .nav-link{
    width: 100%;
    justify-content: space-between;
  }
  body.nav-open .hv2-nav-layer{ pointer-events: auto; }
  body.nav-open .nav-overlay{
    opacity: 1;
    pointer-events: auto;
  }
  body.nav-open .nav-drawer{ transform: translateX(0); visibility: visible; }
  body.nav-open .plate-search,
  #site-header .hv2-header.hv2-open .plate-search{
    position: relative;
    z-index: 0 !important;
  }
  body.nav-open .hv2-burger{
    visibility: hidden;
    pointer-events: none;
  }

  #site-header .nav-drawer .nav-list{
    max-height: none;
    overflow: visible;
  }

  .hv2-top{
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
}

/* =========================
   MEGA PANEL: DESKTOP vs MOBILE
   ========================= */
@media (max-width: 1023px){
  /* Desktop-float uitschakelen op mobiel */
  .hv-mega-panel,
  .mega-panel{
    position: static !important;
    inset: auto !important;
    transform: none !important;
    width: 100% !important;
    max-height: none !important;
    overflow: visible !important;
    box-shadow: none !important;
    border: 0 !important;
    margin-top: 10px;
    padding: 0;
  }

  /* Hidden attribute echt verbergen */
  .hv-mega-panel[hidden],
  .mega-panel[hidden]{
    display: none !important;
  }

  /* In drawer: lijst scrollbaar indien lang */
  [data-hv2-drawer] .mega-list,
  [data-hv2-drawer] .hv-mega-list{
    max-height: 60dvh;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    padding: 0;
    margin: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    grid-template-columns: 1fr;
    justify-items: stretch;
    align-content: start;
  }
  [data-hv2-drawer] .mega-list a,
  [data-hv2-drawer] .hv-mega-list a{
    width: 100%;
    max-width: 100%;
    white-space: normal;
    text-align: center;
    overflow-wrap: anywhere;
  }
  [data-hv2-drawer] .mega-inner,
  [data-hv2-drawer] .mega-col{
    padding: 0;
    margin: 0;
  }
}

/* Zorg overlay/drawer boven header-content liggen */
.hv2-header [data-hv2-overlay]{ z-index: 11990; }
.hv2-header [data-hv2-drawer]{ z-index: 12000; }
.hv2-header{ position: relative; z-index: 1; }
body.nav-open .plate-search,
.hv2-header.hv2-open .plate-search{
  position: relative;
  z-index: 0;
}
/* baseline z-index laag houden */
.plate-search{ position: relative; z-index: 10; }

/* Contact stack */
.hv2-contact-stack{
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: stretch;
}
.hv2-contact-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  min-width: 170px;
  padding: 0 12px;
}
.hv2-contact-btn svg{
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

.hv2-header.is-scrolled .header-inner{
  padding: 8px 14px;
  min-height: 64px;
}

/* Scroll shrink driven by the calc() on .brand-logo */
.hv2-header { --header-shrink: 0; }
.hv2-header.is-scrolled { --header-shrink: 1; }

/* Smooth animation */
.hv2-header .brand-logo{
  transition: height .18s ease, padding .18s ease, border-radius .18s ease;
}


@media (max-width: 1024px){
  .site-header.hv-header .plate-search{
    width: 100%;
    justify-content: flex-start;
    margin-left: 0;
  }
  .platebar{ width: 100%; justify-content: flex-start; }
  .plate-search{ width: 100%; }
  .plate-ui{ width: 100%; max-width: 280px; }
  .plate-input{ width: 120px; font-size: 16px; letter-spacing: .12em; }
  .plate-button{ height: 30px; min-width: 32px; }
  .nlplate{ width: 100%; max-width: 280px; }
  .nlplate__input{ width: 120px; font-size: 16px; }
  .nlplate__btn{ height: 30px; width: 32px; }
  .platepill-row .wrap{ padding: 6px 14px 8px; }
}

@media (max-width: 760px){
  .plate-ui{ height: 42px; }
  .plate-input{ width: 115px; font-size: 16px; letter-spacing: .12em; }
  .nlplate{ height: 42px; }
  .nlplate__input{ width: 115px; font-size: 16px; letter-spacing: .12em; }
}

@media (max-width: 640px){
  .platepill{ width: 100%; justify-content: space-between; }
  .fitment-status{ flex-direction: column; align-items: flex-start; }
}

/* Vehicle card */
.veh-card { border-radius: 16px; overflow: hidden; }
.veh-head { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap: wrap; }
.veh-head .eyebrow { margin: 0; }
.veh-title { margin: 0; }
.veh-toggle { width: 100%; max-width: 340px; }

@media (max-width: 900px){
  .veh-body { display: none; }
  .veh-card.veh-expanded .veh-body { display: block; }
  .veh-toggle{
    display: inline-flex;
    align-self: flex-start;
    margin-top: 8px;
    background: transparent;
    border: 1px solid var(--border);
    color: #f6f8ff;
    border-radius: 999px;
    padding: 6px 12px;
    font-size: 0.85rem;
    cursor: pointer;
  }
  .veh-toggle:hover{
    background: rgba(255,255,255,0.06);
  }
  #site-header .nav-list{
    align-items: stretch;
    text-align: left;
  }
  #site-header .nav-drawer a.nav-link,
  #site-header .nav-drawer .nav-toggle-cta{
    white-space: normal;
    text-align: left;
    justify-content: space-between;
    line-height: 1.2;
    padding: 12px 12px;
    width: 100%;
    max-width: 100%;
    word-break: break-word;
    overflow-wrap: anywhere;
    color: #f6f8ff;
  }
}

@media (min-width: 901px){
  .veh-body { display: block !important; }
  .veh-toggle { display: none !important; }
}

@media (max-width: 1023px){
  #site-header ~ main,
  #site-header ~ .page-main{
    padding-top: calc(var(--hv-header-h, 88px) * 0.25);
  }
  #site-header .nav-drawer .hv2-nav{
    overflow: visible;
  }
}

/* Hero */ 

.hero { padding: 80px 0 40px; } 

.hero .wrap { display: grid; gap: 24px; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); align-items: center; } 

.hero-card { background: linear-gradient(145deg, rgba(88,213,255,0.1), rgba(244,162,97,0.05)); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; box-shadow: var(--shadow); } 

.hero h1 { font-size: clamp(32px, 4vw, 46px); margin-bottom: 12px; } 

.hero p.lead { font-size: 18px; color: #cdd8f5; } 

.hero-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin-top: 20px; } 

.hero-stat { background: rgba(255,255,255,0.04); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 16px; } 

.hero-stat strong { display: block; font-size: 22px; } 

.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 12px; } /* Feature cards */ 

.grid { display: grid; gap: 22px; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); justify-content: center; } 

.card { 
background: var(--card); 
border: 1px solid var(--border); border-radius: var(--radius); 
padding: 18px; margin-top: 4px; 
margin-bottom: 16px; box-shadow: 0 16px 40px rgba(0,0,0,0.35); transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease; color: #f6f8ff; text-decoration: none; } 

.card:hover { transform: translateY(-2px); border-color: rgba(88,213,255,0.4); box-shadow: 0 24px 50px rgba(0,0,0,0.45); } 

.card .t { font-weight: 700; font-size: 17px; } 

.card .s { color: var(--muted); font-size: 14px; } /* Product cards */ 

.card.product { display: grid; gap: 14px; grid-template-columns: 1fr; align-items: start; } 

.card.product:hover { transform: none; border-color: rgba(88,213,255,0.35); } 

.card.product .img { background: rgba(255,255,255,0.03); border-radius: 12px; border: 1px dashed var(--border); min-height: 220px; position: relative; overflow: hidden; } 

.card.product .img img { width: 100%; height: 100%; object-fit: cover; } 

.card.product .badge { position: absolute; top: 10px; right: 10px; background: #0f172a; color: #fff; padding: 6px 10px; border-radius: 10px; border: 1px solid var(--border); } 
.card.product .badge.price { background: #FAB819; color: #111; border-color: transparent; font-weight: 700; }

.card.product .body { display: grid; gap: 10px; } 

.card.product .sku { font-weight: 800; letter-spacing: 0.08em; } 

.card.product .meta { display: grid; grid-template-columns: 160px 1fr; gap: 8px 12px; font-size: 14px; align-items: center; } 

.card.product.plate-context .meta { grid-template-columns: 160px 1fr 160px 1fr; } 

@media (max-width: 900px) { 
.card.product.plate-context .meta { grid-template-columns: 160px 1fr; } 
} 

.card.product .meta .k { color: var(--muted); } 

.card.product .chips { display: flex; flex-wrap: wrap; gap: 6px; } 

.chip { border-radius: 999px; padding: 6px 10px; background: rgba(255,255,255,0.08); font-size: 12px; } 

.chip.small { padding: 4px 8px; } 

.chip.danger { background: rgba(244,162,97,0.15); color: #ffd4b2; } 

.chip.support { background: rgba(88,213,255,0.16); color: #def5ff; } 
.chip.price { background: #FAB819; color: #111; border-color: transparent; font-weight: 700; }

.enginebox { border: 1px solid var(--border); border-radius: 12px; padding: 10px 12px; background: rgba(255,255,255,0.03); } 

.enginebox .lst { display: flex; flex-wrap: wrap; gap: 8px 12px; color: #e9eefc; } 

.pillrow { display: flex; flex-wrap: wrap; gap: 8px; } 

.pill { background: rgba(255,255,255,0.06); border-radius: 999px; padding: 6px 10px; color: #dfe8ff; font-size: 12px; border: 1px solid var(--border); } 
.pill.price { background: #FAB819; color: #111; border-color: transparent; font-weight: 700; }

.cta-row { display: flex; flex-wrap: wrap; gap: 10px; } 

.filters { display: grid; gap: 10px; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); margin: 18px 0; } 

.grp { background: rgba(255,255,255,0.04); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px 14px; } 

.filters .grp { display: flex; flex-direction: column; gap: 8px; min-height: 90px; justify-content: flex-start; } 

.filters .grp.range { display: flex; } 

.filters .grp.range .range-row { display: flex; align-items: center; gap: 10px; } 

.filters .grp.range input[type="range"] { flex: 1; margin: 2px 0 0; } 

/* Shared filters layout for HV/NR/LS */
.filters-grid {
  display: grid;
  gap: 18px;
  align-items: start;
  margin: 18px 0;
}

/* Desktop: 2 kolommen (zoals HV) */
@media (min-width: 901px) {
  .filters-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* Mobile: onder elkaar */
@media (max-width: 900px) {
  .filters-grid {
    grid-template-columns: 1fr;
  }
}

/* Cards consistent */
.filter-card {
  border-radius: 16px;
  overflow: hidden;
}

/* Bouwjaar layout */
.fy{
  display:grid;
  gap:12px;
  align-items:center;
}

@media (min-width: 901px){
  .fy{
    grid-template-columns: minmax(260px,1fr) auto;
  }
  .fy-right{
    justify-self:end;
  }
}

@media (max-width: 900px){
  .fy{
    grid-template-columns: 1fr;
  }
  .fy-right{
    justify-self:start;
  }
}

.fy-left{
  display:grid;
  gap:10px;
}

.fy-label{
  font-weight:600;
  opacity:.9;
}

.fy-range{
  width:100%;
}

.fy-right .range-row{
  display:flex;
  align-items:center;
  gap:8px;
  justify-content:flex-end;
}

@media (max-width: 900px){
  .fy-right .range-row{
    justify-content:flex-start;
  }
}

.grp .muted { color: var(--muted); font-size: 14px; } 

.set-meta { 
display: flex; 
gap: 8px; 
flex-wrap: wrap; align-items: center; 
margin: 8px 0 14px; 
color: var(--muted); font-size: 14px; 
} 

#filter-summary:not(
:empty)::before { 

content: "·"; 
margin: 0 4px 0 2px; 
} 

input[type="range"] { 
width: 100%; 
accent-color: var(--accent); } 

.chips { display: flex; flex-wrap: wrap; gap: 8px; } 

.chips .chip { cursor: pointer; border: 1px solid transparent; } 

.chips .chip[data-on="1"] { border-color: var(--accent); background: rgba(88,213,255,0.16); } 

.experience-chips { margin-bottom: 8px; } 

.crumbs { color: var(--muted); font-size: 14px; margin-bottom: 8px; } 

.crumbs a { color: #d7e7ff; } 

.note, .loading { color: var(--muted); } 

.app { padding: 0 20px 60px; } 

.footer { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; color: var(--muted); font-size: 14px; } /* Footer */ 

.site-footer { background: linear-gradient(180deg, #0b1021, #060914); border-top: 1px solid var(--border); padding: 56px 0 28px; } 

.footer-shell { width: min(100%, var(--max)); margin: 0 auto; padding: 0 20px; display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; } 

.footer-block { background: rgba(255,255,255,0.03); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px; } 

.footer-list { list-style: none; margin: 0; padding: 0; color: var(--muted); display: grid; gap: 8px; } 

.footer-link { color: #d7e7ff; display: inline-flex; gap: 6px; align-items: center; margin-top: 8px; } 

.footer-muted { color: var(--muted); } 

.taglist { display: flex; flex-wrap: wrap; gap: 8px; } 

.taglist a { background: rgba(255,255,255,0.06); color: #f6f8ff; padding: 6px 10px; border-radius: 10px; border: 1px solid var(--border); } 

.taglist a:hover { border-color: rgba(88,213,255,0.4); } 

.footer-cta { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 10px; } 

.footer-bottom { width: min(100%, var(--max)); margin: 28px auto 0; padding: 0 20px; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; color: var(--muted); gap: 10px; } 

.footer-links { display: flex; gap: 12px; } 

.footer-links a { color: var(--muted); } /* Pages */ 

.page-main { width: min(100%, var(--max)); margin: 0 auto; padding: 40px 20px; } 

.page-main h1 { font-size: 34px; } 

.page-section { background: rgba(255,255,255,0.03); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; margin-bottom: 20px; } 

.seo-copy p { color: #e8eefc; } 

.seo-list { margin: 12px 0 0 18px; display: grid; gap: 6px; list-style: disc; color: #e8eefc; } 

.mounted-gallery { margin-top: 24px; } 

.mounted-grid { display: grid; gap: 16px; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); } 

.mounted-grid.is-single { max-width: 520px; margin: 0 auto; } 

.mounted-card { position: relative; overflow: hidden; border-radius: 14px; border: 1px solid var(--border); background: rgba(255,255,255,0.04); } 

.mounted-card img { display: block; width: 100%; height: 220px; object-fit: cover; } 

.mounted-caption { position: absolute; left: 12px; bottom: 12px; background: rgba(4, 9, 20, 0.72); color: #f6f8ff; padding: 6px 10px; border-radius: 10px; font-size: 13px; } 

.contact-grid { display: grid; gap: 18px; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); align-items: start; } 

.contact-map-frame { position: relative; padding-top: 56.25%; border: 1px solid var(--border); border-radius: 12px; overflow: hidden; background: rgba(255,255,255,0.03); } 

.contact-map-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; } 

.contact-map-link { margin-top: 10px; } /* Forms */ 

form { display: grid; gap: 12px; 
} 

input, textarea { 
width: 100%; 
padding: 12px 14px; border-radius: 12px; 
border: 1px solid var(--border); 
background: rgba(255,255,255,0.04); 
color: #f6f8ff; } input:focus, textarea:focus { 
outline: 1px solid var(--accent); } 

/* Responsive */ @media (max-width: 960px) { 

.nav-shell { grid-template-columns: auto auto; grid-template-areas: 'brand toggle' 'nav nav' 'cta cta'; } 

.brand { grid-area: brand; } 

.nav { grid-area: nav; width: 100%; display: none; max-height: calc(100vh - 140px); overflow-y: auto; } 

.nav .mega-panel { max-height: 60vh; overflow-y: auto; } 

.nav-list { flex-direction: column; align-items: flex-start; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px; width: 100%; max-height: calc(100vh - 200px); overflow-y: auto; } 

.nav-item-mega .mega-panel { position: static; transform: none; margin-top: 8px; } 

.nav-item-mega.is-open .mega-panel { transform: none; } 

.nav-cta { grid-area: cta; justify-content: flex-start; } 

.card.product { grid-template-columns: 1fr; } } @media (max-width: 640px) { 

.hero { padding: 60px 0 32px; } 

.card.product .meta { grid-template-columns: 1fr; }
.card.product.plate-context .meta { grid-template-columns: 1fr; }
}

/* Plate Product Group Overlay */
.pgo { position: fixed; inset: 0; z-index: 9999; display: none; }
.pgo.is-open { display: block; }

.pgo-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(6px);
}

.pgo-dialog {
  position: relative;
  max-width: 760px;
  margin: 10vh auto 0;
  background: rgba(8, 18, 35, .96);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  box-shadow: 0 20px 70px rgba(0,0,0,.6);
  padding: 22px;
  color: #fff;
}

@media (max-width: 900px) {
  .pgo-dialog { margin: 12vh 12px 0; }
}

.pgo-close {
  position: absolute; top: 10px; right: 12px;
  width: 38px; height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: #fff;
  font-size: 22px;
  cursor: pointer;
}

.pgo-kicker {
  display: inline-block;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  opacity: .8;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}

.pgo-title { margin: 12px 0 6px; font-size: 30px; }
.pgo-sub { opacity: .9; margin-bottom: 16px; }

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

.pgo-card {
  text-align: left;
  padding: 16px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: #fff;
  cursor: pointer;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.pgo-card:hover {
  transform: translateY(-1px);
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.16);
}
.pgo-card-title { font-size: 16px; font-weight: 700; margin-bottom: 6px; }
.pgo-card-sub { font-size: 13px; opacity: .85; line-height: 1.35; }

.pgo-footer { display: flex; justify-content: flex-end; margin-top: 16px; }
.pgo-secondary {
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: #fff;
  cursor: pointer;
}

/* Header scroll shrink + transparante balk */
.site-header{
  background: rgba(5, 7, 15, 0.35);
  backdrop-filter: blur(12px) saturate(1.1);
  transition: background-color .25s ease, box-shadow .25s ease, backdrop-filter .25s ease;
  --header-shrink: 0;
  --header-pad-y-base: 16px;
  --header-pad-y-compact: 8px;
  --header-pad-x-base: 28px;
  --header-pad-x-compact: 28px;
  --header-gap-base: 18px;
  --header-gap-compact: 14px;
  --logo-h-base: 72px;
  --logo-h-compact: 52px;
  --logo-pad-base: 14px;
  --logo-pad-compact: 10px;
  --logo-radius-base: 21px;
  --logo-radius-compact: 16px;
}

/* hv2 header uses the same shrink variables as legacy site-header */
.hv2-header{
  background: rgba(5, 7, 15, 0.35);
  backdrop-filter: blur(12px) saturate(1.1);
  transition: background-color .25s ease, box-shadow .25s ease, backdrop-filter .25s ease;

  --header-shrink: 0;
  --header-pad-y-base: 16px;
  --header-pad-y-compact: 8px;
  --header-pad-x-base: 28px;
  --header-pad-x-compact: 28px;
  --header-gap-base: 18px;
  --header-gap-compact: 14px;
  --logo-h-base: 72px;
  --logo-h-compact: 52px;
  --logo-pad-base: 14px;
  --logo-pad-compact: 10px;
  --logo-radius-base: 21px;
  --logo-radius-compact: 16px;
}

.hv2-header.is-scrolled{
  --header-shrink: 1;
}

/* Ensure shrink var works on hv2 header */
.hv2-header { --header-shrink: 0; }
.hv2-header.is-scrolled { --header-shrink: 1; }

/* Smooth the change */
.hv2-header .brand-logo{
  transition: height .18s ease, padding .18s ease, border-radius .18s ease;
}

.nav-shell{
  padding:
    calc(var(--header-pad-y-base) - (var(--header-pad-y-base) - var(--header-pad-y-compact)) * var(--header-shrink))
    calc(var(--header-pad-x-base) - (var(--header-pad-x-base) - var(--header-pad-x-compact)) * var(--header-shrink));
  gap:
    calc(var(--header-gap-base) - (var(--header-gap-base) - var(--header-gap-compact)) * var(--header-shrink));
}

.brand-logo{
  height:
    calc(var(--logo-h-base) - (var(--logo-h-base) - var(--logo-h-compact)) * var(--header-shrink));
  padding:
    calc(var(--logo-pad-base) - (var(--logo-pad-base) - var(--logo-pad-compact)) * var(--header-shrink));
  border-radius:
    calc(var(--logo-radius-base) - (var(--logo-radius-base) - var(--logo-radius-compact)) * var(--header-shrink));
}

.site-header.is-scrolled{
  box-shadow: 0 6px 18px rgba(0,0,0,.12);
}

@media (max-width: 960px){
  .site-header{
    --header-pad-y-base: 20px; /* Gat tussen bovenkant en logo */ 
    --header-pad-y-compact: 20px;
    --header-pad-x-base: 4px;  /* Gat tussen links en logo */ 
    --header-pad-x-compact: 14px;
    --header-gap-base: 0px; /* Gat tussen onderkant en logo */
    --header-gap-compact: 0px; /* Gat tussen onderkant en logo na scrollen */
    --logo-h-base: 80px;  /* Grootte logo */
    --logo-h-compact: 35px; /* Grootte logo na scrollen */
    --logo-pad-base: 10px; /* Breedte logo */
    --logo-pad-compact: 3px; /* Breedte logo na scrollen */
    --logo-radius-base: 16px; /* Afronding Logo */
    --logo-radius-compact: 12px; /* Afronding Logo na scrollen */
  }
}

/* Legacy breadcrumbs fallback */
.has-site-breadcrumbs .crumbs,
.has-site-breadcrumbs .breadcrumbs{
  display: none !important;
}

.site-breadcrumbs{
  background: rgba(5, 7, 15, 0.3);
  border-bottom: 1px solid var(--border);
}

.site-breadcrumbs .wrap{
  padding: 10px 20px;
}

.site-breadcrumbs ol{
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--muted);
  font-size: 0.92rem;
}

.site-breadcrumbs li{
  display: flex;
  align-items: center;
  gap: 8px;
}

.site-breadcrumbs li + li::before{
  content: "/";
  opacity: 0.55;
}

.site-breadcrumbs a{
  color: #d7e7ff;
  text-decoration: none;
}

.site-breadcrumbs a:hover{
  color: #ffffff;
}

.site-breadcrumbs span{
  color: #ffffff;
  font-weight: 600;
}

@media (max-width: 960px){
  .site-breadcrumbs .wrap{
    padding: 8px 14px;
  }
}

body.plate-route .hero{
  display: none;
}

/* Fix Summary:
 * Broken: Plate UI regressed visually and status/reset feedback lacked styling.
 * Change: Restyled the plate input/button to Dutch plate proportions and added status/reset styles.
 * Test: Header plate search styling on desktop/mobile + status/reset states.
 */

/* --- Plate UI (NL) --- */
.plate-search{
  display:inline-flex;
  flex-direction:column;
  gap:6px;
  align-items:flex-start;
}

/* De plaat zelf */
.plate-ui{
  position:relative;
  display:flex;
  align-items:center;
  height:44px;
  border-radius:10px;
  background:#f2c200;
  border:1px solid rgba(0,0,0,.18);
  box-shadow: 0 2px 10px rgba(0,0,0,.25);
  overflow:hidden;
  padding:0 52px 0 44px;
}

/* EU/NL band links */
.plate-eu{
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:44px;
  background:#0b4ea2;
  color:#fff;
  font-weight:800;
  display:flex;
  align-items:center;
  justify-content:center;
  letter-spacing:.08em;
  font-size:12px;
}

/* Input */
.plate-input{
  width:140px;
  border:0;
  outline:0;
  background:transparent;
  height:100%;
  font-weight:800;
  font-size:18px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#111;
  text-align:center;
  padding:0 8px;
}

.plate-button{
  position:absolute;
  right:6px;
  top:50%;
  transform:translateY(-50%);
  height:32px;
  min-width:34px;
  border:0;
  border-radius:8px;
  background: rgba(0,0,0,.15);
  color:#111;
  font-weight:700;
  font-size:12px;
  padding:0 8px;
  cursor:pointer;
}

.plate-button:hover{
  background: rgba(0,0,0,.22);
}

.plate-search[data-plate-state="loading"] .plate-button{
  cursor: wait;
  opacity: 0.8;
}

.plate-status,
.hv-plate-status{
  margin-top: 6px;
  font-size: 12px;
  color: #1e2430;
  display: grid;
  gap: 6px;
}

.plate-status[data-state="error"],
.hv-plate-status[data-state="error"]{
  color: #b0302a;
}

.plate-status[data-state="success"],
.hv-plate-status[data-state="success"]{
  color: #1f7a4d;
}

.plate-status__actions{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.plate-status__reset{
  border: 1px solid #1e2430;
  background: #fff;
  color: #1e2430;
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 12px;
  cursor: pointer;
}

.plate-status__link{
  text-decoration: none;
  color: #0b3a7a;
  border: 1px solid rgba(11,58,122,0.25);
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
}

.plate-year-note{
  display: block;
  opacity: .75;
  font-size: 12px;
  margin-top: 4px;
}

.platepill-row{
  background: rgba(5, 7, 15, 0.35);
  border-bottom: 1px solid var(--border);
}

.platepill{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
}

.platepill__label{
  color: var(--muted);
  font-size: 0.9rem;
}

.platepill__text{
  font-weight: 600;
}

.platepill__clear{
  margin-left: auto;
  background: transparent;
  border: 1px solid var(--border);
  color: #fff;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 0.85rem;
  cursor: pointer;
}

.plate-type-choice{
  margin-top: 12px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
}

.plate-type-choice__title{
  font-weight: 600;
  margin-bottom: 8px;
}

.plate-type-choice__actions{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 8px;
}

/* Desktop: menu zichtbaar, burger uit */
@media (min-width: 1024px){
  #site-header .header-center{ display:flex; }
  #site-header .hv2-nav-layer{ display:flex; justify-content:center; width:100%; }
  #site-header .nav-overlay{ display:none; }
  #site-header .hv2-nav{ display:block; }
  #site-header .hv2-top{ display:flex; gap:12px; align-items:center; flex-wrap:nowrap; }
  #site-header .hv2-burger{ display:none; }
  #site-header .hv2-nav{ overflow: visible; }
}
@media (min-width: 1024px){
  #site-header .header-inner{
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
  }
  #site-header .header-left{ justify-content: flex-start; }
  #site-header .header-center{ justify-content: center; }
  #site-header .header-right{ justify-content: flex-end; }
}

@media (min-width: 1024px) and (max-width: 1400px){
  .header-inner{
    gap: 12px;
    padding: 10px 14px;
  }
  .hv2-top{ gap: 12px; }
  .hv2-nav a{ padding: 8px 10px; }
  .hv2-plate{ max-width: 200px; }
}
@media (max-width: 1023px){
  #site-header [data-hv2-drawer]{
    width: min(92vw, 360px) !important;
    height: 100vh !important;
    min-width: 280px !important;
    min-height: 100vh !important;
    padding: 16px !important;
    box-sizing: border-box !important;
  }
}

/* =========================
   HV2 header/drawer final overrides
   - force header fixed + high stacking
   - keep drawer/overlay above logo/plate
   ========================= */
#site-header .hv2-header{
  position: fixed !important;
  top: 0;
  left: 0;
  right: 0;
  z-index: 20000 !important;
}

#site-header .header-inner,
#site-header .header-left,
#site-header .header-center,
#site-header .header-right{
  position: relative;
  z-index: 1;
}


@media (max-width: 900px){
  .menu-open .plate-search{
    display: none !important;
  }
  #site-header .nav-drawer{
    right: 0;
    left: 0;
    margin: 0 auto;
    max-width: 520px;
    padding-inline: 18px;
  }
  #site-header .nav-shell{
    width: 100%;
  }
  #site-header .nav-list{
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 10px;
  }
  #site-header .nav-link{
    justify-content: center;
    width: 100%;
    padding: 12px 10px;
  }
}

@media (max-width: 900px){
  /* Mobile split-button nav */
  .mnav-item{
    position: relative;
    width: 100%;
    min-height: 52px;
  }
  .mnav-link{
    display: flex;
    align-items: center;
    height: 52px;
    line-height: 1;
    padding: 0 56px 0 16px;
    border-radius: 14px;
  }
  .mnav-toggle,
  .nav-toggle-cta{
    position: absolute;
    top: 50%;
    right: 8px;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    padding: 0;
    border-radius: 12px;
    display: grid;
    place-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1;
    min-width: 40px;
    max-width: 40px;
    z-index: 2;
    background: rgba(255,255,255,.06);
    border: 1px solid var(--border);
    font-size: 0;
    color: transparent;
  }
  .mnav-chevron{
    width: 10px;
    height: 10px;
    border-right: 2px solid rgba(255,255,255,.85);
    border-bottom: 2px solid rgba(255,255,255,.85);
    transform: rotate(45deg);
    transition: transform .18s ease;
  }
  .mnav-toggle[aria-expanded="true"] .mnav-chevron{
    transform: rotate(-135deg);
  }
  .mnav-sub{
    margin-top: 10px;
    padding-left: 10px;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    background: transparent !important;
  }
  .mnav-sub li{
    background: none !important;
  }
  .mnav-item::before,
  .mnav-item::after,
  .mnav-link::before,
  .mnav-link::after,
  .mnav-toggle::before,
  .mnav-toggle::after{
    content: none !important;
  }

  /* Override drawer link sizing so the toggle stays on the right */
  #site-header .nav-drawer a.nav-link.mnav-link{
    display: flex;
    align-items: center;
    justify-content: flex-start;
    height: 52px;
    width: 100%;
    padding: 0 56px 0 16px;
    line-height: 1;
  }
  #site-header .nav-drawer .nav-item-mega[data-family="hv"] > a.nav-link,
  #site-header .nav-drawer .hv-nav-item-mega[data-family="hv"] > a.nav-link{
    display: flex;
    align-items: center;
    height: 52px;
    width: 100%;
    padding: 0 56px 0 16px;
    line-height: 1;
    position: relative;
    z-index: 1;
  }
  #site-header .nav-drawer .mnav-toggle{
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    padding: 0;
    min-width: 40px;
    max-width: 40px;
    display: grid;
    place-items: center;
    justify-content: center;
    text-align: center;
    font-size: 0;
    color: transparent;
  }

  /* Mobile mega list: ensure labels are visible */
  #site-header .nav-drawer .mega-list,
  #site-header .nav-drawer .mega-list li{
    width: 100%;
  }
  #site-header .nav-drawer .mega-list a,
  #site-header .nav-drawer .mega-link{
    display: block;
    color: #f6f8ff;
    background: rgba(255,255,255,0.06);
    border: 1px solid var(--border);
    padding: 10px 12px;
    border-radius: 10px;
    text-align: left;
    line-height: 1.2;
    font-weight: 600;
  }
  #site-header .nav-drawer .mega-list a:hover{
    background: rgba(88,213,255,0.14);
    color: #eaf8ff;
  }

  /* Drawer scroll only; prevent submenu stretch/inner scroll */
  #site-header .nav-drawer{
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  #site-header .nav-drawer .mega-panel,
  #site-header .nav-drawer .hv-mega-panel,
  #site-header .nav-drawer .mega-inner,
  #site-header .nav-drawer .mega-col,
  #site-header .nav-drawer .mega-list{
    height: auto !important;
    max-height: none !important;
    min-height: 0 !important;
    flex: 0 0 auto !important;
    overflow: visible !important;
    background: transparent !important;
  }
  #site-header .nav-drawer .mega-list li{
    background: none !important;
  }
}

@media (min-width: 901px) {
  .mnav-toggle,
  .hv2-nav-toggle,
  .drawer-toggle,
  .mnav-chevron,
  .hv2-chevron,
  .nav-toggle-cta,
  .hv-nav-toggle{
    display: none !important;
  }
  .hv2-nav a::before,
  .hv2-nav a::after,
  .hv2-nav li::before,
  .hv2-nav li::after{
    content: none !important;
  }
}

@media (max-width: 900px){
  .crumbs { margin-bottom: 10px !important; }
  .crumbs + * { margin-top: 0 !important; }
}

@media (min-width: 1024px){
  #site-header .hv2-nav-layer{
    position: static !important;
    inset: auto !important;
    width: auto !important;
    height: auto !important;
    pointer-events: auto !important;
    z-index: auto !important;
  }
  #site-header .nav-overlay{
    display: none !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: none !important;
  }
}

/* HV2 desktop nav must stay visible */
@media (min-width: 1024px){
  #site-header header.hv2-header .nav-drawer{
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    position: static !important;
    transform: none !important;
    height: auto !important;
    width: auto !important;
  }
}

/* Build range inputs */
.build-range-fields {
  display: grid;
  grid-template-columns: auto 1fr auto 1fr;
  gap: 10px;
  align-items: center;
}
.br-label { white-space: nowrap; }
.br-input { width: 100%; }
@media (max-width: 600px) {
  .build-range-fields {
    grid-template-columns: 1fr;
  }
}

/* FIX: mobile drawer click-through  header-inner should not eat taps */
@media (max-width: 900px) {
  /* When the mobile menu is open, the inner wrapper must not intercept taps */
  html.menu-open #site-header .hv2-header .hv2-inner.header-inner {
    pointer-events: none;
  }

  /* Re-enable interactions inside the drawer and the burger toggle */
  html.menu-open #site-header .hv2-header .nav-drawer,
  html.menu-open #site-header .hv2-header .nav-drawer *,
  html.menu-open #site-header .hv2-header [data-hv2-toggle] {
    pointer-events: auto;
  }
}

/* Plate summary (kenteken-ovaal) */
.kt-summary {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  border-radius: 999px;
  line-height: 1.35;
}

.kt-summary .kt-left {
  min-width: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px 12px;
  align-items: center;
}

.kt-summary .kt-label {
  opacity: 0.85;
  white-space: nowrap;
  line-height: 1.2;
}

.kt-summary .kt-value {
  min-width: 0;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.2;
}

.kt-summary .kt-lines {
  grid-column: 2 / -1;
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.kt-summary .kt-chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border);
  font-weight: 700;
  white-space: nowrap;
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.2;
}

.kt-summary .kt-right {
  display: grid;
  gap: 6px;
  justify-items: end;
  text-align: right;
}

.kt-summary .kt-note {
  opacity: 0.75;
  font-size: 13px;
  line-height: 1.25;
  max-width: 220px;
}

.kt-summary .platepill__clear {
  margin-left: 0;
  padding: 6px 12px;
  border-radius: 12px;
  line-height: 1.2;
  white-space: nowrap;
}

@media (max-width: 900px) {
  .kt-summary {
    grid-template-columns: 1fr;
    border-radius: 18px;
    padding: 14px;
  }

  .kt-summary .kt-left {
    grid-template-columns: 1fr;
    gap: 8px;
    align-items: start;
  }

  .kt-summary .kt-lines {
    grid-column: auto;
  }

  .kt-summary .kt-right {
    justify-items: start;
    text-align: left;
  }

  .kt-summary .kt-note {
    max-width: none;
  }

  .kt-summary .kt-chip {
    max-width: 100%;
  }

  .kt-summary .platepill__clear {
    padding: 8px 12px;
  }
}


/* Jump to first set (mobile) */
.jump-row {
  display: none;
  margin: 10px 0 6px;
}

.jump-first-set {
  width: 100%;
  justify-content: center;
}

@media (max-width: 900px) {
  .jump-row {
    display: block;
  }
}

/* FINAL: hv2 logo shrink (force calc + wins specificity) */
#site-header .hv2-header .brand-logo{
  height: calc(var(--logo-h-base) - (var(--logo-h-base) - var(--logo-h-compact)) * var(--header-shrink)) !important;
  padding: calc(var(--logo-pad-base) - (var(--logo-pad-base) - var(--logo-pad-compact)) * var(--header-shrink)) !important;
  border-radius: calc(var(--logo-radius-base) - (var(--logo-radius-base) - var(--logo-radius-compact)) * var(--header-shrink)) !important;
  transition: height .32s cubic-bezier(.22,1,.36,1),
            padding .32s cubic-bezier(.22,1,.36,1),
            border-radius .32s cubic-bezier(.22,1,.36,1);
  width: auto;
}

/* Jump to first set (mobile) – make it pop */
.jump-first-set{
  border: 2px solid var(--accent) !important;
  color: var(--accent) !important;
  background: transparent !important;
  box-shadow: 0 10px 24px rgba(250,184,25,0.20);
  font-weight: 800;
  letter-spacing: .02em;
}

.jump-first-set:hover{
  background: rgba(250,184,25,0.10) !important;
}

.jump-first-set:active{
  transform: translateY(1px);
}

.jump-first-set span[aria-hidden="true"]{
  display: inline-block;
  margin-left: 8px;
  font-size: 16px;
  line-height: 1;
}

/* -----------------------------
   Filters layout (NR/LS/HV)
------------------------------ */

.filters-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items: start;
}

/* Zorg dat filter cards netjes dezelfde "hoogte feel" hebben */
.filters-grid .filter-card{
  width: 100%;
}

/* Bouwjaar blok: slider + inputs beter verdeeld */
.filters-grid .filter-card.grp.fy{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Range-row (van/tot) altijd naast elkaar */
.filters-grid .range-row{
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  align-items: center;
  margin-top: 8px !important;
}

/* Checkbox groepen (As, Goedkeuring etc.) laten wrappen */
.filters-grid .filter-card.grp label{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-right: 10px;
}

/* Actieknoppen/Resultaten: alles op 1 rij, wrap als nodig */
.filters-grid .filter-card.grp.actions,
.filters-grid #nr-filters .filter-card.grp:last-child,
.filters-grid #ls-filters .filter-card.grp:last-child{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

/* Resultaten label iets rustiger */
.filters-grid .muted{
  white-space: nowrap;
}

/* Motor input: volle breedte binnen kaart */
.filters-grid input[type="text"],
.filters-grid input[type="number"]{
  width: 100%;
}

/* Mobiel: 1 kolom */
@media (max-width: 900px){
  .filters-grid{
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .filters-grid .range-row{
    grid-template-columns: 1fr 1fr;
  }
}

/* Filters: compacte cards met gelijke hoogte */
.filters-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  align-items:stretch;
}

.filters-grid .filter-card{
  min-height: 92px;           /* gelijke hoogte */
  padding: 10px 12px;
}

/* Bouwjaar: label + slider + values in 1 rij */
.filters-grid .filter-card.grp.fy .fy-left{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.filters-grid .filter-card.grp.fy .fy-label{
  font-weight:700;
  font-size:14px;
  white-space:nowrap;
}

/* Zet de "range" (2024 2024 / of label) naast slider */
.filters-grid .filter-card.grp.fy .fy-range{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0;
}

/* Slider rij compacter */
.filters-grid .filter-card.grp.fy input[type="range"]{
  width: 180px;
  max-width: 40vw;
}

/* De van/tot velden onder de slider UIT voor compacte variant (alleen als je dat wil) */
.filters-grid .filter-card.grp.fy .range-row{
  display:none;
}

/* Mobiel: 1 kolom */
@media (max-width: 900px){
  .filters-grid{ grid-template-columns: 1fr; }
  .filters-grid .filter-card{ min-height: 88px; }
  .filters-grid .filter-card.grp.fy input[type="range"]{
    width: 100%;
    max-width: 100%;
  }
}

@media (min-width: 1024px){
  /* Desktop must never show mobile drawer UI */
  .hv2-drawer-close{ display:none !important; }
  .nav-overlay{ display:none !important; }

  /* Safety: if any drawer/panel exists, force-hide on desktop */
  .hv2-drawer, .hv2-drawer-panel, .nav-drawer, .drawer, .mobile-drawer{
    display:none !important;
    visibility:hidden !important;
    opacity:0 !important;
    pointer-events:none !important;
  }

  /* Safety: no stuck "open" scroll lock on desktop */
  html.nav-open, html.menu-open, body.nav-open, body.menu-open{
    overflow:auto !important;
  }
}

@media (min-width: 1024px){
  /* Desktop mega menu must override mobile hidden state */
  .hv-nav-item-mega .hv-mega-panel,
  .nav-item-mega .mega-panel{
    display: none;
    opacity: 0;
    visibility: hidden;
  }

  .hv-nav-item-mega.is-open .hv-mega-panel,
  .nav-item-mega.is-open .mega-panel{
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  /* hidden attribute must not block desktop */
  .hv-nav-item-mega.is-open .hv-mega-panel[hidden],
  .nav-item-mega.is-open .mega-panel[hidden]{
    display: block !important;
  }
}

@media (min-width: 1024px){
  /* HARD OVERRIDE: mega panel must be visible when item is open (beat any other rule) */
  header.hv2-header nav.hv2-nav .nav-item-mega.is-open > .mega-panel,
  header.hv2-header nav.hv2-nav .hv-nav-item-mega.is-open > .hv-mega-panel{
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
}

@media (min-width: 1024px){
  /* Desktop nav must be clickable */
  header.hv2-header nav.hv2-nav{
    pointer-events: auto !important;
  }
}

@media (min-width: 1024px){
  /* Desktop: never keep drawer-layout heights at 0 */
  #site-header .hv2-header .hv2-nav-layer,
  #site-header .hv2-header .hv2-nav-wrap,
  #site-header .hv2-header .header-center{
    height: auto !important;
    min-height: 0 !important;
  }

  /* Desktop: ensure the nav container is not hidden like mobile drawer */
  #site-header .hv2-header .nav-drawer{
    display: block !important;
    transform: none !important;
    visibility: visible !important;
  }
}

@media (min-width: 1024px){
  /* Desktop: ensure nav layout never collapses to 0px */
  header.hv2-header .hv2-nav-layer,
  header.hv2-header .hv2-nav-wrap,
  header.hv2-header .header-center{
    height: auto !important;
    min-height: 0 !important;
  }

  /* Desktop: nav container must not behave like a hidden drawer */
  header.hv2-header .nav-drawer{
    display: block !important;
    position: static !important;
    transform: none !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  /* Desktop: the mega toggles must be visible/clickable */
  header.hv2-header button.hv-nav-toggle{
    display: inline-flex !important;
    pointer-events: auto !important;
  }

  /* Desktop: never show mobile overlay/close */
  header.hv2-header .nav-overlay,
  header.hv2-header .hv2-drawer-close{
    display: none !important;
  }

  /* Desktop: never keep scroll-locked states */
  html.menu-open, html.nav-open,
  body.menu-open, body.nav-open{
    overflow: auto !important;
/* HARD FIX: desktop drawer must never be transparent */
@media (min-width: 1024px){
  #site-header .nav-drawer,
  #site-header header.hv2-header .nav-drawer,
  #site-header [data-hv2-drawer]{
    opacity: 1 !important;
  }
}

/* FINAL OVERRIDE — desktop nav must always be visible */
@media (min-width: 1024px){
  html body #site-header header.hv2-header .hv2-nav-layer .nav-drawer{
    opacity: 1 !important;
  }
}

/* === FIX: HV2 desktop nav must not be hidden by legacy drawer rules === */
@media (min-width: 1024px){
  #site-header header.hv2-header .nav-drawer,
  #site-header header.hv2-header [data-hv2-drawer]{
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    position: static !important;
    transform: none !important;
    height: auto !important;
    width: auto !important;
  }

  /* Ensure the container isn't acting like an overlay layer */
  #site-header header.hv2-header .hv2-nav-layer,
  #site-header header.hv2-header [data-hv2-layer]{
    pointer-events: auto !important;
  }

  /* Overlay should never cover desktop */
  #site-header header.hv2-header .nav-overlay,
  #site-header header.hv2-header [data-hv2-overlay]{
    display: none !important;
    opacity: 0 !important;
    pointer-events: none !important;
    visibility: hidden !important;
  }

  /* Desktop: layer behaves like normal layout (never a fullscreen fixed overlay) */
  #site-header header.hv2-header .hv2-nav-layer,
  #site-header header.hv2-header [data-hv2-layer]{
    position: static !important;
    inset: auto !important;
    pointer-events: auto !important;
    height: auto !important;
    z-index: auto !important;
  }

  /* Desktop: drawer is ALWAYS visible; never fall back to mobile closed state */
  #site-header header.hv2-header .nav-drawer,
  #site-header header.hv2-header [data-hv2-drawer]{
    position: static !important;
    height: auto !important;
    width: auto !important;
    transform: none !important;
    visibility: visible !important;
    display: block !important;
    overflow: visible !important;
    z-index: auto !important;
    top: auto !important;
    right: auto !important;
    left: auto !important;
  }
}
