/* ═══════════════════════════════════════════════════════════
   TedaCity Politie — Personeelsbeheer v3
   style.css
   ═══════════════════════════════════════════════════════════ */

/* ─── RESET & ROOT ─────────────────────────────────────────── */
*, *::before, *::after {
  margin: 0; padding: 0; box-sizing: border-box;
}

:root {
  /* Backgrounds */
  --bg:    #090c12;
  --bg2:   #0e1220;
  --bg3:   #141828;
  --bg4:   #1a2033;
  --bg5:   #202540;

  /* Borders */
  --border:  rgba(255,255,255,0.06);
  --border2: rgba(255,255,255,0.11);
  --border3: rgba(255,255,255,0.18);

  /* Accent */
  --accent:      #1e40af;
  --accent-h:    #2563eb;
  --accent-glow: rgba(30,64,175,0.28);
  --accent-soft: rgba(30,64,175,0.12);

  /* Text */
  --text:  #dde4f0;
  --text2: #7a84a0;
  --text3: #434b66;
  --text4: #2e3550;

  /* Status colors */
  --gold:   #c8991a;
  --red:    #dc2626;
  --green:  #16a34a;
  --orange: #d97706;
  --purple: #7c3aed;

  /* Layout */
  --sidebar-w: 236px;
  --topbar-h:  52px;

  /* Fonts */
  --font: 'DM Sans', sans-serif;
  --mono: 'JetBrains Mono', monospace;
}

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  font-size: 13px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

input, select, button, textarea { font-family: var(--font); }

/* ─── SCROLLBAR ─────────────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.07); border-radius: 2px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.14); }

/* ═══════════════════════════════════════════════════════════
   LOGIN SCREEN
   ═══════════════════════════════════════════════════════════ */
#login-screen {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
  background-image:
    radial-gradient(ellipse 90% 70% at 50% -10%, rgba(30,64,175,0.22), transparent),
    repeating-linear-gradient(0deg,  rgba(255,255,255,0.013) 0px, transparent 1px, transparent 44px),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.013) 0px, transparent 1px, transparent 44px);
}

.login-wrap {
  display: flex;
  align-items: stretch;
  width: 820px;
  max-width: 96vw;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--border2);
  box-shadow: 0 50px 100px rgba(0,0,0,0.65), 0 0 0 1px rgba(255,255,255,0.04) inset;
}

.login-left {
  flex: 1;
  padding: 46px 44px;
  background: var(--bg2);
  display: flex;
  flex-direction: column;
}

.login-right {
  width: 250px;
  background: linear-gradient(160deg, #0c183a 0%, #090c12 100%);
  padding: 46px 28px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border-left: 1px solid var(--border);
}

.login-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(30,64,175,0.14);
  border: 1px solid rgba(30,64,175,0.28);
  border-radius: 6px;
  padding: 5px 12px;
  font-size: 11px;
  color: #60a5fa;
  font-weight: 500;
  margin-bottom: 30px;
  width: fit-content;
}

.login-badge-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #60a5fa;
  animation: pulse 2.2s infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.35; transform: scale(0.85); }
}

.login-title {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.2;
  color: #fff;
  margin-bottom: 6px;
  letter-spacing: -0.02em;
}

.login-sub {
  font-size: 13px;
  color: var(--text2);
  margin-bottom: 38px;
}

.fgroup { margin-bottom: 16px; }

.fgroup label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text2);
  margin-bottom: 6px;
}

.fgroup input, .fgroup select, .fgroup textarea {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--border2);
  border-radius: 8px;
  padding: 10px 14px;
  color: var(--text);
  font-size: 13px;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.fgroup input:focus,
