﻿*{box-sizing:border-box;margin:0;padding:0}

:root{
  /* FaunaTrack brand */
  --eco-deep:    #0D2B1F;
  --eco-forest:  #1A4D35;
  --eco-leaf:    #2E7D55;
  --eco-sage:    #52A878;
  --eco-mist:    #A8D5BC;
  --eco-light:   #E8F5EE;
  --eco-sand:    #F4F0E6;
  --eco-chalk:   #FAFAF8;
  --eco-amber:   #D4821A;
  --eco-amber-l: #FBE9C8;
  /* BIJ12 heritage */
  --bij12:       #1B5C9E;
  --bij12-light: #D6E8F9;
  /* Neutral */
  --border:      rgba(13,43,31,0.10);
  --border-md:   rgba(13,43,31,0.18);
  --text:        #0D2B1F;
  --text-deep:   #0D2B1F;
  --text-mid:    #3B5A49;
  --text-muted:  #6B8C7B;
  --bg:          #F4F0E6;
  --surface:     #FFFFFF;
  --sidepanel:   #123528;
  --sidepanel-h: #1A4D35;
  /* Type colours (badges) */
  --c-waarneming: #2E7D55;
  --c-schade:     #D4821A;
  --c-aanrijding: #B53A2A;
  --c-beheer:     #1B5C9E;
}

#landing-container, #app-container-wrapper {
  display: flex;
  flex: 1;
  min-height: 0;
  height: 0; /* Laat flex de hoogte bepalen */
}

#landing-container:empty, #app-container-wrapper:empty {
  display: none;
}

.section-container {
  display: flex;
  flex-direction: column;
  height: 100vh;
}

#header-container, #toast-container {
  flex: 0 0 auto;
}

body{
  font-family:'DM Sans',sans-serif;
  font-size:14px;
  color:var(--text);
  height: 100vh;
  margin: 0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  background:var(--eco-sand);
  position: relative;
}
.app-container{
  display: flex;
  flex: 1;
  overflow: hidden;
  position: relative;
}

/* ─── SIDEPANEL ──────────────────────────────── */
.sidepanel{
  width: 240px;
  height: 100vh;
  background: var(--sidepanel);
  color: rgba(255,255,255,0.7);
  display: flex;
  flex-direction: column;
  transition: transform 0.3s ease, width 0.3s ease;
  z-index: 1500;
  flex-shrink: 0;
}
.sidepanel.collapsed{
  width: 0;
  transform: translateX(-240px);
  overflow: hidden;
}
.sp-nav{
  flex: 1;
  padding: 15px 0;
  overflow-y: auto;
}
.sp-item{
  padding: 10px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 13px;
  color: rgba(255,255,255,0.7);
  text-decoration: none;
}
.sp-item:hover{
  background: var(--sidepanel-h);
  color: #fff;
}
.sp-group{
  margin-bottom: 5px;
}
.sp-group-hdr{
  padding: 10px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  font-size: 13px;
  color: rgba(255,255,255,0.7);
  transition: all 0.2s;
  font-weight: 500;
}
.sp-group-hdr:hover{
  background: var(--sidepanel-h);
  color: #fff;
}
.sp-group-title{
  display: flex;
  align-items: center;
  gap: 12px;
}
.sp-group-arrow{
  transition: transform 0.3s ease;
  opacity: 0.5;
}
.sp-group.open .sp-group-arrow{
  transform: rotate(180deg);
}
.sp-group-items{
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-out;
  background: rgba(0,0,0,0.1);
}
.sp-group.open .sp-group-items{
  max-height: 500px;
}
.sp-subitem{
  padding: 8px 20px 8px 50px;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  text-decoration: none;
  transition: all 0.2s;
}
.sp-subitem:hover{
  background: var(--sidepanel-h);
  color: #fff;
}
.sp-subitem.active{
  color: #fff;
  background: rgba(46,125,85,0.3);
  border-left: 2px solid var(--eco-leaf);
}
.sp-item.active{
  background: var(--eco-leaf);
  color: #fff;
  border-left: 3px solid var(--eco-sage);
}
.sp-item svg{
  width: 18px;
  height: 18px;
  opacity: 0.8;
}
.sp-footer{
  padding: 15px 20px;
  border-top: 1px solid rgba(255,255,255,0.1);
  font-size: 11px;
}

