/* ── TOPBAR ── */
#topbar {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center;
  height: 56px;
  background: var(--navbar-bg);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  padding: 0 20px;
  box-shadow: 0 2px 8px rgba(12,26,39,0.35);
}

.topbar-brand {
  display: flex; align-items: center; gap: 8px;
  font-size: 1.05rem; font-weight: 800;
  color: #fff; white-space: nowrap;
  margin-right: 32px; letter-spacing: -.01em;
}

.topbar-nav { display: flex; align-items: center; gap: 2px; flex: 1; }

.nav-btn {
  background: none; border: none;
  color: var(--navbar-txt);
  font-size: var(--text-sm); font-weight: 500;
  padding: 7px 14px; border-radius: var(--radius-sm);
  cursor: pointer; transition: color .15s, background .15s;
  white-space: nowrap;
}
.nav-btn:hover { color: var(--navbar-txt-active); background: rgba(255,255,255,0.08); }
.nav-btn.active {
  color: var(--navbar-bg);
  background: var(--navbar-accent);
  font-weight: 600;
}

.topbar-right {
  display: flex; align-items: center; gap: 12px;
  margin-left: auto;
}
.topbar-datum {
  font-size: 0.8rem; color: rgba(255,255,255,0.55);
  white-space: nowrap;
}
.topbar-avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--accent); color: var(--navy);
  font-size: 0.72rem; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  cursor: default; flex-shrink: 0;
}
.btn-uitlog {
  background: none; border: 1px solid rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.65); font-size: 0.8rem;
  padding: 5px 12px; border-radius: var(--radius);
  cursor: pointer; transition: border-color .15s, color .15s;
}
.btn-uitlog:hover { border-color: var(--red); color: #ff8a8a; }

/* ── SCREEN WRAPPER ── */
.screen { display: none; padding: 20px; min-height: calc(100vh - 56px); background: var(--bg); }
.screen.active { display: block; }

.screen-title {
  font-size: var(--text-xl); font-weight: 600;
  color: var(--txt); margin-bottom: 16px;
}

/* ── DASHBOARD GRID ── */
.dash-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  align-items: start;
}
@media (max-width: 1100px) { .dash-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 700px)  { .dash-grid { grid-template-columns: 1fr; } }

.dash-col { display: flex; flex-direction: column; gap: 10px; }

.dash-col-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 2px;
}
.dash-col-title {
  font-size: var(--text-xs); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--txt3);
}
.dash-col-count {
  background: var(--surface-2); color: var(--text-secondary);
  font-size: 11px; font-weight: 700;
  padding: 2px 8px; border-radius: 20px;
  border: 1px solid var(--border);
}

/* ── BADGES ── */
.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px; border-radius: 20px;
  font-size: var(--text-xs); font-weight: 600;
  white-space: nowrap; border: 1px solid transparent;
}

/* Status badges */
.badge-nieuw        { background: var(--status-nieuw-bg);        color: var(--status-nieuw-txt);        border-color: var(--status-nieuw-border); }
.badge-beschikbaar  { background: var(--status-beschikbaar-bg);  color: var(--status-beschikbaar-txt);  border-color: var(--status-beschikbaar-border); }
.badge-voorgesteld  { background: var(--status-voorgesteld-bg);  color: var(--status-voorgesteld-txt);  border-color: var(--status-voorgesteld-border); }
.badge-ingepland    { background: var(--status-voorgesteld-bg);  color: var(--status-voorgesteld-txt);  border-color: var(--status-voorgesteld-border); }
.badge-bevestigd    { background: var(--status-bevestigd-bg);    color: var(--status-bevestigd-txt);    border-color: var(--status-bevestigd-border); }
.badge-issue        { background: var(--status-issue-bg);        color: var(--status-issue-txt);        border-color: var(--status-issue-border); }
.badge-afgerond     { background: var(--status-afgerond-bg);     color: var(--status-afgerond-txt);     border-color: var(--status-afgerond-border); }
.badge-geparkeerd   { background: var(--status-geparkeerd-bg);   color: var(--status-geparkeerd-txt);   border-color: var(--status-geparkeerd-border); }
.badge-niet_gepland { background: var(--status-nieuw-bg);        color: var(--status-nieuw-txt);        border-color: var(--status-nieuw-border); }
.badge-vervallen    { background: var(--status-afgerond-bg);     color: var(--status-afgerond-txt);     border-color: var(--status-afgerond-border); }
.badge-wacht_onderdeel { background: var(--status-voorgesteld-bg); color: var(--status-voorgesteld-txt); border-color: var(--status-voorgesteld-border); }
.badge-geannuleerd  { background: var(--status-issue-bg);        color: var(--status-issue-txt);        border-color: var(--status-issue-border); }

/* Prioriteit badges */
.badge-prio         { background: var(--prio-bg);      color: var(--prio-txt);      border-color: var(--prio-border); }
.badge-normaal      { background: var(--normaal-bg);   color: var(--normaal-txt);   border-color: var(--normaal-border); }
.badge-opvulling    { background: var(--opvulling-bg); color: var(--opvulling-txt); border-color: var(--opvulling-border); }
.badge-niet_nodig   { background: var(--opvulling-bg); color: var(--opvulling-txt); border-color: var(--opvulling-border); }

/* Onderdeel badges */
.badge-onderweg     { background: var(--onderdeel-onderweg-bg);   color: var(--onderdeel-onderweg-txt);   border-color: var(--onderdeel-onderweg-border); }
.badge-ontvangen    { background: var(--onderdeel-ontvangen-bg);  color: var(--onderdeel-ontvangen-txt);  border-color: var(--onderdeel-ontvangen-border); }

/* ── DASH TABLE ── */
.dash-table {
  width: 100%; border-collapse: collapse;
  font-size: var(--text-base);
}
.dash-table th {
  font-size: var(--text-xs); font-weight: 600;
  color: var(--txt3); text-transform: uppercase; letter-spacing: 0.05em;
  padding: 8px 12px; border-bottom: 1px solid var(--border);
  text-align: left; background: var(--bg-secondary);
}
.dash-table td {
  padding: 10px 12px; border-bottom: 1px solid var(--border);
  color: var(--txt); vertical-align: middle;
}
.dash-table tr:hover td { background: var(--bg-secondary); cursor: pointer; }
.dash-table tr:last-child td { border-bottom: none; }

/* ── CASE CARDS ── */
.case-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 13px 15px;
  cursor: pointer; transition: border-color .15s, box-shadow .15s;
  box-shadow: var(--shadow-sm);
}
.case-card:hover { border-color: var(--border-strong); box-shadow: var(--shadow); }
.case-card.nieuw { border-left: 3px solid var(--accent); }

.case-card-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 5px;
}
.case-num {
  font-size: 13px; font-weight: 500; color: var(--text-secondary);
  font-family: monospace;
}
.case-badges { display: flex; gap: 4px; flex-wrap: wrap; }

.case-card-stad {
  font-size: 14px; font-weight: 600; color: var(--text-primary);
  margin-bottom: 2px;
}
.case-card-type { font-size: 13px; color: var(--text-secondary); }

.dagen-binnen {
  font-size: 12px; font-weight: 600;
  margin-top: 6px; display: inline-block;
  padding: 2px 8px; border-radius: 20px;
}
.dagen-groen  { background: var(--green-light);  color: var(--green); }
.dagen-oranje { background: var(--orange-light); color: var(--orange); }
.dagen-rood   { background: var(--red-light);    color: var(--red); }

/* ── STAT BLOKJES ── */
.stat-row { display: flex; gap: 10px; }
.stat-blok {
  flex: 1; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px;
  text-align: center; box-shadow: var(--shadow-sm);
}
.stat-getal { font-size: 28px; font-weight: 700; color: var(--navy); }
.stat-label { font-size: 12px; color: var(--text-secondary); margin-top: 2px; }

/* ── MELDING BOX ── */
.melding-box {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px 15px;
  box-shadow: var(--shadow-sm);
}
.melding-title {
  font-size: 12px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .05em; color: var(--text-secondary); margin-bottom: 8px;
}
.melding-leeg { font-size: 13px; color: var(--text-tertiary); }