.fgroup select:focus {
  border-color: var(--accent-h);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.fgroup input::placeholder { color: var(--text3); }
.fgroup select option { background: var(--bg3); }

.btn-login {
  width: 100%;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 12px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s, transform 0.1s;
  margin-top: 4px;
  letter-spacing: 0.03em;
}
.btn-login:hover  { background: var(--accent-h); }
.btn-login:active { transform: scale(0.98); }

.login-err {
  color: #f87171;
  font-size: 12px;
  margin-top: 10px;
  display: none;
  padding: 8px 12px;
  background: rgba(239,68,68,0.1);
  border-radius: 6px;
  border: 1px solid rgba(239,68,68,0.2);
}

.login-hint {
  margin-top: auto;
  padding-top: 28px;
  border-top: 1px solid var(--border);
  font-size: 11px;
  color: var(--text3);
  line-height: 1.75;
}

/* Right panel */
.login-right-logo { text-align: center; }

.lr-icon {
  width: 66px; height: 66px;
  margin: 0 auto 14px;
  background: linear-gradient(135deg, var(--accent) 0%, #1d4ed8 100%);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  box-shadow: 0 12px 32px rgba(30,64,175,0.4);
}

.lr-title { font-size: 16px; font-weight: 700; color: #fff; margin-bottom: 4px; }
.lr-sub   { font-size: 11px; color: var(--text3); }

.lr-stats { margin-top: auto; }

.lr-stat {
  padding: 11px 0;
  border-bottom: 1px solid var(--border);
}
.lr-stat:last-child { border: none; }

.lr-stat-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text3);
  margin-bottom: 2px;
}
.lr-stat-val {
  font-size: 22px;
  font-weight: 700;
  color: var(--text);
  font-family: var(--mono);
}

/* ═══════════════════════════════════════════════════════════
   APP SHELL
   ═══════════════════════════════════════════════════════════ */
#app { display: none; min-height: 100vh; }

/* ─── SIDEBAR ───────────────────────────────────────────────── */
.sidebar {
  width: var(--sidebar-w);
  background: var(--bg2);
  border-right: 1px solid var(--border);
  position: fixed;
  top: 0; left: 0;
  height: 100vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  z-index: 100;
}

.sb-head {
  padding: 18px 16px 16px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 10px;
}

.sb-icon {
  width: 34px; height: 34px;
  background: var(--accent);
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(30,64,175,0.4);
}

.sb-brand { font-size: 12px; font-weight: 700; color: var(--text); line-height: 1.3; }
.sb-brand span { display: block; font-size: 10px; color: var(--text3); font-weight: 400; }

.sb-user-bar {
  margin: 12px;
  padding: 10px;
  background: var(--bg3);
  border-radius: 8px;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 8px;
}

.sb-avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}

.sb-uname { font-size: 12px; font-weight: 600; color: var(--text); line-height: 1.3; }
.sb-urole { font-size: 10px; color: var(--text3); }

.sb-logout {
  margin-left: auto;
  background: none;
  border: none;
  color: var(--text3);
  cursor: pointer;
  font-size: 16px;
  padding: 0 2px;
  transition: color 0.15s;
}
.sb-logout:hover { color: #f87171; }

.nav { flex: 1; padding: 8px 0; }

.nav-section-lbl {
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text4);
  padding: 14px 16px 4px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 7px 16px;
  cursor: pointer;
  font-size: 12px;
  color: var(--text2);
  border-left: 2px solid transparent;
  transition: all 0.15s;
  user-select: none;
}
.nav-item:hover { background: rgba(255,255,255,0.025); color: var(--text); }
.nav-item.active {
  background: rgba(30,64,175,0.12);
  color: #60a5fa;
  border-left-color: var(--accent-h);
}

.nav-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }

.nav-count {
  margin-left: auto;
  font-size: 10px;
  background: rgba(255,255,255,0.05);
  padding: 1px 7px;
  border-radius: 8px;
  color: var(--text3);
  font-family: var(--mono);
}

/* ─── TOPBAR ────────────────────────────────────────────────── */
.topbar {
  position: fixed;
  top: 0; left: var(--sidebar-w); right: 0;
  height: var(--topbar-h);
  background: rgba(14,18,32,0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 22px;
  z-index: 99;
}

.tb-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
  letter-spacing: -0.01em;
}

.tb-crumb { color: var(--text3); font-size: 12px; font-weight: 400; }

.tb-actions { display: flex; align-items: center; gap: 8px; }

.tb-search {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 6px 12px;
  font-size: 12px;
  color: var(--text);
  outline: none;
  width: 220px;
  transition: border-color 0.2s;
}
.tb-search:focus { border-color: var(--accent-h); }
.tb-search::placeholder { color: var(--text3); }

.tb-filter {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 6px 10px;
  color: var(--text);
  font-size: 12px;
  outline: none;
  cursor: pointer;
  transition: border-color 0.2s;
}
.tb-filter:focus { border-color: var(--accent-h); }
.tb-filter option { background: var(--bg3); }

/* ─── MAIN ──────────────────────────────────────────────────── */
.main {
  margin-left: var(--sidebar-w);
  margin-top: var(--topbar-h);
  padding: 22px;
  min-width: 0;
}