/* ─── LANDING PAGE ───────────────────────────── */
.landing-page{
  position: absolute;
  inset: 0;
  background: var(--eco-deep);
  z-index: 3000;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-align: center;
  padding: 40px 20px;
  background-image:
    radial-gradient(ellipse at 30% 20%, rgba(46,125,85,0.15) 0%, transparent 60%),
    radial-gradient(ellipse at 70% 80%, rgba(27,92,158,0.1) 0%, transparent 60%),
    linear-gradient(rgba(13,43,31,0.88), rgba(13,43,31,0.92)),
    url('https://images.unsplash.com/photo-1518495973542-4542c06a5843?ixlib=rb-1.2.1&auto=format&fit=crop&w=1350&q=80');
  background-size: cover;
  background-position: center;
  background-color: var(--eco-deep); /* fallback als afbeelding faalt */
}
.lp-content{
  max-width: 520px;
}
.lp-logo{
  margin-bottom: 35px;
}
.lp-logo .logo-icon-box{
  width: 80px; height: 80px;
  margin: 0 auto 15px;
}
.lp-logo .logo-name{
  font-size: 42px;
  letter-spacing: -0.5px;
}
.lp-title{
  font-family: 'DM Serif Display', serif;
  font-size: 30px;
  margin-bottom: 16px;
  line-height: 1.2;
  letter-spacing: -0.3px;
}
.lp-sub{
  font-size: 15px;
  color: rgba(255,255,255,0.65);
  margin-bottom: 0;
  line-height: 1.6;
  max-width: 440px;
  margin-left: auto;
  margin-right: auto;
}
.lp-btns{
  display: flex;
  gap: 12px;
  justify-content: center;
  margin-top: 36px;
  flex-wrap: wrap;
}
.btn-lp-ghost{
  background: rgba(255,255,255,0.08);
  color: #fff;
  border-color: rgba(255,255,255,0.25);
}
.btn-lp-ghost:hover{
  background: rgba(255,255,255,0.15);
  border-color: rgba(255,255,255,0.4);
}
.lp-auth-card {
  background: #fff;
  border-radius: 16px;
  padding: 30px;
  width: 100%;
  max-width: 400px;
  box-shadow: 0 20px 50px rgba(0,0,0,0.3);
  color: var(--text);
  text-align: left;
}
.lp-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(13,43,31,0.6);
  backdrop-filter: blur(4px);
  z-index: 4000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: fadeIn 0.3s ease;
}
.lp-overlay-content {
  width: 100%;
  display: flex;
  justify-content: center;
  animation: slideUp 0.3s ease;
}
.btn-close-lp {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 5px;
  border-radius: 50%;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.btn-close-lp:hover {
  background: var(--eco-light);
  color: var(--eco-deep);
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideUp { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.lp-auth-card .fg {
  margin-bottom: 15px;
}
.lp-auth-card input {
  background: #f9f9f9;
  border: 1px solid #ddd;
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 14px;
}
.lp-auth-card input:focus {
  border-color: var(--eco-leaf);
  outline: none;
  background: #fff;
}


.btn-lp{
  padding: 12px 30px;
  font-size: 15px;
}

/* ─── HEADER TOGGLE ──────────────────────────── */
.menu-toggle{
  background: none;
  border: none;
  color: #fff;
  cursor: pointer;
  padding: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.menu-toggle svg{
  width: 22px;
  height: 22px;
}

/* ─── HEADER ─────────────────────────────────── */
header{
  background:var(--eco-deep);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 20px;
  height:56px;
  flex-shrink:0;
  border-bottom:3px solid var(--eco-leaf);
}
.hdr-l{display:flex;align-items:center;gap:14px}

.logo-mark{
  display:flex;
  align-items:center;
  gap:9px;
}
.logo-icon-box{
  width:34px;height:34px;
  background:var(--eco-leaf);
  border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.logo-icon-box svg{width:20px;height:20px}
.logo-name{
  font-family:'DM Serif Display',serif;
  font-size:20px;
  color:#fff;
  line-height:1;
  letter-spacing:-0.3px;
}
.logo-name em{font-style:italic;color:var(--eco-sage)}

.hdr-divider{width:1px;height:26px;background:rgba(255,255,255,0.15);margin:0 4px}

.hdr-org{
  display:flex;flex-direction:column;
}
.hdr-title{font-size:13px;font-weight:500;color:rgba(255,255,255,0.9)}
.hdr-sub{font-size:11px;color:rgba(255,255,255,0.45);margin-top:1px;font-weight:300}

.hdr-btn{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.85);
  padding:6px 14px;
  border-radius:8px;
  font-size:12px;
  cursor:pointer;
  font-family:'DM Sans',sans-serif;
  font-weight:500;
  transition:background .15s;
  display:flex;align-items:center;gap:6px;
}
.hdr-btn:hover{background:rgba(255,255,255,0.15)}

/* ─── TOOLBAR ────────────────────────────────── */
.toolbar{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:8px 16px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-shrink:0;
  overflow-x:auto;
}
.pill{
  background:transparent;
  border:1px solid var(--border-md);
  color:var(--text-mid);
  font-size:12px;
  font-weight:500;
  padding:5px 13px;
  border-radius:100px;
  cursor:pointer;
  white-space:nowrap;
  transition:all .15s;
  font-family:'DM Sans',sans-serif;
}
.pill:hover{background:var(--eco-light);border-color:var(--eco-sage);color:var(--eco-forest)}
.pill.active{background:var(--eco-forest);color:#fff;border-color:var(--eco-forest)}

.sep{flex:1}

.chip{
  font-size:12px;
  color:var(--text-muted);
  display:flex;align-items:center;gap:5px;
  padding:5px 11px;
  background:var(--eco-light);
  border-radius:100px;
  border:1px solid rgba(46,125,85,0.15);
  white-space:nowrap;
  font-weight:400;
}
.chip strong{color:var(--eco-forest);font-weight:600}

/* ─── MAIN LAYOUT ────────────────────────────── */
.main{display:flex;flex:1;flex-direction:column;overflow:hidden}
.main-content{display:flex;flex:1;overflow:hidden}

/* ─── SIDEBAR ────────────────────────────────── */
.sidebar{
  width:268px;
  height: 100vh;
  flex-shrink:0;
  background:var(--surface);
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.sb-hdr{
  padding:12px 16px 10px;
  border-bottom:1px solid var(--border);
  font-size:10px;
  font-weight:600;
  color:var(--text-muted);
  letter-spacing:.6px;
  text-transform:uppercase;
  display:flex;align-items:center;justify-content:space-between;
}
.sb-cnt{
  background:var(--eco-leaf);
  color:#fff;
  font-size:10px;font-weight:700;
  padding:2px 7px;
  border-radius:10px;
  text-transform:none;letter-spacing:0;
}
.sb-list{flex:1;overflow-y:auto}

/* Registration item */
.ri{
  padding:11px 15px;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:background .1s;
}
.ri:hover{background:var(--eco-light)}
.ri.active-item { background: var(--eco-light); border-left: 3px solid var(--eco-leaf); }
.ri-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.ri-soort{font-weight:600;font-size:13px;color:var(--text)}

/* Badges */
.badge{
  font-size:10px;font-weight:600;
  padding:2px 8px;
  border-radius:100px;
  letter-spacing:.2px;
  display:inline-flex;align-items:center;gap:4px;
}
.badge::before{
  content:'';width:5px;height:5px;border-radius:50%;
  background:currentColor;
  opacity:0.7;
  flex-shrink:0;
}
.bw{background:#E8F5EE;color:#1A4D35}
.bs{background:#FBE9C8;color:#7A4A0A}
.ba{background:#FAEAE7;color:#7A2218}
.bb{background:#D6E8F9;color:#0D3F73}

.ri-meta{font-size:11px;color:var(--text-muted);display:flex;gap:9px;font-weight:300}

/* ─── MAP ─────────────────────────────────────── */
.map-wrap{flex:1;position:relative}
#map{width:100%;height:100%}

/* FAB */
.fab{
  position:absolute;bottom:28px;right:22px;z-index:2000;
  background:var(--eco-leaf);
  color:#fff;border:none;
  border-radius:50%;width:54px;height:54px;
  font-size:26px;cursor:pointer;
  box-shadow:0 4px 18px rgba(46,125,85,0.45);
  display:flex;align-items:center;justify-content:center;
  transition:transform .15s,background .15s;
  line-height:1;
}
.fab:hover{transform:scale(1.08);background:var(--eco-forest)}

.mhdr-btn {
  background: var(--eco-forest);
  color: white;
  border: none;
  width: 32px;
  height: 32px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.2s;
}
.mhdr-btn:hover { background: var(--primary); }

/* Map controls */
.mctrls{position:absolute;top:12px;right:12px;z-index:1000;display:flex;flex-direction:column;gap:6px}
.mb{
  background:#fff;
  border:1px solid var(--border-md);
  border-radius:8px;
  width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:16px;
  color:var(--text-mid);
  box-shadow:0 1px 5px rgba(0,0,0,.08);
  transition:background .12s;
  font-family:'DM Sans',sans-serif;
}
.mb:hover{background:var(--eco-light)}
.leaflet-control-zoom{display:none}
/* ── Map Controls (Layers + Buffers) ────── */
.leaflet-control-layers {
  margin-top: 55px !important;
  margin-left: 12px !important;
  z-index: 1100 !important;
  border-radius: 10px !important;
  border: none !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.12) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 13px !important;
}
.leaflet-control-layers-expanded {
  padding: 12px 14px !important;
  min-width: 180px;
}

/* Animatie voor bewegende marker */
@keyframes pulse-marker {
  0% { filter: brightness(1) drop-shadow(0 0 0 rgba(46,125,85,0)); }
  50% { filter: brightness(1.3) drop-shadow(0 0 8px rgba(46,125,85,0.8)); }
  100% { filter: brightness(1) drop-shadow(0 0 0 rgba(46,125,85,0)); }
}
.moving-marker {
  animation: pulse-marker 1.5s infinite ease-in-out;
  z-index: 2000 !important;
  cursor: move !important;
}

.leaflet-control-layers-list { transition: all 0.3s ease; }
.leaflet-control-layers-list label { display: flex; align-items: center; gap: 6px; padding: 3px 0; cursor: pointer; }
.leaflet-control-layers-separator { border-color: #f0f0f0 !important; margin: 6px 0 !important; }

.leaflet-control-layers-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 8px; border-bottom: 1px solid #eee; padding-bottom: 6px;
}
.leaflet-control-layers-header span:first-child {
  font-size: 11px; font-weight: 700; color: var(--eco-forest); text-transform: uppercase; letter-spacing: 0.5px;
}

.map-ctrl-pin {
  background: none; border: none; cursor: pointer; padding: 2px;
  font-size: 13px; color: #ccc; display: flex; align-items: center;
  transition: color 0.2s, transform 0.2s; border-radius: 4px;
}
.map-ctrl-pin:hover { color: #999; }
.map-ctrl-pin.active { color: var(--eco-leaf); transform: rotate(-45deg); }

.leaflet-control-layers:not(.leaflet-control-layers-expanded) .leaflet-control-layers-header { display: none; }

/* ── Buffer Toolbar ────────────────────── */
.buffer-toolbar {
  background: white;
  padding: 10px;
  border-radius: 10px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.12);
  margin-top: 8px !important;
  margin-left: 12px !important;
  min-width: 80px;
  transition: all 0.25s ease;
  font-family: 'DM Sans', sans-serif;
}
.buffer-toolbar.collapsed {
  min-width: 40px; width: 40px; height: 40px;
  padding: 0; display: flex; align-items: center; justify-content: center;
  cursor: pointer; overflow: hidden; border-radius: 10px;
}
.buffer-toolbar.collapsed > * { display: none !important; }
.buffer-toolbar.collapsed .buffer-collapse-icon { display: flex !important; align-items: center; justify-content: center; }
.buffer-collapse-icon { display: none; }

/* Leaflet toggle override - verberg default background-image */
.leaflet-control-layers-toggle {
  background-image: none !important;
}
.buffer-toolbar .buffer-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 8px; padding-bottom: 6px; border-bottom: 1px solid #eee;
}
.buffer-title {
  font-size: 11px; font-weight: 700; color: var(--eco-forest);
  text-transform: uppercase; letter-spacing: 0.5px;
}
.buffer-toolbar .pin-btn { /* reuse shared style */ }
.buffer-toolbar .map-ctrl-pin { margin: 0; }

.buffer-target-row {
  display: flex; gap: 4px; margin-bottom: 8px; padding-bottom: 8px; border-bottom: 1px solid #eee;
}
.buf-target-btn {
  flex: 1; display: flex; align-items: center; justify-content: center;
  background: #f8faf9; border: 1px solid #e8ece9; border-radius: 6px;
  padding: 7px 8px; cursor: pointer; color: var(--text-muted);
  transition: all 0.15s ease;
}
.buf-target-btn:hover { background: #eef4f0; border-color: var(--eco-mist); }
.buf-target-btn:hover svg { stroke: var(--eco-forest); }
.buf-target-btn.active { background: var(--eco-leaf); color: white; border-color: var(--eco-leaf); }
.buf-target-btn.active svg { stroke: white; }

.buffer-options { display: flex; flex-direction: column; gap: 4px; }
.buf-btn {
  background: #f8faf9; border: 1px solid #e8ece9; border-radius: 6px;
  padding: 6px 10px; font-size: 12px; cursor: pointer; text-align: center;
  transition: all 0.15s ease; color: var(--text-mid); font-family: inherit;
  font-weight: 500; white-space: nowrap;
}
.buf-btn:hover { background: #eef4f0; border-color: var(--eco-mist); color: var(--eco-forest); }
.buf-btn.active {
  background: var(--eco-forest); color: white;
  border-color: var(--eco-forest); font-weight: 600;
  box-shadow: 0 1px 4px rgba(26,77,53,0.3);
}

/* Place hint */
.place-hint{
  position:absolute;top:12px;left:50%;transform:translateX(-50%);
  z-index:1000;
  background:var(--eco-forest);
  color:#fff;
  padding:9px 20px;
  border-radius:100px;
  font-size:13px;font-weight:500;
  pointer-events:none;opacity:0;
  transition:opacity .3s;
  white-space:nowrap;
  box-shadow:0 4px 14px rgba(26,77,53,0.4);
  font-family:'DM Sans',sans-serif;
}
.place-hint.show{opacity:1}

/* ─── MODAL (DEPRECATED -> SECTION PAGE) ───────────────── */
.overlay{
  position:fixed;inset:0;
  background:rgba(13,43,31,0.45);
  z-index:4000;
  display:none;align-items:center;justify-content:center;padding:20px;
  backdrop-filter:blur(2px);
}
.overlay.open{display:none} /* Disabled */

.modal{
  background:var(--surface);
  border-radius:16px;
  width:100%;max-width:490px;
  display:flex;flex-direction:column;
}

/* Nieuwe container voor secties die voorheen modals waren */
.section-page {
  background: #fff;
  max-height: 95vh;
  flex: 1;
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 4px 15px rgba(0,0,0,0.05);
  border: 1px solid #eee;
}
.section-page .mhdr {
  padding: 20px 30px;
}
.section-page .mbody {
  padding: 30px;
  flex: 1;
  overflow-y: auto;
}
.section-page .mftr {
  padding: 20px 30px;
  background: #fafafa;
  border-top: 1px solid #eee;
}
.mhdr{
  background:var(--eco-deep);
  color:#fff;
  padding:18px 20px;
  border-radius:16px 16px 0 0;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:2px solid var(--eco-leaf);
}
.mhdr-logo{display:flex;align-items:center;gap:10px}
.mhdr-icon{
  width:30px;height:30px;
  background:var(--eco-leaf);
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
}
.mhdr-icon svg{width:17px;height:17px}
.mhdr h2{font-size:14px;font-weight:500;color:rgba(255,255,255,0.95)}
.mstep{font-size:11px;color:rgba(255,255,255,0.45);margin-top:2px;font-weight:300}
.mclose{
  background:none;border:none;
  color:rgba(255,255,255,0.5);
  font-size:18px;cursor:pointer;
  padding:4px 8px;border-radius:6px;
  transition:all .12s;
  line-height:1;
}
.mclose:hover{background:rgba(255,255,255,0.1);color:#fff}

/* Progress stepper */
.stepper{
  display:flex;align-items:center;
  padding:12px 20px;
  border-bottom:1px solid var(--border);
  gap:0;
}
.step-item{display:flex;align-items:center;flex:1}
.step-dot{
  width:24px;height:24px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:600;
  border:1.5px solid var(--border-md);
  color:var(--text-muted);
  background:var(--surface);
  flex-shrink:0;
  transition:all .2s;
  font-family:'DM Sans',sans-serif;
}
.step-dot.active{background:var(--eco-leaf);color:#fff;border-color:var(--eco-leaf)}
.step-dot.done{background:var(--eco-light);color:var(--eco-forest);border-color:var(--eco-mist)}
.step-label{font-size:11px;color:var(--text-muted);margin-left:6px;font-weight:400;white-space:nowrap}
.step-label.active{color:var(--eco-forest);font-weight:500}
.step-line{flex:1;height:1px;background:var(--border);margin:0 8px}
.step-line.done{background:var(--eco-mist)}

.mbody{padding:20px; overflow-y: auto;}

/* Location bar */
.loc-bar{
  background:var(--eco-light);
  border:1px solid rgba(46,125,85,0.2);
  border-radius:9px;
  padding:10px 14px;
  font-size:12px;color:var(--eco-forest);
  display:flex;align-items:center;gap:8px;
  margin-bottom:18px;
  font-weight:500;
}
.loc-bar svg{width:14px;height:14px;flex-shrink:0}

/* Form groups */
.fg{margin-bottom:16px}
.fg label{
  display:block;
  font-size:11px;font-weight:600;
  color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.5px;
  margin-bottom:6px;
}
.fg select,.fg input,.fg textarea{
  width:100%;
  padding:9px 12px;
  border:1px solid var(--border-md);
  border-radius:9px;
  font-size:14px;
  color:var(--text);
  background:#fff;
  transition:border-color .15s,box-shadow .15s;
  appearance:none;
  font-family:'DM Sans',sans-serif;
}
.fg select:focus,.fg input:focus,.fg textarea:focus{
  outline:none;
  border-color:var(--eco-sage);
  box-shadow:0 0 0 3px rgba(82,168,120,0.15);
}
.fg textarea{resize:vertical;min-height:70px}

/* Type cards */
.tgrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.tc{
  border:1.5px solid var(--border-md);
  border-radius:10px;
  padding:13px 10px;
  cursor:pointer;
  text-align:center;
  transition:all .15s;
  background:#fff;
}
.tc:hover{border-color:var(--eco-sage);background:var(--eco-light)}
.tc.sel{border-color:var(--eco-leaf);background:var(--eco-light);box-shadow:0 0 0 3px rgba(46,125,85,0.12)}
.tc.sel-schade{border-color:var(--eco-amber);background:var(--eco-amber-l);box-shadow:0 0 0 3px rgba(212,130,26,0.12)}
.tc.sel-aanrijding{border-color:#B53A2A;background:#FAEAE7;box-shadow:0 0 0 3px rgba(181,58,42,0.10)}
.tc.sel-beheer{border-color:var(--bij12);background:var(--bij12-light);box-shadow:0 0 0 3px rgba(27,92,158,0.10)}
.tc-icon{font-size:22px;margin-bottom:4px}
.tc-lbl{font-size:12px;font-weight:600;color:var(--text)}
.tc-desc{font-size:11px;color:var(--text-muted);margin-top:2px;font-weight:300}

/* Upload zone */
.upz{
  border:1.5px dashed var(--border-md);
  border-radius:10px;
  padding:24px;text-align:center;cursor:pointer;
  transition:all .15s;
  background:var(--eco-chalk);
}
.upz:hover{border-color:var(--eco-sage);background:var(--eco-light)}
.upz.got{border-color:var(--eco-leaf);background:var(--eco-light)}
.upico{font-size:26px;margin-bottom:6px}
.upt{font-size:13px;color:var(--text-muted)}
.ups{font-size:11px;color:var(--text-muted);margin-top:3px;font-weight:300}
.uprev{margin-top:10px;display:none}
.uprev img{max-width:100%;max-height:150px;border-radius:8px;border:1px solid var(--border)}
.uprev.v{display:block}

/* Summary box */
.sum-box{
  background:var(--eco-light);
  border:1px solid rgba(46,125,85,0.15);
  border-radius:10px;
  padding:14px;
  font-size:13px;
  line-height:2;
  color:var(--text-mid);
}
.sum-box strong{color:var(--text);font-weight:600}

/* Modal footer */
.mftr{
  padding:14px 20px;
  border-top:1px solid var(--border);
  display:flex;gap:8px;justify-content:flex-end;
  background:var(--eco-chalk);
  border-radius:0 0 16px 16px;
}
.btn{
  padding:9px 20px;
  border-radius:9px;
  font-size:13px;font-weight:500;
  cursor:pointer;
  transition:all .15s;
  border:1px solid transparent;
  font-family:'DM Sans',sans-serif;
  display:inline-flex;align-items:center;gap:6px;
}
.btn-g{background:none;border-color:var(--border-md);color:var(--text-muted)}
.btn-g:hover{background:var(--eco-light);color:var(--text-mid)}
.btn-p{background:var(--eco-leaf);color:#fff;border-color:var(--eco-leaf)}
.btn-p:hover{background:var(--eco-forest);border-color:var(--eco-forest)}

/* Notifications Grid & Cards */
.notif-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  margin-top: 10px;
}

.notif-card {
  position: relative;
  cursor: pointer;
  display: block;
}

.notif-card input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.notif-card-inner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px;
  background: #fff;
  border: 2px solid var(--border-md);
  border-radius: 12px;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 2px 4px rgba(0,0,0,0.02);
}

.notif-card:hover .notif-card-inner {
  border-color: var(--eco-sage);
  background: var(--eco-chalk);
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0,0,0,0.05);
}

.notif-card input[type="checkbox"]:checked + .notif-card-inner {
  border-color: var(--eco-leaf);
  background: rgba(46, 125, 85, 0.05);
  box-shadow: 0 4px 12px rgba(46, 125, 85, 0.1);
}

.notif-card-icon {
  width: 42px;
  height: 42px;
  background: var(--eco-light);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  color: var(--eco-leaf);
  transition: all 0.2s;
}

.notif-card input[type="checkbox"]:checked + .notif-card-inner .notif-card-icon {
  background: var(--eco-leaf);
  color: #fff;
}

.notif-card-content {
  display: flex;
  flex-direction: column;
}

.notif-card-title {
  font-weight: 600;
  font-size: 15px;
  color: var(--text-deep);
}

.notif-card-status {
  font-size: 12px;
  color: var(--text-muted);
}

.notif-card input[type="checkbox"]:checked + .notif-card-inner .notif-card-status {
  color: var(--eco-leaf);
  font-weight: 500;
}

.notif-card input[type="checkbox"]:checked + .notif-card-inner .notif-card-status::after {
  content: " (Actief)";
}

/* ─── BERICHTEN ───────────────────────────── */
.reg-table-container {
  flex: 1;
  overflow: auto;
  margin-top: 15px;
  min-height: 0;
}
.reg-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.reg-table th {
  text-align: left;
  padding: 12px 10px;
  background: var(--eco-chalk);
  color: var(--eco-deep);
  font-weight: 600;
  border-bottom: 2px solid var(--border-md);
}
.reg-table td {
  padding: 10px;
  border-bottom: 1px solid var(--border);
  color: var(--text-deep);
}
.reg-table tr:hover {
  background: rgba(46, 125, 85, 0.03);
}
.filter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 15px;
  margin-bottom: 20px;
  background: #fcfdfc;
  padding: 15px;
  border-radius: 10px;
  border: 1px solid var(--border-md);
}
.tab-row {
  display: flex;
  gap: 20px;
  border-bottom: 1px solid var(--border-md);
  margin-bottom: 15px;
}
.tab-btn {
  padding: 8px 4px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-muted);
  cursor: pointer;
  border-bottom: 2px solid transparent;
}
.tab-btn.active {
  color: var(--eco-leaf);
  border-bottom-color: var(--eco-leaf);
}
.badge {
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
}

/* ─── BERICHTEN ───────────────────────────── */
.msg-date-group {
  margin-bottom: 24px;
}
.msg-date-hdr {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 12px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.msg-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--border-md);
  border-radius: 9px;
  margin-bottom: 10px;
  transition: all 0.2s;
}
.msg-item.unread {
  border-left: 3px solid var(--eco-leaf);
  background: var(--eco-chalk);
}
.msg-icon {
  width: 32px;
  height: 32px;
  background: var(--eco-light);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--eco-leaf);
}
.msg-content {
  flex: 1;
}
.msg-title {
  font-weight: 600;
  font-size: 13px;
  color: var(--eco-deep);
  margin-bottom: 2px;
}
.msg-text {
  font-size: 12px;
  color: var(--text-mid);
  line-height: 1.4;
}

/* ─── TOAST ───────────────────────────────────── */
.toast{
  position:fixed;bottom:22px;left:50%;
  transform:translateX(-50%) translateY(80px);
  background:var(--eco-deep);
  color:#fff;
  padding:11px 20px;
  border-radius:10px;
  font-size:13px;font-weight:500;
  z-index:9999;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 4px 20px rgba(13,43,31,0.35);
  transition:transform .3s ease;
  white-space:nowrap;
  border-left:3px solid var(--eco-sage);
  font-family:'DM Sans',sans-serif;
}
.toast.show{transform:translateX(-50%) translateY(0)}
.tico{
  background:var(--eco-leaf);
  border-radius:50%;
  width:20px;height:20px;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;flex-shrink:0;
}

/* ─── LEAFLET POPUP ───────────────────────────── */
.leaflet-popup-content-wrapper{
  border-radius:12px!important;
  box-shadow:0 4px 20px rgba(13,43,31,0.15)!important;
  padding:0!important;overflow:hidden;
  font-family:'DM Sans',sans-serif!important;
}
.leaflet-popup-content{margin:0!important;width:220px!important}
.leaflet-popup-tip-container{display:none}
.pop{padding:12px 14px}
.pop-t{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;margin-bottom:3px}
.pop-s{font-size:15px;font-weight:600;color:#0D2B1F}
.pop-m{font-size:11px;color:#6B8C7B;margin-top:3px;font-weight:300}
.pop-d{height:1px;background:rgba(13,43,31,0.08);margin:7px 0}

.active-item {
  background-color: #f1f8e9 !important;
  border-left: 4px solid var(--eco-forest) !important;
  color: var(--eco-forest) !important;
  font-weight: 600 !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  transform: translateX(2px);
  transition: all 0.2s ease;
}

.reg-table tr.active-item td {
  background-color: #f1f8e9 !important;
}

.sidebar-parcel-item {
  padding: 8px 12px;
  margin-bottom: 5px;
  border-radius: 4px;
  border-left: 4px solid transparent;
  cursor: pointer;
  transition: all 0.2s;
  display: block;
  background: white;
  border: 1px solid #f0f0f0;
}

.sidebar-parcel-item:hover {
  background-color: #f9f9f9;
  border-color: #ddd;
}

/* ─── SCROLLBAR ───────────────────────────────── */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-thumb{background:var(--eco-mist);border-radius:4px}

/* ─── BIJ12 BADGE in header ──────────────────── */
.bij12-badge{
  font-size:10px;
  color:rgba(255,255,255,0.35);
  font-weight:300;
  display:flex;align-items:center;gap:5px;
  padding-left:12px;
  border-left:1px solid rgba(255,255,255,0.1);
  margin-left:4px;
  white-space:nowrap;
}
.bij12-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--bij12);
  flex-shrink:0;
}
  .modal-tabs {
    display: flex;
    border-bottom: 1px solid #eee;
    background: #f8f9fa;
  }
  .tab-btn {
    padding: 12px 25px;
    border: none;
    background: none;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    color: var(--text-mid);
    border-bottom: 2px solid transparent;
    transition: all 0.2s;
  }
  .tab-btn:hover {
    color: var(--primary);
  }
  .tab-btn.active {
    color: var(--primary);
    border-bottom-color: var(--primary);
    background: white;
  }
  .tab-pane {
    animation: fadeIn 0.3s;
    height: 100%;
  }

.leaflet-control-attribution {
  font-size: 9px !important;
  opacity: 0.7;
  background: rgba(255, 255, 255, 0.7) !important;
}

.leaflet-control-attribution a {
  color: #666 !important;
  text-decoration: none;
}

.leaflet-control-attribution a:hover {
  text-decoration: underline;
}

/* ── CMS Content (Help & Handleiding) ──── */
.cms-content {
  padding: 30px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--text);
}
.cms-content h2 {
  font-family: 'DM Serif Display', serif;
  font-size: 26px; font-weight: 400; color: var(--eco-deep);
  margin: 0 0 8px 0; padding-bottom: 12px;
  border-bottom: 2px solid var(--eco-mist);
}
.cms-content h3 {
  font-size: 17px; font-weight: 600; color: var(--eco-forest);
  margin: 28px 0 10px 0; padding-left: 12px;
  border-left: 3px solid var(--eco-leaf);
}
.cms-content h4 {
  font-size: 14px; font-weight: 600; color: var(--text-mid);
  margin: 20px 0 6px 0;
}
.cms-content p {
  margin: 0 0 14px 0;
}
.cms-content ul, .cms-content ol {
  margin: 0 0 16px 0; padding-left: 24px;
}
.cms-content li {
  margin-bottom: 6px;
}
.cms-content li strong {
  color: var(--eco-forest);
}
.cms-content a {
  color: var(--eco-leaf); text-decoration: none; font-weight: 500;
  border-bottom: 1px solid transparent; transition: border-color 0.2s;
}
.cms-content a:hover {
  border-bottom-color: var(--eco-leaf);
}
.cms-content blockquote {
  margin: 16px 0; padding: 12px 20px;
  border-left: 4px solid var(--eco-mist);
  background: var(--eco-light); border-radius: 0 6px 6px 0;
  color: var(--text-mid); font-style: italic;
}
.cms-content code {
  background: #f0f4f2; padding: 2px 6px; border-radius: 4px;
  font-size: 13px; color: var(--eco-forest);
}
.cms-content pre {
  background: var(--eco-deep); color: var(--eco-mist);
  padding: 16px 20px; border-radius: 8px; overflow-x: auto;
  font-size: 13px; line-height: 1.5; margin: 16px 0;
}
.cms-content pre code {
  background: none; padding: 0; color: inherit;
}
.cms-content img {
  max-width: 100%; height: auto; border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08); margin: 12px 0;
}
.cms-content table {
  width: 100%; border-collapse: collapse; margin: 16px 0; font-size: 13px;
}
.cms-content th {
  background: var(--eco-light); font-weight: 600; color: var(--eco-forest);
  text-align: left; padding: 10px 12px; border-bottom: 2px solid var(--eco-mist);
}
.cms-content td {
  padding: 8px 12px; border-bottom: 1px solid #f0f0f0;
}
.cms-content tr:hover td { background: #fafcfb; }
.cms-content hr {
  border: none; border-top: 1px solid #eee; margin: 24px 0;
}

.cms-empty {
  text-align: center; padding: 60px 20px; color: var(--text-muted);
}
.cms-empty svg { margin-bottom: 15px; opacity: 0.4; }
.cms-empty h3 { margin-bottom: 8px; color: var(--text-mid); font-size: 16px; }
.cms-empty p { font-size: 14px; }

/* ══════════════════════════════════════════════════════
 *  DESIGN SYSTEM - Buttons, Tabellen, Modals, Forms
 *  Centraal gedefinieerd voor consistentie
 * ══════════════════════════════════════════════════════ */

/* ─── Buttons ──────────────────────────────── */
.btn-primary{background:var(--eco-leaf);color:#fff;border-color:var(--eco-leaf)}
.btn-primary:hover{background:var(--eco-forest);border-color:var(--eco-forest)}
.btn-secondary{background:none;border-color:var(--border-md);color:var(--text-muted)}
.btn-secondary:hover{background:var(--eco-light);color:var(--text-mid)}
.btn-danger{background:#B53A2A;color:#fff;border-color:#B53A2A}
.btn-danger:hover{background:#9A2E22;border-color:#9A2E22}
.btn-sm{padding:5px 12px;font-size:12px;border-radius:7px}
.btn-xs{padding:3px 8px;font-size:11px;border-radius:6px}
.btn-icon{background:none;border:none;cursor:pointer;padding:4px;border-radius:6px;color:var(--text-muted);transition:all .15s;display:inline-flex;align-items:center}
.btn-icon:hover{background:var(--eco-light);color:var(--eco-leaf)}
.btn-icon-danger{color:#B53A2A}
.btn-icon-danger:hover{background:#FEF2F2;color:#9A2E22}

/* ─── Tabel (unified: vervangt .reg-table en .admin-table) ── */
/* ─── Card layout (admin pagina's) ─────── */
.card{
  display:flex;flex-direction:column;
  flex:1;min-height:0;
  background:#fff;border-radius:12px;
  box-shadow:0 1px 4px rgba(0,0,0,0.04);
  border:1px solid var(--border);
  overflow:hidden;
}
.card-hdr{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 24px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.card-title{margin:0;font-size:17px;font-weight:600;color:var(--eco-forest)}
.card-body{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}

.data-table-container{overflow:auto;flex:1;min-height:0}
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{
  text-align:left;padding:10px 14px;
  background:var(--eco-chalk);color:var(--text-mid);
  font-weight:600;font-size:12px;
  border-bottom:2px solid var(--border-md);
  text-transform:uppercase;letter-spacing:0.3px;
  white-space:nowrap;
}
.data-table td{
  padding:10px 14px;
  border-bottom:1px solid var(--border);
  color:var(--text);
  vertical-align:middle;
}
.data-table tr:hover{background:rgba(46,125,85,0.03)}
.data-table tr.active-item td{background:var(--eco-light)}
.data-table .td-actions{white-space:nowrap;text-align:right}
.data-table .td-center{text-align:center}
.data-table .td-num{text-align:right;font-variant-numeric:tabular-nums}
.data-table .empty-row td{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:13px}

/* ─── Admin Overlay & Modal (centraal) ────── */
.admin-overlay{
  position:fixed;inset:0;
  background:rgba(13,43,31,0.45);
  display:flex;align-items:center;justify-content:center;
  z-index:2000;
  backdrop-filter:blur(2px);
  animation:fadeIn .2s ease;
}
.admin-modal{
  background:#fff;border-radius:14px;
  width:560px;max-width:92%;
  box-shadow:0 20px 50px rgba(0,0,0,0.15);
  overflow:hidden;
  animation:slideUp .25s ease;
}
.admin-modal-hdr{
  padding:16px 24px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  background:var(--eco-chalk);
}
.admin-modal-hdr h3{margin:0;font-size:17px;font-weight:600;color:var(--eco-forest)}
.admin-modal-body{padding:24px;max-height:80vh;overflow-y:auto}
.admin-modal-ftr{
  padding:16px 24px;
  border-top:1px solid var(--border);
  display:flex;justify-content:flex-end;gap:10px;
  background:var(--eco-chalk);
}
.admin-modal.wide{width:720px}

@keyframes slideUp{
  from{transform:translateY(20px);opacity:0}
  to{transform:translateY(0);opacity:1}
}

/* ─── Form verbeteringen ──────────────────── */
.fg label{
  text-transform:none;
  font-size:13px;font-weight:500;
  color:var(--text-mid);
  letter-spacing:0;
}
.form-row{display:grid;gap:16px}
.form-row-2{grid-template-columns:1fr 1fr}
.form-row-3{grid-template-columns:1fr 1fr 1fr}
.form-row-auto{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.form-hint{font-size:11px;color:var(--text-muted);margin-top:4px}
.form-divider{border:none;border-top:1px solid var(--border);margin:20px 0}

/* ─── Toast verbeteringen ─────────────────── */
.toast.error{border-left-color:#B53A2A}
.toast.error .tico{background:#B53A2A}
.toast.warning{border-left-color:var(--eco-amber)}
.toast.warning .tico{background:var(--eco-amber)}

/* ─── Focus & Accessibility ───────────────── */
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:var(--eco-sage);
  box-shadow:0 0 0 3px rgba(82,168,120,0.15);
  outline:none;
}
.btn:focus-visible{
  outline:2px solid var(--eco-sage);
  outline-offset:2px;
}

/* ─── Status badges ───────────────────────── */
.status-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 10px;border-radius:20px;
  font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:0.3px;
}
.status-open{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}
.status-gesloten{background:#F1F5F9;color:#64748B;border:1px solid #e2e8f0}
.status-actief{background:#DBEAFE;color:#1E40AF;border:1px solid #bfdbfe}
.status-warning{background:#fff7ed;color:#c2410c;border:1px solid #fdba74}

/* ─── Table helpers ────────────────────────── */
.td-clickable{cursor:pointer}
.td-loading{text-align:center;padding:30px 20px;color:var(--text-muted);font-style:italic}
.td-error{text-align:center;padding:30px 20px;color:#B53A2A}
.td-empty{text-align:center;padding:30px 20px;color:var(--text-muted);font-size:13px}
.td-clickable{cursor:pointer}

/* ─── Header user info ─────────────────────── */
.hdr-user{display:flex;align-items:center;gap:12px}
.hdr-user-info{text-align:right}
.hdr-user-name{font-size:12px;font-weight:600;color:#fff}
.hdr-user-email{font-size:10px;color:rgba(255,255,255,0.6)}
.hdr-tenant-select{
  font-size:10px;color:rgba(255,255,255,0.8);
  background:transparent;border:1px solid rgba(255,255,255,0.2);
  outline:none;border-radius:3px;
  font-family:'DM Sans',sans-serif;
}
.hdr-tenant-select option{color:#000}
.hdr-logo-img{height:24px;width:auto;display:block}
.hdr-logo-img.large{height:45px}

/* ─── Progress bar ─────────────────────────── */
.progress-bar{display:flex;align-items:center;gap:10px}
.progress-track{flex:1;height:6px;background:#eee;border-radius:3px;overflow:hidden;min-width:60px}
.progress-track.sm{height:4px;min-width:40px}
.progress-fill{height:100%;border-radius:3px;transition:width 0.3s}
.progress-label{font-weight:bold;font-size:12px;min-width:35px;text-align:right}
.progress-sub{font-size:10px;color:#999;margin-top:2px}

/* ─── List items / cards ───────────────────── */
.list-card{
  background:#fff;border:1px solid #eee;border-radius:8px;
  padding:15px;display:flex;align-items:flex-start;gap:12px;
  position:relative;overflow:hidden;
}
.list-card-accent{position:absolute;left:0;top:0;bottom:0;width:4px}
.list-card-avatar{
  width:44px;height:44px;border-radius:50%;
  background:#f0f4f2;border:2px solid #eee;
  display:flex;align-items:center;justify-content:center;
  font-weight:bold;color:var(--eco-leaf);flex-shrink:0;font-size:16px;
}
.list-card-body{flex:1;min-width:0}
.list-card-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px}
.list-card-name{font-weight:700;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-card-meta{font-size:12px;color:var(--text-muted);margin-bottom:8px;display:flex;align-items:center;gap:5px}
.list-card-tags{display:flex;flex-wrap:wrap;gap:6px}

/* ─── Color swatch ─────────────────────────── */
.color-swatch{
  width:20px;height:20px;border-radius:4px;
  display:inline-block;vertical-align:middle;margin-right:8px;
}

/* ─── Modal Tabellen & Tabs ────────────────── */
.modal-tabs {
  display: flex;
  gap: 5px;
  border-bottom: 1px solid #ddd;
  margin-bottom: 15px;
}
.tab-btn {
  padding: 8px 15px;
  border: 1px solid transparent;
  border-bottom: none;
  background: none;
  cursor: pointer;
  font-size: 14px;
  color: #666;
  border-radius: 4px 4px 0 0;
  margin-bottom: -1px;
}
.tab-btn.active {
  background: #fff;
  border-color: #ddd;
  border-bottom: 1px solid #fff;
  color: var(--primary);
  font-weight: bold;
}
.edit-tab-content {
  background: #fff;
  padding: 10px 0;
}

/* ─── Parcel list item ─────────────────────── */
.parcel-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px;border-bottom:1px solid #eee;
}
.parcel-item-name{font-weight:600;color:var(--text);font-size:14px}
.parcel-item-label{font-size:12px;color:var(--text-mid)}

/* ─── Empty state ──────────────────────────── */
.empty-state{padding:20px;text-align:center;color:var(--text-muted);font-size:12px}

/* ─── Inline detail text ───────────────────── */
.text-xs{font-size:10px}.text-sm{font-size:11px}.text-md{font-size:12px}
.text-muted{color:var(--text-muted)}.text-mid{color:var(--text-mid)}
.text-success{color:var(--eco-leaf)}.text-warning{color:#d97706}.text-danger{color:#B53A2A}
.text-bold{font-weight:600}.text-heavy{font-weight:700}
.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}
.gap-sm{gap:5px}.gap-md{gap:8px}.gap-lg{gap:12px}
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}
.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}
.nowrap{white-space:nowrap}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ══════════════════════════════════════════════════════
 *  RESPONSIVE - Mobile & Tablet
 *  Desktop layout blijft 100% ongewijzigd.
 *  Alle wijzigingen zitten ALLEEN in @media blokken.
 * ══════════════════════════════════════════════════════ */

/* ─── Drawer overlay (mobile sidepanel) ───────── */
.drawer-overlay{
  position:fixed;inset:0;
  background:rgba(13,43,31,0.5);
  z-index:1499;
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;
  display:none;
}
.drawer-overlay.on{opacity:1;pointer-events:auto}

/* ─── Mobile Bottom Nav ──────────────────────────── */
.mobile-bnav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  height:var(--bnav-h);
  background:var(--eco-deep);
  border-top:2px solid var(--eco-leaf);
  z-index:1600;
  padding:0 4px;
  padding-bottom:var(--safe-bottom);
}
.mobile-bnav-inner{
  display:flex;align-items:center;
  justify-content:space-around;
  height:100%;max-width:500px;margin:0 auto;
}
.bnav-item{
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:2px;padding:6px 8px;
  color:rgba(255,255,255,0.5);
  text-decoration:none;
  font-size:10px;font-weight:500;
  transition:color .15s;position:relative;
  -webkit-tap-highlight-color:transparent;
  min-width:52px;
}
.bnav-item svg{width:22px;height:22px;flex-shrink:0}
.bnav-item.active,.bnav-item:active{color:#fff}
.bnav-item.active::after{
  content:'';position:absolute;top:0;left:25%;right:25%;
  height:2px;background:var(--eco-leaf);border-radius:0 0 2px 2px;
}
.bnav-fab{
  width:50px;height:50px;
  background:var(--eco-leaf);
  border:3px solid var(--eco-deep);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:24px;line-height:1;
  margin-top:-22px;
  box-shadow:0 2px 12px rgba(46,125,85,0.4);
  cursor:pointer;text-decoration:none;
  -webkit-tap-highlight-color:transparent;
}
.bnav-badge{
  position:absolute;top:2px;right:8px;
  background:#8b1a1a;color:#fff;
  font-size:9px;font-weight:700;
  min-width:16px;height:16px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  padding:0 4px;
}
.bnav-badge:empty{display:none}

/* ═══ TABLET (768 – 1024) ═══════════════════════ */
@media(max-width:1024px){
  .sidepanel{width:200px}
  .sidebar{width:220px}
  .section-page .mhdr{padding:16px 20px}
  .section-page .mbody{padding:20px}
  .cms-content{padding:20px}
}

/* ═══ MOBILE (< 768px) ═════════════════════════ */
@media(max-width:767px){

  /* ── Body & App container ─────────── */
  body{
    overflow-y:auto;overflow-x:hidden;
    height:auto;min-height:100vh;min-height:100dvh;
  }
  .app-container{
    flex-direction:column;overflow:visible;min-height:0;
  }
  .main{overflow:visible;flex:1}
  .main-content{
    flex-direction:column;overflow:visible;height:auto;
  }

  /* ── Header compact ───────────────── */
  header{height:48px;padding:0 12px}
  .hdr-divider,.hdr-org,.bij12-badge{display:none}
  .hdr-l{gap:10px}
  .logo-name{font-size:17px}
  .logo-icon-box{width:30px;height:30px;border-radius:7px}
  .logo-icon-box svg{width:17px;height:17px}
  .hdr-btn{padding:5px 10px;font-size:11px}
  /* Verberg user naam/rol in header, behoud logout knop */
  #authBtnContainer > div > div:first-child{display:none}

  /* ── Sidepanel als drawer overlay ──── */
  .drawer-overlay{display:block}
  .sidepanel{
    position:fixed;top:0;left:0;bottom:0;
    width:280px;
    transform:translateX(-100%);
    transition:transform .3s cubic-bezier(.4,0,.2,1);
    z-index:1500;
    height:100vh;height:100dvh;
  }
  .sidepanel.collapsed{
    width:280px;transform:translateX(-100%);
  }
  .sidepanel.mobile-open{
    transform:translateX(0)!important;
    width:280px!important;
  }
  /* Verberg admin menu op mobiel */
  #adminMenu{display:none!important}

  /* ── Bottom nav zichtbaar ─────────── */
  .mobile-bnav{display:block}

  /* ── Content spacing voor bottom nav ── */
  .section-page{
    border-radius:0;border:none;box-shadow:none;
    max-height:none;
    min-height:calc(100vh - 48px - var(--bnav-h));
    min-height:calc(100dvh - 48px - var(--bnav-h));
    margin-bottom:var(--bnav-h);
    overflow:visible;
  }
  .section-page .mbody{
    overflow:visible!important;
    overflow-y:auto!important;
    -webkit-overflow-scrolling:touch;
    height:auto!important;
    flex:none!important;
  }
  .section-page .mhdr{padding:14px 16px;border-radius:0}
  .mhdr h2{font-size:13px}
  .mstep{font-size:10px}
  .mhdr-icon{width:26px;height:26px;border-radius:6px}
  .section-page .mbody{padding:14px}
  .section-page .mftr{padding:12px 14px}

  /* ── Dashboard: kaart fullscreen, sidebar verborgen ── */
  #map-section{
    flex-direction:column;
    height:calc(100vh - 48px - var(--bnav-h));
    height:calc(100dvh - 48px - var(--bnav-h));
  }
  #map-section .sidebar{display:none}
  .map-wrap{flex:1;min-height:300px}
  .fab{bottom:16px;right:16px;width:48px;height:48px;font-size:22px}
  .mctrls{top:10px;right:10px}
  .mb{width:38px;height:38px;font-size:18px}
  .place-hint{
    font-size:12px;padding:8px 16px;
    top:8px;max-width:calc(100% - 80px);
    white-space:normal;text-align:center;
  }

  /* ── Leaflet controls ─────────────── */
  .leaflet-control-layers{margin-top:8px!important;margin-left:8px!important;font-size:12px!important}
  .buffer-toolbar{margin-left:8px!important;font-size:12px}

  /* ── Toolbar ──────────────────────── */
  .toolbar{padding:6px 12px;gap:6px;flex-wrap:wrap}
  .pill{padding:4px 10px;font-size:11px}
  .chip{font-size:11px;padding:4px 9px}

  /* ── Tabellen: horizontal scroll ──── */
  .data-table-container{
    overflow-x:auto;-webkit-overflow-scrolling:touch;
    margin:0 -14px;padding:0 14px;
  }
  .data-table{min-width:600px}
  .data-table th,.data-table td{padding:8px 10px;font-size:12px}

  /* ── Filter grid: stapelen ────────── */
  .filter-grid{grid-template-columns:1fr;gap:10px;padding:12px;margin:0 0 12px}

  /* ── Tab row ──────────────────────── */
  .tab-row{
    gap:10px;overflow-x:auto;-webkit-overflow-scrolling:touch;
    flex-wrap:nowrap;padding-bottom:2px;
  }
  .tab-btn{font-size:13px;padding:6px 2px;white-space:nowrap}

  /* ── Wizard: fullscreen overlay ───── */
  .wiz-overlay{
    position:fixed;inset:0;z-index:2500;
    background:#fff;display:none;flex-direction:column;overflow:hidden;
  }
  .wiz-overlay.on{display:flex}
  .wiz-header{
    display:flex;align-items:center;gap:10px;
    padding:14px 16px;background:var(--eco-deep);
    color:#fff;border-bottom:2px solid var(--eco-leaf);flex-shrink:0;
  }
  .wiz-header-ico{font-size:20px}
  .wiz-header-inf{flex:1}
  .wiz-header-ttl{font-size:14px;font-weight:600}
  .wiz-header-sub{font-size:11px;color:rgba(255,255,255,0.5)}
  .wiz-header-cls{
    margin-left:auto;background:none;border:none;
    color:rgba(255,255,255,0.6);font-size:24px;cursor:pointer;padding:6px 10px;
  }
  .wiz-dots{
    display:flex;justify-content:center;gap:8px;
    padding:12px 16px;background:var(--eco-chalk);
    border-bottom:1px solid var(--border);flex-shrink:0;
  }
  .wiz-dot{width:10px;height:10px;border-radius:50%;background:var(--border-md);transition:all .2s}
  .wiz-dot.act{background:var(--eco-leaf);transform:scale(1.3)}
  .wiz-dot.done{background:var(--eco-sage)}
  .wiz-body{flex:1;overflow-y:auto;padding:20px 16px;-webkit-overflow-scrolling:touch}
  .wiz-step-lbl{font-size:16px;font-weight:600;color:var(--eco-forest);margin-bottom:16px}
  .wiz-loc{
    background:var(--eco-light);border:1px solid rgba(46,125,85,0.2);
    border-radius:8px;padding:10px 14px;font-size:12px;color:var(--eco-forest);margin-bottom:16px;
  }
  .wiz-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .wiz-type-card{
    border:2px solid var(--border-md);border-radius:12px;
    padding:16px 10px;text-align:center;cursor:pointer;
    transition:all .15s;background:#fff;
  }
  .wiz-type-card.sel{
    border-color:var(--eco-leaf);background:var(--eco-light);
    box-shadow:0 0 0 3px rgba(46,125,85,0.12);
  }
  .wiz-type-ico{font-size:28px;margin-bottom:6px}
  .wiz-type-nm{font-size:13px;font-weight:600;color:var(--text)}
  .wiz-type-sb{font-size:11px;color:var(--text-muted);margin-top:2px}
  .wiz-footer{
    display:flex;gap:8px;padding:14px 16px;
    border-top:1px solid var(--border);background:var(--eco-chalk);
    flex-shrink:0;padding-bottom:calc(14px + var(--safe-bottom));
  }
  .btn-wiz-cancel,.btn-wiz-prev,.btn-wiz-next{
    padding:11px 18px;border-radius:10px;font-size:14px;font-weight:500;
    cursor:pointer;font-family:'DM Sans',sans-serif;border:1px solid transparent;
  }
  .btn-wiz-cancel{background:none;border-color:var(--border-md);color:var(--text-muted)}
  .btn-wiz-prev{background:none;border-color:var(--border-md);color:var(--text-mid)}
  .btn-wiz-next{
    background:var(--eco-leaf);color:#fff;border-color:var(--eco-leaf);
    margin-left:auto;flex:1;max-width:200px;text-align:center;
  }
  .wiz-sum{margin-top:16px}
  .wiz-sum-row{
    display:flex;justify-content:space-between;
    padding:8px 0;border-bottom:1px solid var(--border);font-size:13px;
  }
  .wiz-sum-l{color:var(--text-muted);font-weight:500}
  .wiz-sum-v{color:var(--text);font-weight:600}
  .foto-zone{
    border:2px dashed var(--border-md);border-radius:12px;
    padding:30px 20px;text-align:center;cursor:pointer;background:var(--eco-chalk);
  }
  .foto-zone-ico{font-size:32px;margin-bottom:8px}
  .form-group{margin-bottom:14px}
  .f-lbl{display:block;font-size:12px;font-weight:600;color:var(--text-mid);margin-bottom:6px}
  .f-inp,.f-sel{
    width:100%;padding:11px 12px;border:1px solid var(--border-md);
    border-radius:9px;font-size:16px;font-family:'DM Sans',sans-serif;
    color:var(--text);background:#fff;-webkit-appearance:none;
  }
  .f-inp:focus,.f-sel:focus{outline:none;border-color:var(--eco-sage);box-shadow:0 0 0 3px rgba(82,168,120,0.15)}
  .f-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}

  /* ── Toast boven bottom nav ───────── */
  .toast{bottom:calc(var(--bnav-h) + 16px)}

  /* ── Berichten mobiel ─────────────── */
  .msg-card{flex-direction:column;gap:10px;padding:12px}
  .msg-icon-box{width:32px;height:32px}
  .msg-title{font-size:13px;flex-direction:column;gap:4px}
  .msg-actions-inline{opacity:1}
  .msg-archive-btn{opacity:1}

  /* ── Section header wrapping ──────── */
  .section-page .mhdr{flex-wrap:wrap;gap:8px}
  .mhdr-actions{
    display:flex;flex-wrap:wrap;gap:6px!important;
    align-items:center;
  }
  .mhdr-actions .btn{padding:4px 8px!important;font-size:11px!important}

  /* ── Leaflet popup kleiner ────────── */
  .leaflet-popup-content{width:200px!important}

  /* ── Cards ─────────────────────────── */
  .card-hdr{padding:12px 16px}
  .card-title{font-size:15px}

  /* ── Admin overlay modal fullscreen ── */
  .admin-modal{width:100%!important;max-width:100%!important;border-radius:12px 12px 0 0;max-height:90vh}

  /* ── CMS content ──────────────────── */
  .cms-content{padding:16px}
  .cms-content h2{font-size:20px}
  .cms-content h3{font-size:15px}

  /* ── Notificatie grid ─────────────── */
  .notif-grid{grid-template-columns:1fr}

  /* ── Scrollbar dikker voor touch ──── */
  ::-webkit-scrollbar{width:6px}

  /* ── Landing page mobiel ──────────── */
  .lp-logo .logo-icon-box{width:60px;height:60px}
  .lp-logo .logo-name{font-size:32px}
  .lp-title{font-size:22px}
  .lp-sub{font-size:13px}
  .lp-btns{flex-direction:column;align-items:center}
  .lp-auth-card{padding:24px;max-width:100%}

  /* ── TKA detail: vertical stack ───── */
  .tka-detail-layout{
    flex-direction:column!important;
    height:auto!important;
    min-height:0!important;
    overflow-y:auto!important;
  }
  .tka-detail-sidebar{
    width:100%!important;border-right:none!important;
    border-bottom:1px solid #eee;
    overflow-y:visible!important;
    flex-shrink:0!important;
  }
  .tka-detail-sidebar .sidebar{
    width:100%!important;height:auto!important;
    overflow:visible!important;
  }
  .tka-detail-sidebar .sb-hdr{padding:10px 14px;font-size:9px}
  .tka-detail-sidebar .sb-list{max-height:100px!important;overflow-y:auto}
  .tka-detail-sidebar > div[style*="padding: 15px"]{padding:12px!important}
  .tka-detail-main{
    padding:14px!important;
    flex-shrink:0!important;
    overflow:visible!important;
  }
  .tka-detail-main .map-wrap{
    min-height:280px!important;
    height:280px!important;
    flex:none!important;
    margin-bottom:14px!important;
  }
  .tka-stats-grid{grid-template-columns:repeat(2,1fr)!important}
  #tkaUsersList{grid-template-columns:1fr!important}
  .tka-invite-row{flex-direction:column!important;gap:8px!important}
  .tka-invite-row .fg{width:100%!important}

  /* ── Registratie formulier als fullscreen overlay op mobiel ── */
  #section-content{
    position:fixed!important;
    inset:0!important;
    z-index:2500!important;
    background:#fff!important;
    padding:0!important;
    overflow-y:auto!important;
    -webkit-overflow-scrolling:touch;
  }
  #section-content .section-page{
    border-radius:0;border:none;
    min-height:100vh;min-height:100dvh;
    margin-bottom:0;
  }
  #section-content .stepper{
    padding:8px 14px;
    overflow-x:auto;
  }
  #section-content .step-label{font-size:10px}
  #section-content .step-line{margin:0 4px;min-width:15px}
  #section-content .mbody{padding:16px}
  #section-content .mftr{
    position:sticky;bottom:0;
    padding-bottom:calc(14px + var(--safe-bottom));
  }

  /* ── Registraties top bar stacking ── */
  .reg-topbar{flex-direction:column!important;gap:10px!important;align-items:stretch!important}

  /* ── Modal tabs scroll ────────────── */
  .modal-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}
  .modal-tabs .tab-btn{white-space:nowrap;flex-shrink:0}

  /* ── Berichten footer stacking ────── */
  .msg-footer{flex-direction:column!important;gap:10px!important}

  /* ── Form inputs grotere touch targets ── */
  .fg select,.fg input,.fg textarea{padding:11px 12px;font-size:16px}
  .fg label{font-size:12px}

  /* ── TKA footer pagination ────────── */
  .tka-pagination{flex-direction:column!important;gap:10px!important;align-items:stretch!important;text-align:center}

  /* ── Verberg desktop FAB als bottom nav actief ── */
  #map-section .fab{display:none}
}

/* ═══ SMALL PHONES (< 360px) ═════════════════ */
@media(max-width:359px){
  .wiz-type-grid{grid-template-columns:1fr}
  .logo-name{font-size:15px}
  .bnav-item{min-width:44px;font-size:9px}
  .bnav-fab{width:44px;height:44px;font-size:20px}
  header{padding:0 8px}
}