/* ── OPTIMIZER BTN ── */
.btn-optimizer {
  width: 100%; background: var(--accent); color: var(--accent-text);
  border: none; border-radius: var(--radius);
  padding: 10px 16px; font-size: 14px; font-weight: 700;
  cursor: pointer; transition: background .15s;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.btn-optimizer:hover { background: var(--accent-dark); }

/* ── VANDAAG PLANNING ── */
.monteur-blok {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 13px 15px;
  box-shadow: var(--shadow-sm);
}
.monteur-blok-header {
  display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
}
.monteur-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.monteur-naam-text { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.monteur-tijd { font-size: 12px; color: var(--text-secondary); margin-left: auto; }

.klus-rij {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 0; border-top: 1px solid var(--border);
  font-size: 13px;
}
.klus-volgorde {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--surface-2); color: var(--text-secondary);
  font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.klus-num { font-weight: 500; color: var(--text-secondary); font-family: monospace; font-size: 12px; }
.klus-stad { color: var(--text-primary); flex: 1; }

.btn-beschikbaarheid {
  width: 100%; margin-top: 10px;
  background: none; border: 1px solid var(--border-strong);
  color: var(--text-secondary); font-size: 13px;
  padding: 8px; border-radius: var(--radius);
  cursor: pointer; transition: border-color .15s, color .15s, background .15s;
}
.btn-beschikbaarheid:hover {
  border-color: var(--accent); background: var(--accent-light);
  color: var(--navy);
}

.leeg-state {
  padding: 32px 16px; text-align: center;
  color: var(--text-tertiary); font-size: 14px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: var(--shadow-sm);
}

/* ── CASES SCHERM ── */
.cases-toolbar {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 14px; flex-wrap: wrap;
}
.cases-zoek {
  flex: 1; min-width: 200px;
  background: var(--surface); border: 1px solid var(--border-strong);
  border-radius: var(--radius); padding: 8px 13px;
  color: var(--text-primary); font-size: 14px; outline: none;
  transition: border-color .15s, box-shadow .15s;
  box-shadow: var(--shadow-sm);
}
.cases-zoek:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(245,197,24,0.2); }
.cases-zoek::placeholder { color: var(--text-tertiary); }

.filter-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.chip {
  background: var(--surface); border: 1px solid var(--border-strong);
  color: var(--text-secondary); font-size: 13px; font-weight: 500;
  padding: 5px 12px; border-radius: 20px; cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
  white-space: nowrap; box-shadow: var(--shadow-sm);
}
.chip:hover { border-color: var(--accent-dark); color: var(--navy); background: var(--accent-light); }
.chip.active { border-color: var(--accent); color: var(--navy); background: var(--accent-light); font-weight: 600; }

/* Count-badge naast filter-label */
.chip-count {
  display: inline-block;
  margin-left: 4px;
  padding: 1px 7px;
  font-size: 11px;
  font-weight: 600;
  border-radius: 999px;
  background: rgba(0,0,0,.07);
  color: inherit;
  min-width: 18px;
  text-align: center;
}
.chip.active .chip-count { background: rgba(255,255,255,.6); }

/* Kleurvarianten voor categorie-chips wanneer actief */
.chip-blauw.active  { border-color: #2563EB; background: #EFF6FF; color: #1E40AF; }
.chip-geel.active   { border-color: #B45309; background: #FEF3C7; color: #92400E; }
.chip-groen.active  { border-color: #027A48; background: #ECFDF3; color: #027A48; }
.chip-rood.active   { border-color: #B91C1C; background: #FEF2F2; color: #991B1B; }
.chip-grijs.active  { border-color: #475467; background: #F2F4F7; color: #344054; }
.chip-amber.active  { border-color: #B45309; background: #FEF3C7; color: #92400E; }

.toggle-view {
  display: flex; background: var(--surface);
  border: 1px solid var(--border-strong); border-radius: var(--radius);
  overflow: hidden; flex-shrink: 0; box-shadow: var(--shadow-sm);
}
.toggle-view button {
  background: none; border: none; color: var(--text-secondary);
  font-size: 13px; font-weight: 500;
  padding: 7px 14px; cursor: pointer; transition: background .15s, color .15s;
}
.toggle-view button.active { background: var(--accent); color: var(--navy); font-weight: 700; }

.btn-nieuwe-case {
  background: var(--accent); color: var(--accent-text);
  border: none; border-radius: var(--radius);
  padding: 8px 16px; font-size: 14px; font-weight: 700;
  cursor: pointer; transition: background .15s;
  white-space: nowrap;
}
.btn-nieuwe-case:hover { background: var(--accent-dark); }

/* Case groep header */
.case-groep { margin-bottom: 8px; }
.case-groep-header {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius); cursor: pointer; user-select: none;
}
.case-groep-naam {
  font-size: 12px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .05em;
  color: var(--text-secondary);
}
.case-groep-badge {
  background: var(--surface); color: var(--text-secondary);
  border: 1px solid var(--border-strong);
  font-size: 11px; font-weight: 700;
  padding: 1px 7px; border-radius: 20px;
}
.case-groep-toggle { margin-left: auto; color: var(--text-tertiary); font-size: 12px; }

/* Cases tabel */
.cases-tabel-wrap { overflow-x: auto; border-radius: var(--radius); box-shadow: var(--shadow-sm); margin-bottom: 2px; }
.cases-tabel {
  width: 100%; border-collapse: collapse; table-layout: fixed;
  background: var(--surface); border: 1px solid var(--border);
  font-size: 13px;
}
.cases-tabel col.col-num        { width: 120px; }
.cases-tabel col.col-stad       { width: 120px; }
.cases-tabel col.col-type       { width: auto; min-width: 120px; }
.cases-tabel col.col-prio       { width: 100px; }
.cases-tabel col.col-status     { width: 110px; }
.cases-tabel col.col-onderdeel  { width: 110px; }
.cases-tabel col.col-opdrachtgever { width: 120px; }
.cases-tabel col.col-monteur    { width: 140px; }
.cases-tabel th {
  text-align: left; font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .05em;
  color: var(--text-secondary); padding: 8px 12px;
  background: var(--surface-2); border-bottom: 1px solid var(--border);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cases-tabel td {
  padding: 10px 12px; border-bottom: 1px solid var(--border);
  color: var(--text-primary); vertical-align: middle;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cases-tabel tr:last-child td { border-bottom: none; }
.cases-tabel tbody tr { cursor: pointer; transition: background .1s; }
.cases-tabel tbody tr:hover td { background: var(--accent-light); }
.cases-tabel tbody tr.selected td { background: var(--accent-light); }
.cases-tabel tbody tr.selected td:first-child { border-left: 3px solid var(--accent); }
.td-num { font-family: monospace; color: var(--text-secondary); font-weight: 500; }
.td-muted { color: var(--text-secondary); }
.cases-prio-badge {
  display: inline-block;
  font-size: 10px; font-weight: 700;
  padding: 1px 5px; border-radius: 3px;
  background: #FEF3C7; color: #92400E;
  border: 1px solid #FDE68A;
  margin-right: 4px; vertical-align: middle;
}

/* Case sidebar */
.case-sidebar-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.3); z-index: 200;
}
.case-sidebar-overlay.open { display: block; }
.case-sidebar {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(420px, 100vw);
  background: var(--surface); border-left: 1px solid var(--border);
  z-index: 201; overflow-y: auto; display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform .25s cubic-bezier(.4,0,.2,1);
  box-shadow: -8px 0 32px rgba(0,0,0,0.12);
}
.case-sidebar.open { transform: translateX(0); }

.sidebar-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid rgba(255,255,255,0.12);
  position: sticky; top: 0; background: var(--navy); z-index: 1;
  gap: 12px;
}
.sidebar-header-left { flex: 1; min-width: 0; }
.sidebar-header h3 {
  font-size: 16px; font-weight: 700; color: #fff;
  font-family: monospace; letter-spacing: .02em;
}
.sidebar-subtitel {
  font-size: 13px; color: rgba(255,255,255,0.6); margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.btn-sidebar-sluit {
  background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.7); width: 28px; height: 28px; flex-shrink: 0;
  border-radius: 6px; cursor: pointer; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s; margin-top: 2px;
}
.btn-sidebar-sluit:hover { background: rgba(220,38,38,0.3); color: #fff; border-color: var(--red); }

.sidebar-body { flex: 1; overflow-y: auto; }

/* Secties */
.sidebar-sectie { padding: 16px 20px; border-bottom: 1px solid var(--border); }
.sidebar-sectie:last-child { border-bottom: none; }
.sidebar-sectie-titel {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text-tertiary); margin-bottom: 12px;
}

/* Label-waarde rijen */
.sidebar-rij {
  display: flex; align-items: baseline; gap: 8px;
  padding: 5px 0; font-size: 14px;
}
.sidebar-rij + .sidebar-rij { border-top: 1px solid var(--border); }
.sidebar-rij-label {
  flex-shrink: 0; width: 130px;
  font-size: 13px; color: var(--text-secondary);
}
.sidebar-rij-waarde {
  flex: 1; color: var(--text-primary); font-size: 14px;
  word-break: break-word;
}
.sidebar-rij-waarde a { color: var(--navy); text-decoration: none; font-weight: 500; }
.sidebar-rij-waarde a:hover { text-decoration: underline; color: var(--navy-light); }

.sidebar-issue-banner {
  background: var(--red); color: #fff;
  font-size: 13px; font-weight: 700;
  padding: 10px 20px; letter-spacing: .03em;
}

/* Case sidebar edit form */
.sidebar-edit-form { display: flex; flex-direction: column; gap: 6px; }
.sidebar-edit-label {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .05em; color: var(--text-tertiary); margin-top: 6px;
}
.sidebar-edit-input {
  width: 100%; background: var(--surface-2); border: 1px solid var(--border-strong);
  border-radius: 6px; padding: 7px 10px; font-size: 13px; color: var(--text-primary);
  box-sizing: border-box; transition: border-color .15s;
}
.sidebar-edit-input:focus { outline: none; border-color: var(--accent); }
.sidebar-edit-textarea {
  width: 100%; background: var(--surface-2); border: 1px solid var(--border-strong);
  border-radius: 6px; padding: 7px 10px; font-size: 13px; color: var(--text-primary);
  box-sizing: border-box; resize: vertical; font-family: inherit; transition: border-color .15s;
}
.sidebar-edit-textarea:focus { outline: none; border-color: var(--accent); }
.sidebar-edit-acties { display: flex; gap: 8px; margin-top: 10px; }
.sidebar-edit-acties .btn-actie-sec,
.sidebar-edit-acties .btn-actie-primair { width: auto; flex: 1; text-align: center; }

/* Case sidebar toast */
.sidebar-toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--navy); color: #fff; font-size: 13px; font-weight: 600;
  padding: 10px 20px; border-radius: 20px; z-index: 3000;
  opacity: 0; transition: opacity .2s, transform .2s; pointer-events: none; white-space: nowrap;
}
.sidebar-toast.zichtbaar { opacity: 1; transform: translateX(-50%) translateY(0); }

/* Actie knoppen */
.sidebar-acties { display: flex; flex-direction: column; gap: 8px; }
.btn-actie-primair {
  width: 100%; background: var(--accent); color: var(--accent-text);
  border: none; border-radius: var(--radius);
  padding: 10px 16px; font-size: 14px; font-weight: 700;
  cursor: pointer; transition: background .15s; text-align: left;
}
.btn-actie-primair:hover { background: var(--accent-dark); }
.btn-actie-sec {
  width: 100%; background: var(--surface); color: var(--text-primary);
  border: 1px solid var(--border-strong); border-radius: var(--radius);
  padding: 9px 16px; font-size: 14px; font-weight: 500;
  cursor: pointer; transition: border-color .15s, background .15s; text-align: left;
}
.btn-actie-sec:hover { border-color: var(--accent); background: var(--accent-light); color: var(--navy); }

/* ── AGENDA SCHERM ── */
.agenda-week-nav {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 14px; flex-wrap: wrap;
}

.agenda-toolbar {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 16px; flex-wrap: wrap;
}
.monteur-pills { display: flex; gap: 6px; flex-wrap: wrap; flex: 1; }
.monteur-pill {
  display: flex; align-items: center; gap: 6px;
  background: var(--surface); border: 1px solid var(--border-strong);
  border-radius: 20px; padding: 5px 12px 5px 8px;
  cursor: pointer; transition: border-color .15s, background .15s;
  font-size: 13px; font-weight: 500; color: var(--text-secondary);
  box-shadow: var(--shadow-sm);
}
.monteur-pill.active {
  border-color: var(--monteur-kleur, var(--accent));
  color: var(--text-primary); background: var(--surface);
}
.monteur-pill-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.btn-solo {
  background: var(--surface); border: 1px solid var(--border-strong);
  color: var(--text-secondary); font-size: 13px;
  padding: 6px 12px; border-radius: 20px; cursor: pointer;
  transition: border-color .15s, color .15s; box-shadow: var(--shadow-sm);
}
.btn-solo.active { border-color: var(--accent); color: var(--navy); background: var(--accent-light); font-weight: 600; }

/* Week kaartjes */
.week-row {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 10px; margin-bottom: 20px;
}
.dag-kaart {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 12px 14px;
  cursor: pointer; transition: border-color .15s, box-shadow .15s;
  box-shadow: var(--shadow-sm);
}
.dag-kaart:hover { box-shadow: var(--shadow); border-color: var(--border-strong); }
.dag-kaart.active { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(245,197,24,0.25); }
.dag-kaart.vandaag { background: var(--accent-light); border-color: var(--accent); }
.dag-naam { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; color: var(--text-secondary); }
.dag-datum { font-size: 20px; font-weight: 700; color: var(--text-primary); margin: 2px 0; }
.dag-blokjes { display: flex; gap: 3px; flex-wrap: wrap; margin-top: 6px; }
.dag-blokje { height: 5px; flex: 1; min-width: 5px; border-radius: 3px; opacity: .75; }
.dag-count { font-size: 12px; color: var(--text-secondary); margin-top: 4px; }

/* Swimlanes */
.swimlane-container { display: flex; flex-direction: column; gap: 10px; }
.swimlane {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm);
}
.swimlane-header {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 16px; border-bottom: 1px solid var(--border);
  background: var(--surface-2);
}
.swimlane-kleur-balk { width: 4px; height: 28px; border-radius: 2px; flex-shrink: 0; }
.swimlane-naam { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.swimlane-body { display: flex; gap: 8px; padding: 12px 16px; flex-wrap: wrap; }
.swimlane-leeg { padding: 16px; font-size: 13px; color: var(--text-tertiary); }

.klus-kaart {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 8px 12px; min-width: 130px;
}
.klus-kaart.vastgezet { border-width: 2px; }
.klus-kaart.afgerond { opacity: .55; }
.klus-kaart-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 4px;
}
.klus-kaart-volgorde {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--border); color: var(--text-secondary);
  font-size: 10px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.klus-kaart-vinkje { color: var(--green); font-size: 13px; }
.klus-kaart-num { font-family: monospace; font-size: 12px; font-weight: 500; color: var(--text-secondary); }
.klus-kaart-stad { font-size: 13px; color: var(--text-primary); margin-top: 2px; }

/* ── PLANNING GRID ── */
.planning-grid-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; margin-bottom: 14px; flex-wrap: wrap;
}
.planning-grid-header .agenda-week-nav { margin-bottom: 0; }
.planning-grid-acties { display: flex; align-items: center; gap: 8px; }

.btn-agenda-optimizer {
  background: var(--navy); color: #fff;
  border: none; border-radius: var(--radius); padding: 7px 14px;
  font-size: 13px; font-weight: 600; cursor: pointer;
  transition: background .15s; white-space: nowrap;
}
.btn-agenda-optimizer:hover { background: #1e3058; }

.btn-agenda-teplanen {
  background: var(--surface); border: 1px solid var(--border-strong);
  color: var(--text-secondary); border-radius: var(--radius);
  padding: 7px 14px; font-size: 13px; font-weight: 500;
  cursor: pointer; transition: border-color .15s; white-space: nowrap;
}
.btn-agenda-teplanen:hover { border-color: var(--accent); color: var(--text-primary); }

.planning-grid-scroll { overflow-x: auto; }

.planning-grid-tabel {
  width: 100%; border-collapse: collapse;
  background: var(--surface); border-radius: var(--radius);
  box-shadow: var(--shadow-sm); table-layout: fixed;
}

/* Kolombreedte */
.planning-grid-tabel colgroup .col-monteur { width: 90px; }

.pg-monteur-kop {
  width: 90px; background: var(--surface-2);
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
}
.pg-dag-kop {
  background: var(--surface-2); border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border); padding: 10px 8px;
  text-align: center; vertical-align: middle;
}
.pg-dag-kop:last-child { border-right: none; }
.pg-dag-naam {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--text-secondary);
}
.pg-dag-datum { font-size: 13px; font-weight: 600; color: var(--text-primary); margin-top: 2px; }
.pg-dag-vandaag { background: var(--accent-light); }
.pg-dag-vandaag .pg-dag-datum { color: var(--navy); }