.page { display: none; }
.page.active { display: block; }

/* ─── STATS ROW ─────────────────────────────────────────────── */
.stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}

.stat-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
  transition: border-color 0.2s;
}
.stat-card:hover { border-color: var(--border2); }

.stat-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text3);
  margin-bottom: 6px;
}
.stat-num { font-size: 28px; font-weight: 700; font-family: var(--mono); line-height: 1; }
.stat-trend { font-size: 11px; color: var(--text3); margin-top: 4px; }

/* ─── PANELS ────────────────────────────────────────────────── */
.log-panel {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 18px 20px;
}
.panel-title {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 14px;
  color: var(--text);
  letter-spacing: -0.01em;
}

/* Dashboard log */
.log-item {
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  font-size: 12px;
  line-height: 1.5;
}
.log-item:last-child { border-bottom: none; }
.log-ts { font-size: 10px; color: var(--text3); white-space: nowrap; font-family: var(--mono); margin-top: 1px; }

/* Spec overview */
.spec-stat-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
}
.spec-stat-item:last-child { border-bottom: none; }
.spec-stat-name { color: var(--text2); }
.spec-stat-count { font-family: var(--mono); font-size: 11px; color: #60a5fa; background: rgba(30,64,175,0.14); padding: 1px 8px; border-radius: 6px; }

/* ─── SECTION HEADER ───────────────────────────────────────── */
.sec-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  padding: 12px 18px;
  background: var(--bg2);
  border-radius: 8px;
  border-left: 3px solid var(--accent);
}

.sec-title {
  font-size: 13px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 10px;
  letter-spacing: -0.01em;
}

.sec-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }

.sec-count {
  font-size: 11px;
  color: var(--text2);
  font-weight: 400;
  background: rgba(255,255,255,0.05);
  padding: 2px 9px;
  border-radius: 8px;
}

.sec-rang-list {
  font-size: 10px;
  color: var(--text3);
  margin-left: 4px;
}

/* ─── BUTTONS ───────────────────────────────────────────────── */
.btn {
  border-radius: 7px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  padding: 7px 16px;
  border: none;
  transition: all 0.15s;
  letter-spacing: 0.01em;
}
.btn-blue { background: var(--accent); color: #fff; }
.btn-blue:hover { background: var(--accent-h); }
.btn-blue:disabled { background: var(--bg4); color: var(--text3); cursor: not-allowed; }
.btn-ghost { background: none; border: 1px solid var(--border2); color: var(--text2); }
.btn-ghost:hover { border-color: var(--accent-h); color: var(--text); }

.btn-sm-blue {
  background: rgba(30,64,175,0.18);
  color: #60a5fa;
  border: none;
  border-radius: 5px;
  padding: 3px 10px;
  font-size: 11px;
  cursor: pointer;
  font-weight: 600;
  transition: background 0.15s;
}
.btn-sm-blue:hover { background: rgba(30,64,175,0.35); }

.btn-sm-red {
  background: rgba(220,38,38,0.14);
  color: #f87171;
  border: none;
  border-radius: 5px;
  padding: 3px 10px;
  font-size: 11px;
  cursor: pointer;
  font-weight: 600;
  transition: background 0.15s;
}
.btn-sm-red:hover { background: rgba(220,38,38,0.3); }

/* ─── TABLE ─────────────────────────────────────────────────── */
.tbl-wrap {
  overflow-x: auto;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 26px;
}

table {
  border-collapse: collapse;
  min-width: 100%;
  width: max-content;
  font-size: 12px;
}

thead th {
  background: var(--bg3);
  color: var(--text2);
  font-weight: 700;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 9px 12px;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
  position: sticky;
  top: 0;
  z-index: 3;
}

thead th.spec-h {
  min-width: 80px;
  text-align: center;
  padding: 9px 6px;
  font-size: 9px;
  letter-spacing: 0.02em;
  background: linear-gradient(180deg, #151922, #0e1220);
}

tbody td {
  padding: 8px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.035);
  color: var(--text);
  white-space: nowrap;
  vertical-align: middle;
}
tbody td.spec-c { text-align: center; padding: 8px 6px; min-width: 80px; }
tbody tr:last-child td { border-bottom: none; }
tbody tr:hover td { background: rgba(255,255,255,0.018); }

/* ── STICKY COLUMNS ──────────────────────────────────────────────────
   col 1 = Rang       220px  left: 0
   col 2 = Dienstnr.  110px  left: 220px
   col 3 = Naam       170px  left: 330px

   KRITIEK: z-index moet HOGER zijn dan niet-sticky cellen (die z-index: 0
   hebben). thead sticky-headers krijgen z-index: 10 zodat ze boven alles
   uitsteken. tbody sticky cellen z-index: 5.
   box-shadow rechts zorgt dat scrollende kolommen er echt achter verdwijnen.
   ──────────────────────────────────────────────────────────────────── */

/* Alle niet-sticky cellen uitdrukkelijk laag houden */
tbody td, thead th { z-index: 0; }

thead th:nth-child(1), thead th:nth-child(2), thead th:nth-child(3) {
  position: sticky;
  z-index: 10;
  background: #141828;
}
tbody td:nth-child(1), tbody td:nth-child(2), tbody td:nth-child(3) {
  position: sticky;
  z-index: 5;
  background: #141828;
}

thead th:nth-child(1), tbody td:nth-child(1) {
  left: 0;
  width: 220px;
  min-width: 220px;
  max-width: 220px;
}
thead th:nth-child(2), tbody td:nth-child(2) {
  left: 220px;
  width: 110px;
  min-width: 110px;
  max-width: 110px;
}
thead th:nth-child(3), tbody td:nth-child(3) {
  left: 330px;
  width: 170px;
  min-width: 170px;
  max-width: 170px;
  /* Schaduw rechts: scrollende kolommen verdwijnen er visueel achter */
  box-shadow: 4px 0 12px 0 rgba(0,0,0,0.55);
}

/* Hover: solid kleur zodat inhoud achter sticky cols onzichtbaar blijft */
tbody tr:hover td:nth-child(1),
tbody tr:hover td:nth-child(2),
tbody tr:hover td:nth-child(3) { background: #161d30; }

/* Subtiele scheidingslijn rechts van naam-kolom */
thead th:nth-child(3),
tbody td:nth-child(3) {
  border-right: 1px solid rgba(255,255,255,0.09);
}

/* Badge in rang-cel mag niet buiten kolom breken */
tbody td:nth-child(1) .badge {
  white-space: normal;
  word-break: break-word;
  display: block;
  width: fit-content;
  max-width: 196px;
}

/* ─── BADGES ────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

/* Rang categories */
.b-kor  { background: rgba(200,153,26,0.16);  color: #f0c040; }
.b-hof  { background: rgba(220,38,38,0.16);   color: #f87171; }
.b-off  { background: rgba(30,64,175,0.22);   color: #60a5fa; }
.b-ooff { background: rgba(124,58,237,0.18);  color: #a78bfa; }
.b-bas  { background: rgba(122,132,160,0.16); color: #9aa3bc; }
.b-stu  { background: rgba(217,119,6,0.16);   color: #fbbf24; }

.b-unit {
  background: rgba(30,64,175,0.14);
  color: #93c5fd;
  font-size: 9px;
  padding: 2px 7px;
  border-radius: 3px;
  font-weight: 700;
  font-family: var(--mono);
}

/* Status */
.status-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
}
.s-actief   { background: rgba(22,163,74,0.15);  color: #4ade80; }
.s-inactief { background: rgba(75,85,99,0.20);   color: #9ca3af; }
.s-verlof   { background: rgba(217,119,6,0.15);  color: #fbbf24; }
.s-geschorst{ background: rgba(220,38,38,0.15);  color: #f87171; }

/* Spec level badges in table */
.spec-level {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 4px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.sl-vrijstelling { background: rgba(75,85,99,0.2);    color: #6b7280; }
.sl-opleiding    { background: rgba(217,119,6,0.15);  color: #fbbf24; }
.sl-volwaardig   { background: rgba(22,163,74,0.14);  color: #4ade80; }
.sl-senior       { background: rgba(30,64,175,0.18);  color: #60a5fa; }
.sl-instructeur  { background: rgba(124,58,237,0.16); color: #a78bfa; }
.sl-astleiding   { background: rgba(200,153,26,0.16); color: #f0c040; }
.sl-leiding      { background: rgba(220,38,38,0.15);  color: #f87171; }

/* ─── MODAL ─────────────────────────────────────────────────── */
.overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.78);
  z-index: 200;
  align-items: center;
  justify-content: center;
  overflow-y: auto;
  padding: 20px;
}
.overlay.open { display: flex; }

.modal {
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: 16px;
  padding: 28px;
  width: 780px;
  max-width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 40px 80px rgba(0,0,0,0.6);
  margin: auto;
}

.modal-hd {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}
.modal-title { font-size: 16px; font-weight: 700; color: var(--text); letter-spacing: -0.01em; }
.modal-x {
  background: none;
  border: none;
  color: var(--text3);
  font-size: 20px;
  cursor: pointer;
  line-height: 1;
  padding: 2px 4px;
  border-radius: 4px;
  transition: all 0.15s;
}
.modal-x:hover { color: var(--text); background: rgba(255,255,255,0.06); }

.modal-section-lbl {
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text3);
  padding: 0 0 8px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 14px;
}

.fgrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 13px;
}
.fgrid .full { grid-column: 1 / -1; }

.modal .fgroup label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text3);
  margin-bottom: 5px;
  display: block;
}

.modal .fgroup input,
.modal .fgroup select {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 8px 12px;
  color: var(--text);
  font-size: 12px;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.modal .fgroup input:focus,
.modal .fgroup select:focus {
  border-color: var(--accent-h);
  box-shadow: 0 0 0 2px var(--accent-glow);
}
.modal .fgroup select option { background: var(--bg3); }

.divider-lbl {
  grid-column: 1 / -1;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text3);
  padding: 8px 0 2px;
  border-top: 1px solid var(--border);
  margin-top: 6px;
}

/* Spec selects grid */
.spec-intro {
  font-size: 11px;
  color: var(--text3);
  margin-bottom: 12px;
}

.spec-selects-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.spec-item {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 9px 12px;
  transition: border-color 0.15s;
}
.spec-item:hover { border-color: var(--border2); }
.spec-item.has-value { border-color: rgba(30,64,175,0.35); background: rgba(30,64,175,0.06); }

.spec-item label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text2);
  margin-bottom: 6px;
}

.spec-item select {
  width: 100%;
  background: var(--bg4);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 5px 8px;
  color: var(--text);
  font-size: 11px;
  outline: none;
  cursor: pointer;
}
.spec-item select:focus { border-color: var(--accent-h); }
.spec-item select option { background: var(--bg3); }

.modal-ft {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 22px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

/* ─── USERS PAGE ────────────────────────────────────────────── */
.users-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
  gap: 14px;
}

.user-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 18px;
  transition: border-color 0.2s;
}
.user-card:hover { border-color: var(--border2); }

.uc-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.uc-avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 700;
  flex-shrink: 0;
}

.uc-name { font-size: 13px; font-weight: 700; color: var(--text); }
.uc-id   { font-size: 10px; color: var(--text3); font-family: var(--mono); margin-top: 2px; }

.uc-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.uc-date { font-size: 10px; color: var(--text3); }

/* Role badges */
.role-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
}
.r-superadmin  { background: rgba(200,153,26,0.2);  color: #f0c040; }
.r-admin       { background: rgba(30,64,175,0.2);   color: #60a5fa; }
.r-korpsleiding{ background: rgba(220,38,38,0.18);  color: #f87171; }
.r-editor      { background: rgba(22,163,74,0.15);  color: #4ade80; }
.r-viewer      { background: rgba(75,85,99,0.2);    color: #9ca3af; }

/* ─── SECTION COLORS ────────────────────────────────────────── */
.sc-kor  { border-left-color: #c8991a !important; }
.sc-hof  { border-left-color: #dc2626 !important; }
.sc-off  { border-left-color: #1e40af !important; }
.sc-ooff { border-left-color: #7c3aed !important; }
.sc-bas  { border-left-color: #4b5563 !important; }
.sc-stu  { border-left-color: #d97706 !important; }

/* ─── EMPTY ROW ─────────────────────────────────────────────── */
.empty-row td {
  text-align: center;
  color: var(--text3);
  padding: 24px;
  font-style: italic;
  font-size: 12px;
}

/* ─── FILTER ROW ────────────────────────────────────────────── */
.filter-row {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
  flex-wrap: wrap;
  align-items: center;
}

.unit-tab {
  padding: 4px 13px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--border);
  color: var(--text2);
  background: none;
  transition: all 0.15s;
}
.unit-tab.active,
.unit-tab:hover {
  background: rgba(30,64,175,0.18);
  border-color: var(--accent);
  color: #60a5fa;
}

/* ─── RANG OFFICIEL INDICATOR ───────────────────────────────── */
.rang-official {
  font-size: 9px;
  color: var(--text3);
  font-family: var(--mono);
  display: block;
  margin-top: 2px;
}