/* Monteur-cel (eerste kolom) */
.pg-monteur-cel {
  background: var(--surface-2); border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border); padding: 10px 8px;
  vertical-align: middle; text-align: center;
  position: sticky; left: 0; z-index: 1;
}
.pg-monteur-dot {
  width: 10px; height: 10px; border-radius: 50%;
  margin: 0 auto 4px;
}
.pg-monteur-naam {
  font-size: 11px; font-weight: 600; color: var(--text-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Data-cellen */
.pg-rij:last-child .pg-cel { border-bottom: none; }
.pg-rij:last-child .pg-monteur-cel { border-bottom: none; }

.pg-cel {
  border-right: 1px solid var(--border); border-bottom: 1px solid var(--border);
  padding: 6px; vertical-align: top; min-height: 60px;
  transition: background .1s;
}
.pg-cel:last-child { border-right: none; }
.pg-cel-vandaag { background: rgba(245,197,24,.05); }
.pg-cel-afwezig { background: repeating-linear-gradient(
  -45deg, transparent, transparent 4px,
  rgba(0,0,0,.03) 4px, rgba(0,0,0,.03) 8px
); }

/* Stop blokjes */
.stop-blok {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: 6px; padding: 5px 7px; margin-bottom: 4px;
  cursor: pointer; transition: box-shadow .12s, border-color .12s;
  font-size: 12px;
}
.stop-blok:last-child { margin-bottom: 0; }
.stop-blok:hover { box-shadow: var(--shadow); border-color: var(--border-strong); }

.stop-blok-bevestigd {
  background: #f0f9eb; border-color: #c0dd97; color: #2d5a0e;
}
.stop-blok-voorgesteld {
  background: var(--accent-light); border-color: var(--accent); color: var(--navy);
}
.stop-blok-geparkeerd {
  background: #f5f5f5; border-color: #ccc; color: #666;
}
.stop-blok-issue {
  background: #fff0f0; border-color: var(--red); color: var(--red);
}
.stop-blok-afgerond { opacity: .5; }

.stop-blok-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 2px;
}
.stop-blok-nr {
  width: 16px; height: 16px; border-radius: 50%;
  background: rgba(0,0,0,.12); color: inherit;
  font-size: 10px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.stop-blok-eta { font-size: 10px; opacity: .75; }
.stop-blok-case { font-family: monospace; font-size: 11px; font-weight: 600; }
.stop-blok-stad { font-size: 11px; opacity: .8; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── STOP POPUP (bottom sheet) ── */
.stop-popup-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.35);
  z-index: 1800; opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.stop-popup-overlay.open { opacity: 1; pointer-events: all; }

.stop-popup {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--surface); border-radius: 16px 16px 0 0;
  box-shadow: 0 -4px 24px rgba(0,0,0,.18);
  z-index: 1900; transform: translateY(100%);
  transition: transform .25s cubic-bezier(.32,1,.23,1);
  max-height: 85vh; display: flex; flex-direction: column;
  overflow: hidden;
}
.stop-popup.open { transform: translateY(0); }

.stop-popup-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px 12px; border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.stop-popup-header h3 { font-size: 16px; font-weight: 700; color: var(--text-primary); margin: 0; }

.stop-popup-body-wrap { overflow-y: auto; padding: 0 0 env(safe-area-inset-bottom, 16px); }

.stop-popup-info { padding: 14px 20px; border-bottom: 1px solid var(--border); }
.stop-popup-rij {
  display: flex; gap: 12px; align-items: baseline;
  font-size: 13px; padding: 3px 0;
}
.stop-popup-label {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .05em; color: var(--text-tertiary);
  min-width: 64px; flex-shrink: 0;
}

.stop-popup-acties {
  display: flex; flex-wrap: wrap; gap: 8px;
  padding: 14px 20px; border-bottom: 1px solid var(--border);
}

.stop-sub-form {
  padding: 12px 20px 4px; border-bottom: 1px solid var(--border);
}
.stop-sub-form-titel {
  font-size: 13px; font-weight: 700; color: var(--text-primary);
  margin-bottom: 10px;
}
.stop-sub-form-acties { display: flex; gap: 8px; margin-top: 12px; padding-bottom: 4px; }

/* Desktop: popup als zijpaneel ipv bottom sheet */
@media (min-width: 768px) {
  .stop-popup {
    bottom: auto; top: 60px; right: 0; left: auto;
    width: 380px; border-radius: 0;
    max-height: calc(100vh - 60px);
    transform: translateX(100%);
    border-left: 1px solid var(--border);
  }
  .stop-popup.open { transform: translateX(0); }
  .stop-popup-overlay { background: rgba(0,0,0,.2); }
}

/* ── UTILITIES ── */
.loader {
  display: flex; align-items: center; justify-content: center;
  padding: 40px; color: var(--text-tertiary); font-size: 14px;
}
.skeleton {
  background: linear-gradient(90deg, var(--surface-2) 25%, var(--border) 50%, var(--surface-2) 75%);
  background-size: 200% 100%; animation: shimmer 1.4s infinite;
  border-radius: var(--radius); height: 60px;
}
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* Beschikbaarheid-tab is verwijderd in Ronde I — tab-grid CSS weg.
   Kebab-menu en bulk-form-paneel CSS hieronder blijven want Planning
   gebruikt ze. */

.besch-kebab-wrap { position: relative; display: inline-block; }
.besch-kebab {
  background: none; border: none; cursor: pointer;
  color: var(--text-tertiary); font-size: 16px; padding: 2px 4px;
  border-radius: 4px; line-height: 1; transition: color .15s, background .15s;
  vertical-align: middle;
}
.besch-kebab:hover { color: var(--text-primary); background: var(--border); }
.besch-kebab-menu {
  display: none;
  background: var(--surface); border: 1px solid var(--border-strong);
  border-radius: var(--radius); box-shadow: 0 4px 16px rgba(0,0,0,.12);
  min-width: 190px; z-index: 9999; overflow: hidden;
}
.besch-kebab-menu.open { display: block; }
.besch-kebab-menu button {
  display: block; width: 100%; text-align: left;
  background: none; border: none; padding: 9px 14px;
  font-size: 13px; color: var(--text-primary); cursor: pointer;
  transition: background .1s;
}
.besch-kebab-menu button:hover { background: var(--surface-2); }
.besch-kebab-menu button.kebab-gevaarlijk { color: var(--red); }
.besch-kebab-menu button.kebab-gevaarlijk:hover { background: var(--red-light); }

/* .besch-cel* / .besch-leeg / .besch-vrij / .besch-beschikbaar /
   .besch-actief-dot / .besch-kantoor-icon: tab-grid CSS verwijderd
   in Ronde I — Planning gebruikt eigen .pl-stop / .pl-dag-cel klassen. */

/* Popup hint tekst (donkerder grijs voor leesbaarheid) */
.popup-toggle-hint {
  font-size: 11px; color: #6B7280;
  margin: 2px 0 0; line-height: 1.3;
}

/* Danger zone — Dag verwijderen */
.popup-danger-zone {
  padding: 16px 20px; border-top: 1px solid var(--border);
  margin-top: 8px;
}
.popup-verwijder-btn {
  background: none; border: 1px solid #FECACA;
  color: #B91C1C; font-size: 13px; font-weight: 600;
  padding: 8px 14px; border-radius: var(--radius);
  cursor: pointer; transition: background .12s, border-color .12s;
}
.popup-verwijder-btn:hover:not(:disabled) {
  background: #FEF2F2; border-color: #F87171;
}
.popup-verwijder-btn:disabled {
  color: var(--text-tertiary); border-color: var(--border);
  cursor: not-allowed; background: var(--surface-2);
}
.popup-verwijder-hint {
  font-size: 11px; color: #6B7280;
  margin: 6px 0 0; line-height: 1.4;
}

/* Subtiele "Annuleren" knop in drawer-footer */
.btn-popup-annuleren {
  background: transparent; color: var(--text-secondary);
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 9px 16px; font-size: 14px; font-weight: 500;
  cursor: pointer; transition: border-color .15s, color .15s, background .15s;
  flex: 1; text-align: center;
}
.btn-popup-annuleren:hover {
  border-color: var(--border-strong); color: var(--text-primary);
  background: var(--surface-2);
}

/* ── DAG POPUP ── */
.dag-popup-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.35); z-index: 300;
}
.dag-popup-overlay.open { display: block; }

.dag-popup {
  position: fixed; right: 0; top: 0; bottom: 0;
  width: min(420px, 100vw);
  background: var(--surface); border-left: 1px solid var(--border);
  z-index: 301; display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform .25s cubic-bezier(.4,0,.2,1);
  box-shadow: -8px 0 32px rgba(0,0,0,.15);
}
.dag-popup.open { transform: translateX(0); }

.dag-popup-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 16px 20px; gap: 12px;
  background: var(--navy); border-bottom: 1px solid rgba(255,255,255,.1);
  position: sticky; top: 0; z-index: 1; flex-shrink: 0;
}
.dag-popup-header h3 {
  font-size: 14px; font-weight: 700; color: #fff;
  margin: 0; line-height: 1.4; flex: 1;
}

.dag-popup-body { flex: 1; overflow-y: auto; }

.dag-popup-footer {
  display: flex; gap: 10px; padding: 16px 20px;
  border-top: 1px solid var(--border); flex-shrink: 0;
  background: var(--surface);
}
.dag-popup-footer .btn-actie-primair,
.dag-popup-footer .btn-actie-sec { flex: 1; text-align: center; }

/* Popup rijen */
.popup-toggle-rij {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px; border-bottom: 1px solid var(--border);
}
.popup-toggle-border { border-top: 1px solid var(--border); }
.popup-toggle-label { font-size: 14px; color: var(--text-primary); font-weight: 500; }

.popup-sectie-titel {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .06em; color: var(--text-tertiary);
  padding: 14px 20px 6px;
}

.popup-tijden-row {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 20px 14px; border-bottom: 1px solid var(--border);
}
.popup-tijd-veld { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.popup-tijd-veld label { font-size: 11px; color: var(--text-secondary); font-weight: 600; }
.popup-tijd-veld input[type="time"],
.popup-tijd-veld input[type="number"] {
  background: var(--surface); border: 1px solid var(--border-strong);
  border-radius: var(--radius); padding: 8px 10px;
  color: var(--text-primary); font-size: 14px; font-weight: 600; outline: none;
  width: 100%; transition: border-color .15s, box-shadow .15s;
}
.popup-tijd-veld input[type="time"]:focus,
.popup-tijd-veld input[type="number"]:focus {
  border-color: var(--accent); box-shadow: 0 0 0 3px rgba(245,197,24,.2);
}
.popup-tijd-sep { font-size: 16px; color: var(--text-tertiary); padding-top: 18px; }

.popup-adres-opties {
  display: flex; flex-direction: column; gap: 2px;
  padding: 4px 20px 14px; border-bottom: 1px solid var(--border);
}
.popup-radio {
  display: flex; align-items: center; gap: 8px;
  font-size: 14px; color: var(--text-primary);
  padding: 5px 0; cursor: pointer;
}
.popup-radio input[type="radio"] { accent-color: var(--accent); width: 16px; height: 16px; }

.popup-aangepast-wrap { margin-top: 6px; }
.popup-aangepast-wrap input[type="text"] {
  width: 100%; background: var(--surface);
  border: 1px solid var(--border-strong); border-radius: var(--radius);
  padding: 9px 12px; font-size: 13px; color: var(--text-primary); outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.popup-aangepast-wrap input[type="text"]:focus {
  border-color: var(--accent); box-shadow: 0 0 0 3px rgba(245,197,24,.2);
}

/* Toggle switch */
.toggle-switch { position: relative; display: inline-block; width: 42px; height: 24px; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute; inset: 0; background: var(--border-strong);
  border-radius: 24px; cursor: pointer; transition: background .2s;
}
.toggle-slider:before {
  content: ''; position: absolute;
  height: 18px; width: 18px; left: 3px; bottom: 3px;
  background: #fff; border-radius: 50%; transition: transform .2s;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.toggle-switch input:checked + .toggle-slider { background: var(--green); }
.toggle-switch input:checked + .toggle-slider:before { transform: translateX(18px); }

/* ── VIEW TOGGLE BAR ── */
.view-toggle-bar {
  display: flex; align-items: center;
  margin-bottom: 14px;
}

/* ── AGENDA MAAND NAV ── */
.agenda-maand-nav {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 16px; flex-wrap: wrap;
}

/* ── AGENDA MAAND KALENDER ── */
.agenda-maand-kalender {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm);
}

.maand-dag-headers {
  display: grid; grid-template-columns: repeat(7, 1fr);
  background: var(--surface-2); border-bottom: 1px solid var(--border);
}
.maand-dag-header {
  padding: 8px 4px; text-align: center;
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .05em;
  color: var(--text-secondary);
}

.maand-weken { display: flex; flex-direction: column; }
.maand-week-row {
  display: grid; grid-template-columns: repeat(7, 1fr);
  border-bottom: 1px solid var(--border);
}
.maand-week-row:last-child { border-bottom: none; }

.maand-dag-cel {
  min-height: 90px; padding: 6px 8px;
  border-right: 1px solid var(--border);
  cursor: pointer; transition: background .1s;
  overflow: hidden;
}
.maand-dag-cel:last-child { border-right: none; }
.maand-dag-cel:hover { background: var(--accent-light); }
.maand-dag-cel.andere-maand { background: var(--bg); opacity: .45; cursor: default; }
.maand-dag-cel.andere-maand:hover { background: var(--bg); }

.maand-dag-cel.maand-vandaag { background: var(--accent-light); }
.maand-dag-nr {
  margin-bottom: 4px; display: flex; align-items: center;
}
.maand-dag-nr span {
  font-size: 13px; font-weight: 600; color: var(--text-primary);
  width: 24px; height: 24px; display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
}
.maand-vandaag .maand-dag-nr span {
  background: var(--accent); color: var(--navy);
}

.maand-blokjes-wrap { display: flex; flex-direction: column; gap: 2px; }
.maand-blokje {
  font-size: 10px; font-weight: 600;
  padding: 2px 5px; border-radius: 3px;
  color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.maand-meer {
  background: var(--surface-2) !important; color: var(--text-secondary) !important;
  border: 1px solid var(--border);
}

/* Maand-view CSS verwijderd in Ronde I — maand-view zit niet meer
   in de app. Bulk-edit + per-dag-edit lopen via Planning-modus + popup. */

/* ── OPTIMIZER SCHERM ── */
.opt-header {
  display: flex; align-items: center;
  margin-bottom: 20px;
}
.opt-titel {
  font-size: 18px; font-weight: 700; color: var(--text-primary);
}

/* Status sectie */
.opt-status-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 14px; margin-bottom: 16px;
}
@media (max-width: 800px) { .opt-status-grid { grid-template-columns: 1fr; } }

.opt-status-blok {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 16px 18px;
  box-shadow: var(--shadow-sm);
}
.opt-status-label {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .05em; color: var(--text-secondary);
  margin-bottom: 10px;
}

.opt-monteur-pills { display: flex; flex-wrap: wrap; gap: 6px; }
.opt-monteur-pill {
  background: var(--surface-2); border: 1px solid var(--border-strong);
  border-radius: 20px; padding: 5px 12px;
  font-size: 13px; font-weight: 500; color: var(--text-primary);
}
.opt-leeg-tekst { font-size: 13px; color: var(--text-tertiary); }

.opt-counts { display: flex; gap: 8px; flex-wrap: wrap; }
.opt-count {
  padding: 6px 14px; border-radius: 20px;
  font-size: 13px; font-weight: 500;
  display: flex; align-items: center; gap: 6px;
}
.opt-count strong { font-size: 18px; font-weight: 700; }
.opt-count-prio     { background: var(--red-light);    color: var(--red); }
.opt-count-normaal  { background: var(--orange-light); color: var(--orange); }
.opt-count-opvulling{ background: var(--surface-2);    color: var(--text-secondary); }
.opt-count-fixed    { background: var(--accent-light); color: var(--navy); }

/* Waarschuwingen */
.opt-warnings {
  background: var(--orange-light); border: 1px solid var(--orange);
  border-radius: var(--radius); padding: 12px 16px; margin-bottom: 16px;
}
.opt-warnings-titel {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  color: var(--orange); margin-bottom: 6px;
}
.opt-warning { font-size: 13px; color: var(--text-primary); padding: 2px 0; }

/* Run knop */
.btn-optimizer-run {
  width: 100%; max-width: 420px;
  background: var(--accent); color: var(--navy);
  border: none; border-radius: var(--radius);
  padding: 14px 24px; font-size: 16px; font-weight: 700;
  cursor: pointer; transition: background .15s;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.btn-optimizer-run:hover:not(:disabled) { background: var(--accent-dark); }
.btn-optimizer-run:disabled { opacity: .7; cursor: not-allowed; }
.opt-spinner { animation: spin 1s linear infinite; display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Resultaat sectie */
.opt-sectie-titel {
  font-size: 14px; font-weight: 700; color: var(--text-primary);
  margin-bottom: 14px;
}

/* Route kaarten */
.opt-route-kaart {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--shadow-sm); margin-bottom: 12px;
}
.opt-niet-gepland-kaart { border-color: var(--red); }
.opt-route-bevestigd {
  background: #f0f9eb; border: 1px solid #c0dd97;
  border-radius: 8px; padding: 12px 16px;
  color: #3b6d11; font-weight: 500; margin-bottom: 8px;
}

/* Optimizer loading overlay */
#opt-loading-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.35);
  z-index: 2000;
  display: flex; align-items: center; justify-content: center;
}
.opt-loading-card {
  background: #fff; border-radius: 12px;
  padding: 32px 48px; text-align: center;
  font-size: 15px; font-weight: 500; color: #1a1a1a;
  display: flex; flex-direction: column; align-items: center; gap: 16px;
  box-shadow: 0 8px 40px rgba(0,0,0,.2);
}
.spinner {
  width: 36px; height: 36px;
  border: 3px solid #e5e5e5;
  border-top-color: #c9a84c;
  border-radius: 50%;
  animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.opt-route-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; background: var(--surface-2);
  border-bottom: 1px solid var(--border); flex-wrap: wrap; gap: 8px;
}
.opt-route-monteur { font-size: 15px; color: var(--text-primary); }
.opt-route-datum   { font-size: 14px; color: var(--text-secondary); }
.opt-route-meta    { font-size: 13px; color: var(--text-secondary); display: flex; align-items: center; gap: 10px; }
.opt-maps-link {
  color: var(--navy); font-weight: 600; font-size: 13px;
  text-decoration: none; border: 1px solid var(--border-strong);
  padding: 3px 10px; border-radius: var(--radius);
  background: var(--accent-light); transition: background .15s;
}
.opt-maps-link:hover { background: var(--accent); }

/* Clickable count badges */
.opt-count-klik { cursor: pointer; transition: opacity .15s, transform .1s; }
.opt-count-klik:hover { opacity: .82; transform: translateY(-1px); }

.opt-stops { padding: 4px 0; }
.opt-stop {
  display: block; font-size: 13px;
  border-bottom: 1px solid var(--border); transition: background .2s;
}
.opt-stop:last-child { border-bottom: none; }
.opt-stop.bevestigd { background: #f0fdf4; }
.opt-stop.verzet    { background: var(--surface-2); opacity: .7; }
.opt-stop.geblokkeerd { background: var(--red-light); opacity: .75; }

.opt-stop-collapsed {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 16px; cursor: pointer;
  transition: background .12s;
}
.opt-stop-collapsed:hover { background: var(--surface-2); }

.opt-stop-main { flex: 1; display: flex; flex-direction: column; min-width: 0; }
.opt-stop-sub  { font-size: 11px; color: var(--text-secondary); }
.opt-stop-expand {
  font-size: 16px; color: var(--text-tertiary); font-weight: 700;
  flex-shrink: 0; width: 18px; text-align: center; user-select: none;
}

.opt-stop-detail {
  padding: 4px 16px 12px 60px; display: flex; flex-direction: column; gap: 4px;
  border-top: 1px solid var(--border);
}
.opt-stop-detail-rij { font-size: 12px; color: var(--text-secondary); }

.opt-stop-nr {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--border); color: var(--text-secondary);
  font-size: 11px; font-weight: 700; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.opt-stop-eta  { font-weight: 700; color: var(--navy); font-size: 13px; flex-shrink: 0; }
.opt-stop-naam { font-weight: 500; color: var(--text-primary); }

.opt-stop-acties { display: flex; gap: 4px; margin-top: 6px; }
.opt-stop-btn {
  background: none; border: 1px solid var(--border);
  border-radius: 6px; padding: 3px 7px; cursor: pointer;
  font-size: 14px; line-height: 1; transition: background .15s;
}
.opt-stop-btn:hover:not(:disabled) { background: var(--surface-2); }
.opt-stop-btn:disabled { opacity: .35; cursor: default; }
.opt-stop-gap {
  font-size: 11px; color: var(--orange); font-weight: 600;
  display: block; padding: 2px 16px 6px 60px;
}

/* Actie knoppen */
.opt-acties {
  display: flex; gap: 10px; margin-top: 20px; flex-wrap: wrap;
}
.opt-acties .btn-actie-primair { flex: none; width: auto; }
.opt-acties .btn-actie-sec     { flex: none; width: auto; }
.btn-actie-rood {
  background: var(--red); color: #fff; border-color: var(--red);
}
.btn-actie-rood:hover { background: #b91c1c; border-color: #b91c1c; }

/* ── OPTIMIZER VISIT PANEL ── */
.opt-panel-overlay {
  display: none; position: fixed; inset: 0; z-index: 200;
  background: rgba(21,32,56,.35);
}
.opt-panel-overlay.open { display: block; }
.opt-visits-panel {
  position: fixed; right: 0; top: 60px; bottom: 0;
  width: 480px; max-width: 95vw; z-index: 1000;
  background: var(--surface); box-shadow: -4px 0 20px rgba(0,0,0,.15);
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform .25s cubic-bezier(.4,0,.2,1);
  overflow-x: hidden; box-sizing: border-box;
}
.opt-visits-panel.open { transform: translateX(0); }
.opt-panel-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.opt-panel-titel { font-size: 15px; font-weight: 700; color: var(--text-primary); }
.opt-panel-body { flex: 1; overflow-y: auto; padding: 8px 0; }

/* ── OPT PANEL TABS ── */
.opt-panel-tabs {
  display: flex; gap: 4px; padding: 10px 16px;
  border-bottom: 1px solid var(--border); flex-shrink: 0; flex-wrap: wrap;
}
.opt-tab {
  padding: 4px 11px; border-radius: 20px; border: 1px solid var(--border);
  font-size: 12px; font-weight: 600; cursor: pointer; background: var(--surface-2);
  color: var(--text-secondary); transition: background .15s, color .15s;
  display: flex; align-items: center; gap: 5px;
}
.opt-tab:hover { background: var(--border); }
.opt-tab.active { background: var(--gold, #e8a020); border-color: var(--gold, #e8a020); color: #fff; }
.opt-tab-count {
  background: rgba(255,255,255,.25); border-radius: 10px;
  padding: 0 5px; font-size: 11px; font-weight: 700;
}
.opt-tab:not(.active) .opt-tab-count { background: var(--surface); color: var(--text-tertiary); }

/* ── OPT ACCORDION ── */
.opt-acc-rij {
  border-bottom: 1px solid var(--border);
}
.opt-acc-top {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px; cursor: pointer; transition: background .12s;
}
.opt-acc-top:hover { background: var(--surface-2); }
.opt-acc-nr { font-size: 12px; font-weight: 700; color: var(--text-primary); flex-shrink: 0; min-width: 52px; }
.opt-acc-info { flex: 1; display: flex; flex-direction: column; gap: 1px; min-width: 0; overflow: hidden; }
.opt-acc-klant {
  font-size: 13px; color: var(--text-primary); font-weight: 500;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  word-break: break-word; overflow-wrap: break-word;
}
.opt-acc-sub { font-size: 11px; color: var(--text-tertiary); }
.opt-acc-badge {
  font-size: 10px; font-weight: 700; padding: 2px 6px; border-radius: 12px; flex-shrink: 0;
}
.opt-acc-badge-prio    { background: var(--red-light);    color: var(--red); }
.opt-acc-badge-normaal { background: var(--orange-light); color: var(--orange); }
.opt-acc-badge-opvul   { background: var(--surface-2);    color: var(--text-tertiary); }
.opt-acc-badge-fixed   { background: #fef3cd;             color: #856404; }
.opt-acc-detail {
  padding: 0 16px 12px 40px; display: flex; flex-direction: column; gap: 4px;
  overflow-x: hidden; word-break: break-word; overflow-wrap: break-word;
}
.opt-acc-detail-rij {
  font-size: 12px; color: var(--text-secondary);
  display: flex; gap: 6px; word-break: break-word; overflow-wrap: break-word;
}
.opt-acc-detail-rij strong { color: var(--text-primary); font-weight: 600; min-width: 70px; }
.opt-acc-acties { display: flex; gap: 8px; margin-top: 8px; flex-wrap: wrap; }
.opt-acc-btn {
  padding: 5px 12px; border-radius: var(--radius); border: 1px solid var(--border);
  background: var(--surface); font-size: 12px; font-weight: 600;
  cursor: pointer; color: var(--text-primary); transition: background .15s;
}
.opt-acc-btn:hover { background: var(--surface-2); }
.opt-acc-btn-blok { border-color: var(--red); color: var(--red); }
.opt-acc-btn-blok:hover { background: var(--red-light); }

/* bekijk alle knop */
.opt-bekijk-btn {
  display: block; width: calc(100% - 32px); margin: 10px 16px 4px;
  padding: 8px 14px; background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius); font-size: 13px; font-weight: 600;
  color: var(--text-primary); cursor: pointer; text-align: left;
  transition: background .15s;
}
.opt-bekijk-btn:hover { background: var(--border); }

/* old item styles kept for any remaining references */
.opt-panel-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 20px; border-bottom: 1px solid var(--border);
}
.opt-panel-item:last-child { border-bottom: none; }
.opt-panel-item-main { flex: 1; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.opt-panel-case-nr { font-size: 13px; font-weight: 700; color: var(--text-primary); }
.opt-panel-klant { font-size: 12px; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.opt-panel-type { font-size: 11px; color: var(--text-tertiary); }
.opt-panel-item-side { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.opt-panel-badge {
  font-size: 11px; font-weight: 700; padding: 2px 7px; border-radius: 20px;
}
.opt-panel-badge-prio    { background: var(--red-light);    color: var(--red); }
.opt-panel-badge-normaal { background: var(--orange-light); color: var(--orange); }
.opt-panel-badge-grijs   { background: var(--surface-2);    color: var(--text-tertiary); }
.opt-panel-arrow {
  background: none; border: 1px solid var(--border); border-radius: 6px;
  padding: 4px 10px; cursor: pointer; font-size: 14px; font-weight: 700;
  color: var(--navy); transition: background .15s;
}
.opt-panel-arrow:hover { background: var(--surface-2); }

/* ── OPTIMIZER MINI POPUPS ── */
.opt-mini-overlay {
  display: none; position: fixed; inset: 0; z-index: 210;
  background: rgba(21,32,56,.4);
}
.opt-mini-overlay.open { display: block; }
.opt-mini-popup {
  display: none; position: fixed; z-index: 211;
  top: 50%; left: 50%; transform: translate(-50%,-50%) scale(.96);
  width: 360px; max-width: 95vw;
  background: var(--surface); border-radius: 12px;
  box-shadow: 0 8px 40px rgba(21,32,56,.2);
  flex-direction: column;
  transition: transform .2s, opacity .2s;
  opacity: 0;
}
.opt-mini-popup.open {
  display: flex; opacity: 1; transform: translate(-50%,-50%) scale(1);
}
.opt-mini-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px; border-bottom: 1px solid var(--border);
  font-size: 15px;
}
.opt-mini-body { padding: 16px 20px; display: flex; flex-direction: column; gap: 8px; }
.opt-mini-label { font-size: 12px; font-weight: 600; color: var(--text-secondary); }
.opt-mini-input {
  width: 100%; padding: 7px 10px; border: 1px solid var(--border);
  border-radius: var(--radius); font-size: 14px; background: var(--surface);
  color: var(--text-primary); box-sizing: border-box;
}
.opt-mini-input:focus { outline: none; border-color: var(--accent); }
.opt-mini-textarea {
  width: 100%; padding: 7px 10px; border: 1px solid var(--border);
  border-radius: var(--radius); font-size: 13px; resize: vertical;
  background: var(--surface); color: var(--text-primary); box-sizing: border-box;
  font-family: inherit;
}
.opt-mini-textarea:focus { outline: none; border-color: var(--accent); }
.opt-mini-check-rij {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text-primary); cursor: pointer;
}
.opt-mini-hint { font-size: 13px; color: var(--text-secondary); margin: 0; }
.opt-mini-footer {
  display: flex; justify-content: flex-end; gap: 8px;
  padding: 12px 20px; border-top: 1px solid var(--border);
}

/* Tab-eigen selectie-CSS verwijderd in Ronde I — Planning gebruikt
   eigen .pl-rij-geselecteerd + .pl-dag-geselecteerd in dashboard.css
   (zie modus-beschikbaarheid sectie hieronder). */

/* ── BESCH DAG PANEL (rechts) ── */
.besch-dag-panel {
  position: fixed; right: 0; top: 0; bottom: 0;
  width: 360px; max-width: 95vw; z-index: 160;
  background: var(--surface); box-shadow: -4px 0 24px rgba(21,32,56,.15);
  display: flex; flex-direction: column; overflow: hidden;
}
.besch-dag-panel-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.besch-dag-panel-header strong { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.besch-form-dag-count { display: block; font-size: 12px; color: var(--text-secondary); margin-top: 2px; }
.besch-dag-panel-body {
  flex: 1; overflow-y: auto; padding: 14px 18px; display: flex; flex-direction: column; gap: 14px;
}
.besch-dag-panel-footer {
  display: flex; justify-content: flex-end; gap: 8px;
  padding: 12px 18px; border-top: 1px solid var(--border); flex-shrink: 0;
}

@media (max-width: 768px) {
  .besch-dag-panel {
    top: auto; right: 0; left: 0; bottom: 0;
    width: 100%; max-width: 100%;
    height: 70vh; border-radius: 16px 16px 0 0;
    box-shadow: 0 -4px 30px rgba(21,32,56,.2);
  }
}

/* Toast */
.besch-toast {
  position: fixed; bottom: 80px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--navy); color: #fff; padding: 10px 22px;
  border-radius: 24px; font-size: 14px; font-weight: 600;
  opacity: 0; transition: opacity .2s, transform .2s;
  pointer-events: none; z-index: 300; white-space: nowrap;
}
.besch-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* Klus-kaart klikbaar */
.klus-kaart[data-case-id] { cursor: pointer; }
.klus-kaart[data-case-id]:hover { opacity: .85; }

/* ── NIEUWE CASE MODAL (ronde A) ─────────────────────────────────────── */
.nieuwe-case-overlay {
  position: fixed; inset: 0; z-index: 9000;
  display: none;
  align-items: center; justify-content: center;
}
.nieuwe-case-overlay.open { display: flex; }
.nieuwe-case-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.5);
}
.nieuwe-case-card {
  position: relative;
  background: var(--surface);
  width: 520px; max-width: 96vw;
  max-height: 92vh; overflow: hidden;
  border-radius: 8px;
  box-shadow: 0 12px 40px rgba(0,0,0,.2);
  display: flex; flex-direction: column;
}
.nieuwe-case-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
  background: var(--surface-2);
}
.nieuwe-case-header h3 {
  margin: 0; font-size: 16px; font-weight: 700; color: var(--text-primary);
}
.nieuwe-case-sluit {
  background: none; border: none; cursor: pointer;
  font-size: 22px; color: var(--text-tertiary);
  line-height: 1; padding: 0 4px;
}
.nieuwe-case-sluit:hover { color: var(--text-primary); }
.nieuwe-case-body {
  flex: 1; overflow-y: auto;
  padding: 16px 20px;
  display: flex; flex-direction: column; gap: 4px;
}
.nieuwe-case-label {
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .05em;
  color: var(--text-tertiary);
  margin-top: 10px; margin-bottom: 4px;
}
.nieuwe-case-input {
  width: 100%; box-sizing: border-box;
  padding: 8px 12px;
  font-size: 13px;
  border: 1px solid #D1D5DB;
  border-radius: 6px;
  background: #fff;
  outline: none;
  transition: border-color .12s, box-shadow .12s;
}
.nieuwe-case-input:focus {
  border-color: #3B82F6;
  box-shadow: 0 0 0 3px rgba(59,130,246,.15);
}
.nieuwe-case-textarea { resize: vertical; min-height: 60px; max-height: 160px; line-height: 1.45; }
.nieuwe-case-rij {
  display: flex; gap: 10px; align-items: flex-end;
}
.nieuwe-case-footer {
  display: flex; justify-content: flex-end; gap: 10px;
  padding: 12px 20px;
  border-top: 1px solid var(--border);
  background: var(--surface-2);
}
.nieuwe-case-footer .btn-actie-sec,
.nieuwe-case-footer .btn-actie-primair { width: auto; }

/* Intake-modaal — Ronde I */
.nc-kopieer-rij {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; margin-bottom: 14px;
  background: var(--surface-2); border: 1px dashed var(--border);
  border-radius: 6px;
}
.nc-kopieer-label { font-size: 12px; color: var(--text-secondary); white-space: nowrap; }
.nc-kopieer-select { flex: 1; }
.nc-sectie-scheiding {
  margin: 16px 0 8px; padding-bottom: 4px;
  border-bottom: 1px solid var(--border);
  font-size: 12px; font-weight: 600; color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.5px;
}
.nc-hint {
  margin: 4px 0 8px; font-size: 12px; color: var(--text-secondary);
  font-style: italic;
}
.nc-hint-info {
  margin-top: 14px; padding: 8px 10px;
  background: #EFF6FF; border-left: 3px solid #3B82F6;
  color: #1E3A8A; font-style: normal; font-size: 12px; border-radius: 4px;
}
.nc-adres-cluster-strip { margin: 4px 0 8px; }
.nc-adres-cluster-strip:empty { display: none; }
.nc-cluster-strip-inhoud {
  padding: 8px 10px; background: #FEF3C7; border-left: 3px solid #D97706;
  font-size: 12px; color: #78350F; border-radius: 4px;
}
.nc-cluster-strip-inhoud ul { margin: 4px 0 0; padding-left: 18px; }
.nc-cluster-link {
  background: none; border: none; padding: 0;
  color: #1D4ED8; text-decoration: underline; cursor: pointer;
  font-size: 12px; font-family: inherit;
}
.nc-cluster-link:hover { color: #1E3A8A; }

/* Case-overlay — Andere projecten op dit adres (zone 3): expandable cards */
.co-andere-cases-lijst { display: flex; flex-direction: column; gap: 8px; }
.co-ap-card {
  padding: 10px 12px;
  background: var(--surface-2, #F8FAFC);
  border: 1px solid var(--border, #E2E8F0);
  border-radius: 6px;
  cursor: pointer;
  transition: background 120ms ease, border-color 120ms ease;
  font-size: 12px;
}
.co-ap-card:hover { background: #F1F5F9; border-color: #CBD5E1; }
.co-ap-card.co-ap-open { background: #FFFFFF; border-color: #CBD5E1; }
.co-ap-header {
  display: flex; justify-content: space-between; align-items: center;
  gap: 8px;
}
.co-ap-titel { font-weight: 600; color: var(--text-primary, #111); }
.co-ap-nr { font-weight: 700; }
.co-ap-datum { color: var(--text-secondary, #475569); font-weight: 500; margin-left: 4px; }
.co-ap-chevron {
  color: var(--text-secondary, #475569); font-size: 14px;
  transition: transform 200ms ease;
  display: inline-block;
}
.co-ap-sub { margin-top: 3px; color: var(--text-secondary, #475569); }
.co-ap-status { margin-top: 2px; font-size: 11px; font-weight: 600; }
.co-ap-detail {
  margin-top: 10px; padding-top: 10px;
  border-top: 1px solid var(--border, #E2E8F0);
  display: flex; flex-direction: column; gap: 4px;
}
.co-ap-detail-loader, .co-ap-detail-error {
  font-style: italic; color: var(--text-secondary, #475569);
}
.co-ap-detail-error { color: #B91C1C; }
.co-ap-detail-inhoud > div { line-height: 1.5; }
.co-ap-lbl { color: var(--text-secondary, #475569); margin-right: 4px; }
.co-ap-bezoeken-titel { margin-top: 6px; font-weight: 600; }
.co-ap-visits { list-style: none; margin: 2px 0 0; padding-left: 8px; }
.co-ap-visits li { padding: 2px 0; }
.co-ap-visits li::before { content: '• '; color: var(--text-secondary, #475569); }
.co-ap-leeg { color: var(--text-secondary, #475569); font-style: italic; }
.co-ap-omschrijving { margin-top: 6px; }
.co-ap-omschrijving > div { white-space: pre-wrap; color: var(--text-primary, #111); }

/* ── Modus-toggle Planning (Ronde I) ─────────────────────────────────── */
.pl-modus-toggle {
  display: inline-flex; align-items: center; gap: 8px;
  cursor: pointer; user-select: none;
  padding: 4px 10px;
  border-radius: 6px;
  background: transparent;
  transition: background 120ms ease;
}
.pl-modus-toggle:hover { background: #F1F5F9; }
.pl-modus-toggle input { display: none; }
.pl-modus-switch {
  position: relative;
  width: 36px; height: 20px;
  background: #CBD5E1;
  border-radius: 10px;
  transition: background 150ms ease;
}
.pl-modus-switch::after {
  content: ''; position: absolute;
  top: 2px; left: 2px;
  width: 16px; height: 16px;
  background: white;
  border-radius: 50%;
  transition: transform 150ms ease;
}
.pl-modus-toggle input:checked + .pl-modus-switch { background: #F59E0B; }
.pl-modus-toggle input:checked + .pl-modus-switch::after { transform: translateX(16px); }
.pl-modus-label { font-size: 13px; font-weight: 600; color: var(--text-primary, #1E293B); }

.pl-modus-banner {
  padding: 10px 16px;
  background: #FEF3C7;
  border-bottom: 2px solid #F59E0B;
  font-size: 13px; color: #78350F;
  display: flex; align-items: center; gap: 8px;
}

/* Bulk-edit-paneel komt uit beschikbaarheid.js (#besch-dag-panel),
   geen apart Planning-paneel meer. Wanneer paneel open is, krijgt de
   Planning-grid padding-right zodat de vrijdag-cel zichtbaar/klikbaar
   blijft naast het 360px-paneel. Op Beschikbaarheid-tab heeft de class
   geen effect — die grid heeft sowieso ruimte rechts. */
body.bulk-paneel-open #pl-grid-wrap {
  padding-right: 376px;  /* 360 paneel + 16 marge */
  transition: padding-right 150ms ease;
}

/* ── Quick-toggle iconen op pl-dag-strip (Ronde I vervolg) ───────────── */
/* Alleen in planning-modus zijn ⚡ en 🏢 klikbaar — in beschikbaarheid-
   modus heeft cel-klik voorrang (handler in JS doet niets in die modus). */
body:not(.modus-beschikbaarheid) .pl-dag-strip .pl-icon-toggle {
  cursor: pointer;
  transition: transform 100ms ease, opacity 150ms ease;
}
body:not(.modus-beschikbaarheid) .pl-dag-strip .pl-icon-toggle:hover {
  transform: scale(1.18);
}
.pl-dag-strip .pl-icon-toggle.uit {
  opacity: 0.3;
  filter: grayscale(70%);
}
.pl-dag-strip .pl-icon-toggle.aan {
  opacity: 1;
}

/* Visit-tiles op de achtergrond in beschikbaarheid-modus */
body.modus-beschikbaarheid .pl-stop {
  opacity: 0.35;
  pointer-events: none;
  filter: grayscale(30%);
  transition: opacity 150ms ease;
}

/* Context-strips juist sterker accentueren — duidelijker dat ze klikbaar zijn */
body.modus-beschikbaarheid .pl-dag-strip {
  background-color: #FEF3C7;
  border-bottom: 2px solid #F59E0B;
  font-weight: 600;
  pointer-events: auto;
}

/* Hele beschikbaar-cel klikbaar in beschikbaarheid-modus */
body.modus-beschikbaarheid .pl-dag-cel-beschikbaar { cursor: pointer; }
body.modus-beschikbaarheid .pl-dag-cel-beschikbaar:hover {
  background-color: #FFFBEB;
}

/* Onbeschikbare cellen ook klikbaar (om te activeren) */
body.modus-beschikbaarheid .pl-dag-leeg-onbeschikbaar {
  cursor: pointer;
  opacity: 0.7;
}
body.modus-beschikbaarheid .pl-dag-leeg-onbeschikbaar:hover {
  opacity: 0.95;
  background-color: #FFFBEB;
}

/* Monteur-cel toont kebab in beschikbaarheid-modus */
body.modus-beschikbaarheid .pl-monteur-cel { cursor: pointer; position: relative; }
body.modus-beschikbaarheid .pl-monteur-cel:hover { background-color: #FFFBEB; }
.pl-monteur-cel .besch-kebab-wrap { display: none; }
body.modus-beschikbaarheid .pl-monteur-cel .besch-kebab-wrap {
  display: inline-block;
  margin-left: 6px;
  vertical-align: middle;
}

/* Geselecteerde monteur-rij */
body.modus-beschikbaarheid tr.pl-rij-geselecteerd .pl-monteur-cel {
  background-color: #FEF3C7;
}

/* Geselecteerde dagen voor bulk-edit */
body.modus-beschikbaarheid .pl-dag-cel.pl-dag-geselecteerd {
  outline: 3px solid #F59E0B;
  outline-offset: -3px;
}

/* ── Case-overlay onderdeel-rij (H2.1) ───────────────────────────────── */
.co-onderdeel-rij {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 16px;
  background: var(--surface-2, #F8FAFC);
  border-bottom: 1px solid var(--border, #E2E8F0);
  font-size: 13px;
}
.co-onderdeel-label { font-weight: 600; color: var(--text-secondary, #475569); }
.co-onderdeel-select {
  padding: 4px 8px; border: 1px solid var(--border-strong, #CBD5E1);
  border-radius: 4px; background: white; font-size: 13px;
  font-family: inherit;
}
.co-onderdeel-select:disabled { background: #F1F5F9; color: #94A3B8; cursor: not-allowed; }
.co-onderdeel-datum {
  color: var(--text-secondary, #64748B); font-style: italic; font-size: 12px;
  margin-left: auto;
}

/* ── Header-knop: Onderdeel-binnenkomst (H2) ─────────────────────────── */
.pl-binnenkomst-btn {
  background: #F1F5F9; color: #1E293B; border: 1px solid var(--border, #CBD5E1);
  border-radius: 6px; padding: 6px 12px;
  font-size: 13px; font-weight: 600; cursor: pointer;
  margin-right: 8px;
}
.pl-binnenkomst-btn:hover { background: #E2E8F0; }

/* ── Onderdeel-binnenkomst modal (H2) ────────────────────────────────── */
.bk-uitleg { margin: 4px 0 12px; color: var(--text-secondary, #64748B); font-size: 13px; }
.bk-toast {
  margin: 0 0 12px; padding: 8px 12px; border-radius: 6px;
  font-size: 13px; font-weight: 600;
  transition: opacity 200ms ease;
}
.bk-toast-ok   { background: #DCFCE7; color: #14532D; border: 1px solid #86EFAC; }
.bk-toast-fout { background: #FEE2E2; color: #7F1D1D; border: 1px solid #FCA5A5; }

.bk-resultaat { margin-top: 14px; min-height: 40px; }
.bk-leeg { color: var(--text-secondary, #64748B); font-style: italic; font-size: 13px; }
.bk-fout { color: #B91C1C; font-size: 13px; }

.bk-lijst { display: flex; flex-direction: column; gap: 4px; margin-bottom: 12px; }
.bk-lijst-item {
  display: grid; grid-template-columns: auto 1fr auto; gap: 10px;
  align-items: center; padding: 8px 10px;
  background: var(--surface-2, #F8FAFC); border: 1px solid var(--border, #E2E8F0);
  border-radius: 6px; cursor: pointer; text-align: left;
  font-family: inherit; font-size: 13px;
}
.bk-lijst-item:hover { background: #E2E8F0; }
.bk-lijst-nr { font-weight: 700; }
.bk-lijst-stad { color: var(--text-secondary, #475569); }

.bk-card {
  padding: 14px 16px; background: #FFFFFF;
  border: 1px solid var(--border-strong, #CBD5E1); border-radius: 8px;
  display: flex; flex-direction: column; gap: 6px;
}
.bk-card-header { display: flex; justify-content: space-between; align-items: center; }
.bk-card-nr { font-size: 18px; font-weight: 700; }
.bk-card-sub { color: var(--text-secondary, #475569); font-size: 13px; }
.bk-card-rij { font-size: 13px; }
.bk-card-lbl { color: var(--text-secondary, #64748B); font-weight: 600; margin-right: 4px; }
.bk-card-bevestig {
  margin-top: 10px; padding: 10px 16px;
  background: #16A34A; color: white; border: none;
  border-radius: 6px; font-size: 14px; font-weight: 700;
  cursor: pointer; transition: background 120ms ease;
}
.bk-card-bevestig:hover { background: #15803D; }
/* Herprint-variant: secundaire actie, neutraler dan groene bevestig-knop */
.bk-card-herprint {
  background: #fff;
  color: #374151;
  border: 1px solid #d1d5db;
}
.bk-card-herprint:hover { background: #f3f4f6; border-color: #9ca3af; }
.bk-card-herprint-info {
  margin-top: 6px; font-size: 12px; color: var(--text-secondary, #475569);
  font-style: italic;
}

.bk-badge {
  display: inline-block; padding: 2px 8px; border-radius: 4px;
  font-size: 11px; font-weight: 600;
  background: #F1F5F9; color: #475569; border: 1px solid #CBD5E1;
}
.bk-badge-wacht_op_onderdeel { background: #FEF3C7; color: #78350F; border-color: #FCD34D; }
.bk-badge-beschikbaar { background: #DBEAFE; color: #1E40AF; border-color: #93C5FD; }
.bk-badge-voorgesteld { background: #FEF3C7; color: #78350F; border-color: #FCD34D; }
.bk-badge-bevestigd { background: #DCFCE7; color: #14532D; border-color: #86EFAC; }
.bk-badge-afgerond { background: #E2E8F0; color: #334155; border-color: #94A3B8; }
.bk-badge-ond-onderweg { background: #FEF3C7; color: #78350F; border-color: #FCD34D; }
.bk-badge-ond-ontvangen { background: #DCFCE7; color: #14532D; border-color: #86EFAC; }
.bk-badge-ond-niet_nodig { background: #F1F5F9; color: #475569; border-color: #CBD5E1; }

/* Intake-modaal: cluster-strip met klantgegevens-overnemen + open-in-tab */
.nc-cluster-strip-titel { font-weight: 600; margin-bottom: 6px; }
.nc-cluster-lijst { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.nc-cluster-item {
  display: grid; grid-template-columns: auto 1fr auto auto; gap: 8px;
  align-items: center;
}
.nc-cluster-nr { font-weight: 600; }
.nc-cluster-klant { color: #78350F; }
.nc-cluster-btn {
  font-size: 11px; padding: 4px 8px; border-radius: 4px;
  border: 1px solid #D97706; background: #FFF; color: #78350F;
  cursor: pointer; font-family: inherit; text-decoration: none;
  white-space: nowrap; display: inline-block;
}
.nc-cluster-btn-overnemen { background: #FBBF24; color: #78350F; border-color: #D97706; font-weight: 600; }
.nc-cluster-btn-overnemen:hover { background: #F59E0B; }
.nc-cluster-btn-nieuw { background: #FFF; }
.nc-cluster-btn-nieuw:hover { background: #FEF3C7; }

/* Cases-lijst: extern case-nummer als subtitle */
.td-num .td-case-nr { font-weight: 600; }
.td-num .td-extern-nr {
  font-size: 11px; color: var(--text-secondary); margin-top: 2px;
}

/* ── MAP-VIEW (Ronde F) ─────────────────────────────────────────── */
#screen-map.active { display: flex; }
#map-layout {
  display: flex;
  width: 100%;
  height: calc(100vh - 64px);
}
#map-sidebar {
  width: 280px;
  flex: 0 0 280px;
  padding: 1rem;
  overflow-y: auto;
  background: #fafafa;
  border-right: 1px solid var(--border, #e5e7eb);
  box-sizing: border-box;
}
#map-canvas { flex: 1; min-height: 400px; }
.map-sidebar-section { margin-bottom: 1rem; }
.map-sidebar-titel { margin: 0 0 .5rem 0; font-size: 14px; font-weight: 600; }
.map-sidebar-uitleg { font-size: 12px; color: var(--text-secondary); margin: 0; }

.map-modus-toggle {
  display: flex; flex-direction: column; gap: .5rem;
  margin-bottom: 1.25rem; padding-bottom: 1rem;
  border-bottom: 1px solid #e5e7eb;
}
.map-modus-toggle label {
  display: flex; align-items: center; gap: .5rem; cursor: pointer;
  padding: .375rem .5rem; border-radius: .375rem; font-size: 13px;
}
.map-modus-toggle label:hover { background: #f3f4f6; }
.map-modus-toggle input[type="radio"] { margin: 0; }

.map-status-checkboxes {
  display: flex; flex-direction: column; gap: .125rem; margin-bottom: .75rem;
}
.map-status-check {
  display: flex; align-items: center; gap: .5rem; cursor: pointer;
  padding: .25rem .375rem; border-radius: .25rem; font-size: 13px;
}
.map-status-check:hover { background: #f3f4f6; }
.map-status-dot {
  display: inline-block; width: 12px; height: 12px; border-radius: 50%;
  flex-shrink: 0; border: 1px solid rgba(0,0,0,.1);
}
.map-counter {
  font-size: 12px; color: var(--text-secondary, #6b7280);
  margin-top: .5rem; padding-top: .5rem; border-top: 1px solid #e5e7eb;
}

.map-popup { font-size: 13px; min-width: 200px; padding: .25rem; }
.map-popup-titel { font-weight: 600; font-size: 14px; margin-bottom: .25rem; }
.map-popup-status {
  display: inline-block; padding: .125rem .5rem; border-radius: .25rem;
  color: white; font-size: 11px; font-weight: 500; margin: .5rem 0;
}
.map-popup-type { color: #6b7280; font-size: 12px; margin-bottom: .5rem; }
.map-popup-ref { color: #6b7280; font-size: 11px; margin: .125rem 0 .25rem; font-family: monospace; }
.map-popup-knop {
  display: block; width: 100%; padding: .5rem;
  background: #3b82f6; color: white; border: none;
  border-radius: .375rem; cursor: pointer; font-size: 13px;
}
.map-popup-knop:hover { background: #2563eb; }
.map-stub { color: #9ca3af; font-style: italic; padding: 1rem 0; font-size: 13px; }

.map-route-veld { margin-bottom: 1rem; }
.map-route-veld label {
  display: block; font-size: 12px; font-weight: 500;
  margin-bottom: .25rem; color: #374151;
}
.map-route-veld select,
.map-route-veld input[type="date"] {
  width: 100%; padding: .5rem;
  border: 1px solid #d1d5db; border-radius: .375rem;
  font-size: 13px; box-sizing: border-box;
}
.map-knop-primary {
  width: 100%; padding: .625rem;
  background: #f59e0b; color: white;
  border: none; border-radius: .375rem;
  cursor: pointer; font-weight: 500; font-size: 13px;
}
.map-knop-primary:hover { background: #d97706; }
.map-route-stat-blok {
  margin-top: 1rem; padding: .75rem;
  background: #f9fafb; border-radius: .375rem;
  display: flex; justify-content: space-around;
  font-size: 12px; color: #374151;
}
.map-popup-eta { color: #6b7280; font-size: 12px; margin-top: .25rem; }
.map-leeg {
  color: #9ca3af; font-style: italic;
  padding: 1rem 0; text-align: center; font-size: 13px;
}

.map-route-stops {
  margin-top: 1.25rem;
  border-top: 1px solid #e5e7eb;
  padding-top: .75rem;
}
.map-stops-titel {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  color: #6b7280; margin-bottom: .5rem; letter-spacing: .03em;
}
.map-stops-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: .125rem;
}
.map-stop-item {
  display: flex; align-items: center; gap: .625rem;
  padding: .375rem .5rem; border-radius: .375rem; cursor: pointer;
}
.map-stop-item:hover { background: #f3f4f6; }
.map-stop-badge {
  flex-shrink: 0; width: 22px; height: 22px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: white; font-size: 11px; font-weight: 600;
  border: 1px solid rgba(0,0,0,.05);
}
.map-stop-start  .map-stop-badge { background: #10b981; }
.map-stop-eind   .map-stop-badge { background: #ef4444; }
.map-stop-kantoor .map-stop-badge { background: #6b7280; }
.map-stop-info { flex: 1; min-width: 0; }
.map-stop-tijd { font-size: 11px; color: #6b7280; font-weight: 500; }
.map-stop-naam { font-size: 13px; font-weight: 500; color: #111827; }
.map-stop-sub  { font-size: 11px; color: #6b7280; }

.map-monteurs-header {
  display: flex; align-items: center; justify-content: space-between;
}
.map-monteurs-shortcuts { display: flex; gap: .5rem; }
.map-monteurs-shortcut {
  font-size: 11px; color: #3b82f6; background: none;
  border: none; cursor: pointer; padding: 0;
}
.map-monteurs-shortcut:hover { text-decoration: underline; }
.map-monteurs-list, .map-status-list {
  display: flex; flex-direction: column; gap: .125rem;
  margin-top: .375rem;
}

.map-routes-lijst {
  margin-top: 1.25rem;
  border-top: 1px solid #e5e7eb;
  padding-top: .75rem;
}
.map-routes-lijst-titel {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  color: #6b7280; margin-bottom: .5rem; letter-spacing: .03em;
}
.map-route-item {
  display: flex; align-items: center; gap: .625rem;
  padding: .5rem .625rem; border-radius: .375rem;
  cursor: pointer; margin-bottom: .25rem;
  border-left: 3px solid transparent;
}
.map-route-item:hover { background: #f3f4f6; }
.map-route-item.geisoleerd {
  background: #fef3c7;
  border-left-color: #f59e0b;
}
.map-route-kleur-dot {
  width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0;
  border: 1px solid rgba(0,0,0,.1);
}
.map-route-info { flex: 1; min-width: 0; }
.map-route-naam { font-size: 13px; font-weight: 500; color: #111827; }
.map-route-meta { font-size: 11px; color: #6b7280; }

.map-periode-toggle {
  display: flex; gap: .5rem; margin-bottom: 1rem;
}
.map-periode-toggle label {
  flex: 1; display: flex; align-items: center; gap: .375rem;
  padding: .5rem; border: 1px solid #e5e7eb; border-radius: .375rem;
  cursor: pointer; font-size: 13px;
}
.map-periode-toggle label.actief {
  border-color: #f59e0b; background: #fef3c7; color: #92400e;
}
.map-periode-toggle input[type="radio"] { margin: 0; }

.map-range-warning {
  background: #fef3c7; color: #92400e;
  padding: .5rem .625rem; border-radius: .375rem;
  font-size: 12px; margin: .5rem 0;
}

.map-groepering-toggle {
  display: flex; align-items: center; gap: .5rem;
  margin: 1rem 0 .5rem; font-size: 12px; color: #6b7280;
}
.map-groep-btn {
  padding: .25rem .625rem; border: 1px solid #e5e7eb;
  background: white; border-radius: .25rem;
  cursor: pointer; font-size: 12px;
}
.map-groep-btn.actief {
  background: #f59e0b; color: white; border-color: #f59e0b;
}

.map-routes-dag-header {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  color: #6b7280; margin: .75rem 0 .25rem;
  padding-top: .5rem; border-top: 1px solid #f3f4f6;
  letter-spacing: .03em;
}
.map-routes-dag-header:first-child {
  margin-top: 0; padding-top: 0; border-top: none;
}
.map-routes-monteur-header {
  font-size: 13px; font-weight: 600; color: #111827;
  margin: .75rem 0 .25rem;
  display: flex; align-items: center; gap: .5rem;
}
.map-routes-monteur-header:first-child { margin-top: 0; }

.map-routes-dag-header,
.map-routes-monteur-header {
  cursor: pointer; user-select: none;
  border-radius: .25rem;
  padding-left: .375rem; padding-right: .375rem;
}
.map-routes-dag-header:hover,
.map-routes-monteur-header:hover { background: #f3f4f6; }
.map-routes-dag-header[data-actief="true"],
.map-routes-monteur-header[data-actief="true"] {
  background: #fef3c7;
  border-left: 3px solid #f59e0b;
  padding-left: .5rem;
}
.map-route-item[data-in-isolate="false"] { opacity: 0.4; }

.map-route-info-block {
  margin: .25rem 0 .5rem 1.5rem;
  padding: .625rem .75rem;
  background: #fffbeb;
  border-left: 3px solid #f59e0b;
  border-radius: .375rem;
}
.map-route-info-block .map-route-info-stats {
  font-size: 11px; color: #92400e;
  margin-bottom: .5rem; font-weight: 500;
}
.map-route-info-block .map-stops-list { margin: 0; }
.map-route-info-block .map-stop-item:hover { background: #fef3c7; }

/* ── Realtime indicator (rechtsboven) ── */
.rt-indicator {
  position: fixed; top: 12px; right: 12px;
  background: #fef3c7; color: #92400e;
  padding: .5rem .875rem; border-radius: 6px;
  font-size: 13px; font-weight: 500;
  z-index: 1000;
  box-shadow: 0 2px 8px rgba(0,0,0,.1);
}

/* ── LIVE-TAB (Ronde D commit 2.4b) ── */
.live-header {
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--border, #e5e7eb);
  background: white;
}
.live-header h1 { margin: 0; font-size: 22px; font-weight: 700; }
.live-datum { color: var(--text-secondary, #6b7280); font-size: 14px; margin-top: 4px; }

#live-monteurs { padding: 1rem 0; background: #fafafa; min-height: 60vh; }

.live-leeg {
  text-align: center; padding: 3rem 1rem;
  color: var(--text-secondary, #6b7280);
  font-style: italic;
}

.live-monteur-blok {
  padding: 1rem 1.5rem;
  background: white;
  border-bottom: 1px solid #f3f4f6;
}
.live-monteur-naam {
  font-size: 13px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .05em;
  color: #111827; margin: 0 0 .625rem;
}
.live-klussen { display: flex; flex-direction: column; gap: .5rem; }

.live-klus {
  display: flex; align-items: center; gap: .75rem;
  padding: .625rem .75rem;
  background: #fafafa;
  border-radius: 8px;
  border-left: 4px solid #e5e7eb;
}
.live-klus-groen  { border-left-color: #10b981; background: rgba(16,185,129,.06); }
.live-klus-grijs  { border-left-color: #6b7280; opacity: .8; }
.live-klus-oranje { border-left-color: #f97316; background: rgba(249,115,22,.06); }
.live-klus-blauw  { border-left-color: #3b82f6; }
.live-klus-rood   { border-left-color: #ef4444; background: rgba(239,68,68,.06); }

.live-klus-icon  { font-size: 18px; flex-shrink: 0; width: 22px; text-align: center; }
.live-klus-info  { flex: 1; min-width: 0; }
.live-klus-titel { font-weight: 600; font-size: 14px; color: #111827; }
.live-klus-stad  { font-weight: 400; color: #6b7280; }
.live-klus-extra { font-size: 12px; color: #6b7280; margin-top: 2px; }

/* ── H3.2: Verwachte-onderdelen paneel in case-overlay ── */
.co-onderdelen-paneel {
  margin: 12px 16px;
  padding: 12px;
  background: white;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
}
.co-od-header {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 8px;
}
.co-od-titel { font-weight: 600; font-size: 14px; }

/* Toggle-knop (chevron + titel) — onzichtbare knop-stijl, hele label
   klikbaar zonder dat het op een knop lijkt. */
.co-od-toggle {
  background: none; border: none; padding: 0; cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  font: inherit; color: inherit;
  flex: 1; text-align: left;
}
.co-od-toggle:hover .co-od-titel { color: #1d4f8a; }
.co-od-toggle:focus-visible { outline: 2px solid rgba(245,197,24,0.5); border-radius: 4px; }
.co-od-chevron {
  font-size: 11px; color: #4a5568; display: inline-block; width: 12px;
}

/* Inklap-gedrag op het wrap-element. Header + locked-banner blijven
   zichtbaar zodat status + acties altijd bereikbaar. */
#co-onderdelen-paneel[data-collapsed="1"] .co-od-lijst,
#co-onderdelen-paneel[data-collapsed="1"] .co-od-batch-paste-area,
#co-onderdelen-paneel[data-collapsed="1"] .co-od-print-prominent {
  display: none !important;
}

/* L-overlay-fix: zelfde inklap-gedrag voor benodigdheden-paneel
   (header zichtbaar, lijst verbergen). */
#co-benodigdheden-paneel[data-collapsed="1"] .co-od-lijst {
  display: none !important;
}

.co-od-btn-toevoegen, .co-od-btn-plakken {
  padding: 4px 10px; font-size: 12px; font-weight: 500;
  background: #F5C518; color: #152038; border: none; border-radius: 4px;
  cursor: pointer;
}
.co-od-btn-toevoegen:hover, .co-od-btn-plakken:hover { background: #e0b412; }
.co-od-btn-plakken {
  background: white; color: #374151; border: 1px solid #d1d5db;
}
.co-od-locked-banner {
  padding: 6px 10px; margin-bottom: 8px;
  background: #fef3c7; color: #92400e;
  border-left: 3px solid #f59e0b; border-radius: 3px; font-size: 12px;
}
.co-od-lijst { display: flex; flex-direction: column; gap: 4px; }
.co-od-loader, .co-od-fout, .co-od-leeg {
  padding: 12px; color: #6b7280; font-style: italic; text-align: center; font-size: 13px;
}
.co-od-fout { color: #ef4444; font-style: normal; }
.co-od-rij {
  display: grid; grid-template-columns: 120px 1fr auto repeat(4, auto);
  align-items: center; gap: 6px;
  padding: 6px 8px;
  background: #f9fafb; border-radius: 4px;
  font-size: 13px;
}
.co-od-rij[data-status="binnen"]     { background: #ecfdf5; }
.co-od-rij[data-status="gemonteerd"] { background: #d1fae5; opacity: .8; }
.co-od-rij[data-status="mismatch"]   { background: #fee2e2; }
.co-od-rij[data-status="retour"]     { background: #f3f4f6; opacity: .65; }
.co-od-status { font-size: 12px; font-weight: 500; white-space: nowrap; }
.co-od-sn { font-family: monospace; font-size: 12px; font-weight: 500; color: #111827; }
.co-od-type { font-size: 11px; color: #6b7280; font-style: italic; }
.co-od-btn-edit, .co-od-btn-del {
  background: none; border: none; cursor: pointer;
  padding: 4px; font-size: 14px; border-radius: 3px;
}
.co-od-btn-edit:hover { background: #fef3c7; }
.co-od-btn-del:hover:not(:disabled) { background: #fee2e2; }
.co-od-btn-del:disabled { opacity: .3; cursor: not-allowed; }

/* H3.3 — Print-knoppen */
.co-od-btn-print-opslag, .co-od-btn-print-monteur {
  background: none; border: 1px solid #d1d5db; cursor: pointer;
  padding: 2px 6px; font-size: 12px; border-radius: 3px;
  color: #374151;
}
.co-od-btn-print-opslag:hover, .co-od-btn-print-monteur:hover {
  background: #f3f4f6; border-color: #9ca3af;
}
.co-od-btn-print-alle-opslag, .co-od-btn-print-alle-monteur {
  padding: 4px 10px; font-size: 12px; font-weight: 500;
  background: white; color: #374151; border: 1px solid #d1d5db; border-radius: 4px;
  cursor: pointer;
}
.co-od-btn-print-alle-opslag:hover, .co-od-btn-print-alle-monteur:hover {
  background: #f3f4f6;
}
.co-od-print-prominent {
  margin-bottom: 10px;
}
.co-od-btn-print-prominent {
  width: 100%; padding: 10px 16px; font-size: 14px; font-weight: 600;
  background: #152038; color: #F5C518; border: none; border-radius: 6px;
  cursor: pointer;
}
.co-od-btn-print-prominent:hover { background: #1f2d4d; }

.co-od-batch-paste-area {
  margin-top: 8px; padding: 10px;
  background: #f9fafb; border: 1px solid #e5e7eb; border-radius: 4px;
}
.co-od-paste-titel { font-size: 12px; font-weight: 500; margin-bottom: 6px; color: #374151; }
.co-od-paste-input {
  width: 100%; padding: 6px; font-family: monospace; font-size: 12px;
  border: 1px solid #d1d5db; border-radius: 3px; box-sizing: border-box;
}
.co-od-paste-acties { display: flex; gap: 8px; justify-content: flex-end; margin-top: 8px; }
.co-od-paste-acties button {
  padding: 4px 12px; font-size: 12px; border-radius: 4px; cursor: pointer; border: none;
}
.co-od-paste-annuleer { background: white; border: 1px solid #d1d5db !important; color: #374151; }
.co-od-paste-submit   { background: #152038; color: white; }

/* Notitie-voor-monteur textarea: laat 'm net iets opvallen */
.co-notitie-monteur {
  resize: vertical; min-height: 60px;
  font-family: inherit; line-height: 1.4;
}

/* K.4 — Duur-input + hint-suffix in bezoek-sectie */
.co-duur-wrap {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.co-duur-input { width: 70px; }
.co-duur-eenheid { color: #6b7280; font-size: 12px; }
.co-duur-default-lbl {
  color: #9ca3af; font-size: 12px; font-style: italic;
}
.co-duur-reset {
  background: none; border: 1px solid #d1d5db;
  padding: 2px 8px; font-size: 11px; color: #374151;
  border-radius: 4px; cursor: pointer;
}
.co-duur-reset:hover { background: #f3f4f6; }

/* ── D5.5.A — Pakking-status regel onder elk onderdeel ── */
.co-od-pakking-rij {
  display: flex; align-items: center; gap: 6px;
  margin-left: 18px;
  padding: 3px 8px 5px;
  font-size: 12px;
  color: #374151;
  cursor: pointer;
  border-radius: 3px;
  user-select: none;
}
.co-od-pakking-rij:hover { background: #f3f4f6; }
.co-od-pakking-leeg     { color: #9ca3af; font-style: italic; }
.co-od-pakking-gevuld   { color: #047857; }
.co-od-pakking-icon     { font-size: 13px; }
.co-od-pakking-txt      { flex: 1; min-width: 0; }
.co-od-pakking-info     {
  opacity: .55; font-size: 12px;
  transition: opacity .15s;
}
.co-od-pakking-rij:hover .co-od-pakking-info { opacity: 1; }

/* Pakking-historie modal */
.co-pakk-hist-backdrop {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, .45);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
}
.co-pakk-hist-modal {
  background: #fff; border-radius: 8px;
  width: min(520px, 92vw);
  max-height: 80vh; display: flex; flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
}
.co-pakk-hist-kop {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid #e5e7eb;
}
.co-pakk-hist-titel { margin: 0; font-size: 15px; font-weight: 600; color: #111827; }
.co-pakk-hist-sluit {
  background: none; border: none; cursor: pointer;
  font-size: 18px; color: #6b7280; padding: 4px 8px; border-radius: 4px;
}
.co-pakk-hist-sluit:hover { background: #f3f4f6; color: #111827; }
.co-pakk-hist-body { padding: 14px 18px; overflow-y: auto; }
.co-pakk-hist-loader, .co-pakk-hist-leeg, .co-pakk-hist-fout {
  padding: 18px; text-align: center; color: #6b7280; font-style: italic;
}
.co-pakk-hist-fout { color: #ef4444; font-style: normal; }
.co-pakk-hist-lijst { list-style: none; margin: 0; padding: 0; }
.co-pakk-hist-item {
  display: grid; grid-template-columns: 130px 22px 1fr;
  align-items: baseline; gap: 8px;
  padding: 8px 4px; border-bottom: 1px solid #f3f4f6;
  font-size: 13px;
}
.co-pakk-hist-item:last-child { border-bottom: none; }
.co-pakk-hist-tijd { color: #6b7280; font-family: monospace; font-size: 12px; }
.co-pakk-hist-icon { text-align: center; font-size: 14px; }
.co-pakk-hist-txt  { color: #111827; }

/* ── D5.5.B — Benodigdheden-sectie (tools per case) ── */
#co-benodigdheden-paneel:empty { display: none; }
#co-benodigdheden-paneel { margin-top: 8px; }
.co-bn-lijst { gap: 2px !important; }
.co-bn-rij {
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: center; gap: 10px;
  padding: 6px 8px;
  background: #f9fafb; border-radius: 4px;
  font-size: 13px;
  cursor: pointer;
  user-select: none;
}
.co-bn-rij:hover { background: #f3f4f6; }
.co-bn-checkbox { width: 16px; height: 16px; cursor: pointer; margin: 0; }
.co-bn-checkbox:disabled { cursor: not-allowed; }
.co-bn-naam { font-weight: 500; color: #111827; }
.co-bn-loc { font-size: 12px; text-align: right; }
.co-bn-loc-zaak { color: #6b7280; font-style: italic; }
.co-bn-loc-bij  { color: #047857; }

/* ── H3.2: Binnenkomst-modal aangepast ── */
.bk-od-titel { font-weight: 600; font-size: 13px; margin: 10px 0 6px; color: #374151; }
.bk-od-lijst { display: flex; flex-direction: column; gap: 4px; margin-bottom: 8px; }
.bk-od-check {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px; background: #f9fafb; border-radius: 4px;
  cursor: pointer; font-size: 13px;
}
.bk-od-check:hover { background: #f3f4f6; }
.bk-od-check input { margin: 0; cursor: pointer; }
.bk-od-sn { font-family: monospace; font-size: 12px; color: #111827; }
.bk-od-al-binnen {
  padding: 4px 10px; background: #ecfdf5; border-radius: 3px;
  font-size: 11px; color: #065f46; margin-bottom: 8px;
}
.bk-od-hint {
  padding: 6px 10px; background: #fef3c7; color: #92400e;
  border-left: 3px solid #f59e0b; border-radius: 3px;
  font-size: 12px; margin-bottom: 10px;
}
.bk-card-leeg {
  padding: 12px; background: #fef3c7; color: #92400e;
  border-radius: 4px; font-size: 13px;
}
