:root{
  /* Modern SaaS Color Palette - Slate/Zinc with Indigo accent */
  --slate-50:#f8fafc;
  --slate-100:#f1f5f9;
  --slate-200:#e2e8f0;
  --slate-300:#cbd5e1;
  --slate-400:#94a3b8;
  --slate-500:#64748b;
  --slate-600:#475569;
  --slate-700:#334155;
  --slate-800:#1e293b;
  --slate-900:#0f172a;
  
  --indigo-50:#eef2ff;
  --indigo-100:#e0e7ff;
  --indigo-500:#4f46e5;
  --indigo-600:#4338ca;
  --indigo-700:#3730a3;
  
  --green-50:#f0fdf4;
  --green-600:#16a34a;
  --green-700:#15803d;
  
  --red-50:#fef2f2;
  --red-600:#dc2626;
  --red-700:#b91c1c;
  
  --amber-50:#fffbeb;
  --amber-600:#d97706;
  
  /* Politie / Rijkshuisstijl Lintblauw (#154273) */
  --police:#154273;
  --police-hover:#1a5294;
  --police-50:#e3eef7;
  --police-blue:#154273;
  --police-blue-light:#1a5294;
  /* Legacy (nu politieblauw voor overal waar --blue werd gebruikt) */
  --blue:#154273;
  --blue2:#1a5294;
  --blue3:#1e5a9e;
  --bg:#f8fafc;
  --panel:#ffffff;
  --border:#e2e8f0;
  --text:#0f172a;
  --muted:#64748b;
  --danger:#dc2626;
  --warning:#d97706;
  --ok:#16a34a;
  --shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);
  --radius:8px;
  --radius-lg:12px;
  --sidebarW:250px;
  --topH:56px;
  --font: 'Inter', system-ui,-apple-system,Segoe UI,Roboto,'Helvetica Neue',Arial,sans-serif;
  --transition:all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-fast:all 0.15s ease;
}

/* Dark mode */
[data-theme="dark"]{
  --slate-50:#0f172a;
  --slate-100:#1e293b;
  --slate-200:#334155;
  --slate-300:#475569;
  --slate-400:#64748b;
  --slate-500:#94a3b8;
  --slate-600:#cbd5e1;
  --slate-700:#e2e8f0;
  --slate-800:#f1f5f9;
  --slate-900:#f8fafc;
  --indigo-50:#1e1b4b;
  --indigo-100:#312e81;
  --green-50:#052e16;
  --red-50:#450a0a;
  --amber-50:#431407;
  --bg:#0f172a;
  --panel:#1e293b;
  --border:#334155;
  --text:#f1f5f9;
  --muted:#94a3b8;
  --shadow:0 1px 3px 0 rgba(0,0,0,.3),0 1px 2px -1px rgba(0,0,0,.2);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,.3),0 4px 6px -4px rgba(0,0,0,.2);
}

[data-theme="dark"] .sidebar{background:#1e293b;border-color:var(--border)}
[data-theme="dark"] .topbar{background:#1e293b;border-color:var(--border);box-shadow:0 1px 2px rgba(0,0,0,.2)}
[data-theme="dark"] .topbar .input{background:#0f172a;border-color:var(--border)}
[data-theme="dark"] .topbar .input:focus{background:#0f172a;border-color:var(--police);box-shadow:0 0 0 3px rgba(21,66,115,.3)}
[data-theme="dark"] .input{background:#1e293b;border-color:var(--border)}
[data-theme="dark"] .input:focus{border-color:var(--police);box-shadow:0 0 0 3px rgba(21,66,115,.3)}
[data-theme="dark"] .btn{background:#1e293b;border-color:var(--border);color:var(--slate-300)}
[data-theme="dark"] .btn:hover{background:#334155;border-color:var(--slate-400);color:var(--text)}
[data-theme="dark"] .btnGhost{background:transparent;color:var(--slate-400)}
[data-theme="dark"] .btnGhost:hover{background:var(--slate-200);color:var(--text)}
[data-theme="dark"] .nav a{color:var(--slate-400)}
[data-theme="dark"] .nav a:hover{background:var(--slate-200);color:var(--text)}
[data-theme="dark"] .nav a.active{background:rgba(21,66,115,.25);color:#7eb8e8}
[data-theme="dark"] .table th{background:var(--slate-100);color:var(--slate-500)}
[data-theme="dark"] .table tbody tr:hover{background:var(--slate-100)}
[data-theme="dark"] .hr{background:rgba(255,255,255,.08)}
[data-theme="dark"] .notice{background:linear-gradient(90deg,#1e293b 0%,#334155 100%);border-color:var(--police);color:var(--text)}
[data-theme="dark"] .action-card-btn{background:#1e293b;border-color:var(--border)}
[data-theme="dark"] .action-card-btn:hover{background:#334155;border-color:var(--police)}
[data-theme="dark"] .tab-btn{color:var(--slate-500)}
[data-theme="dark"] .tab-btn:hover{color:var(--text);background:var(--slate-100)}
[data-theme="dark"] .tab-btn.active{color:#7eb8e8;border-bottom-color:var(--police)}
[data-theme="dark"] .skeleton{background:linear-gradient(90deg,#1e293b 25%,#334155 50%,#1e293b 75%)}
[data-theme="dark"] .loading{border-color:rgba(21,66,115,.4);border-top-color:var(--police)}

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-size:14px;
  line-height:1.5;
}

@keyframes fadeIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes slideIn{
  from{opacity:0;transform:translateX(-20px)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes pulse{
  0%,100%{opacity:1}
  50%{opacity:.5}
}
@keyframes spin{
  to{transform:rotate(360deg)}
}

.fade-in{animation:fadeIn 0.4s ease-out}
.slide-in{animation:slideIn 0.3s ease-out}

a{color:inherit;text-decoration:none}

.appShell{display:flex;min-height:100vh;animation:fadeIn 0.5s ease-out}
.sidebar{
  width:var(--sidebarW);
  background:#ffffff;
  border-right:1px solid var(--border);
  color:var(--text);
  position:fixed;left:0;top:0;bottom:0;
  display:flex;flex-direction:column;
  z-index:100;
}
.brand{
  height:var(--topH);
  display:flex;align-items:center;gap:12px;
  padding:0 16px;
  border-bottom:1px solid var(--border);
}
.brandLogo{
  width:32px;height:32px;border-radius:8px;
  background:var(--police);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;
  font-size:16px;
  transition:var(--transition);
}
.brandLogo:hover{background:var(--police-hover)}
.brandTitle{font-weight:600;font-size:15px;color:var(--text);letter-spacing:-.01em}
.brandSub{font-size:12px;color:var(--muted);margin-top:2px;font-weight:400}

.nav{padding:8px;overflow:auto}
.nav a{
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;border-radius:var(--radius);
  color:var(--slate-700);
  transition:var(--transition-fast);
  position:relative;
  margin-bottom:4px;
  font-size:14px;
  font-weight:500;
}
.nav a::before{
  content:'';
  position:absolute;
  left:0;top:50%;transform:translateY(-50%);
  width:3px;height:0;
  background:var(--police);
  border-radius:0 2px 2px 0;
  transition:var(--transition-fast);
}
.nav a:hover{
  background:var(--slate-100);
  color:var(--text);
}
.nav a.active{
  background:var(--police-50);
  color:var(--police);
  font-weight:600;
}
.nav a.active::before{height:60%}
.nav .icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;stroke-width:1.5;transition:var(--transition-fast)}

.sidebarFooter{
  margin-top:auto;
  padding:12px 16px;
  border-top:1px solid var(--border);
  font-size:12px;
  color:var(--muted);
}

.main{
  margin-left:var(--sidebarW);
  width:calc(100% - var(--sidebarW));
  min-height:100vh;
}
.topbar{
  height:auto;
  min-height:var(--topH);
  background:#ffffff;
  border-bottom:1px solid var(--border);
  color:var(--text);
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 24px;
  position:sticky;top:0;z-index:50;
  box-shadow:0 1px 2px 0 rgba(0,0,0,.05);
}
.topbar .input{
  background:var(--slate-50);
  border:1px solid var(--border);
  color:var(--text);
  max-width:400px;
}
.topbar .input::placeholder{color:var(--slate-400)}
.topbar .input:focus{
  background:#fff;
  border-color:var(--police);
  box-shadow:0 0 0 3px var(--police-50);
}
.topbarTitle{font-weight:900;letter-spacing:.08em;flex:1}
.content{
  padding:24px;
  max-width:1400px;
  width:100%;
  margin:0 auto;
  animation:fadeIn 0.4s ease-out;
}

/* Full width content for citizen profile */
.citizen-profile-content{
  width:100%;
  max-width:100%;
}

.card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:24px;
  transition:var(--transition);
  animation:fadeIn 0.4s ease-out;
}
.card:hover{box-shadow:var(--shadow-lg)}
.card h3{margin:0;font-size:16px;font-weight:600;color:var(--text);letter-spacing:-.01em}
.card h3{margin:0;font-size:16px}
.hr{height:1px;background:rgba(0,0,0,.08);margin:12px 0}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width: 980px){
  :root{--sidebarW:220px}
  .grid2{grid-template-columns:1fr}
  .content{padding:12px}
}
@media (max-width: 760px){
  .sidebar{position:static;width:100%}
  .main{margin-left:0;width:100%}
  .topbar{position:static}
}

.tiles{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin:20px 0;
}
.tiles > *:nth-child(1){animation-delay:0.1s}
.tiles > *:nth-child(2){animation-delay:0.2s}
.tiles > *:nth-child(3){animation-delay:0.3s}
.tiles > *:nth-child(4){animation-delay:0.4s}
@media (max-width: 1100px){ .tiles{grid-template-columns:repeat(2,1fr)} }
@media (max-width: 520px){ .tiles{grid-template-columns:1fr} }

.tile{
  background:linear-gradient(135deg,var(--police-blue) 0%,var(--police-blue-light) 100%);
  color:#fff;
  border-radius:var(--radius-lg);
  padding:20px 18px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;
  min-height:120px;
  cursor:pointer;
  border:none;
  position:relative;
  overflow:hidden;
  transition:var(--transition);
  animation:fadeIn 0.5s ease-out backwards;
}
.tile::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 100%);
  opacity:0;
  transition:var(--transition);
}
.tile:hover{
  transform:translateY(-4px) scale(1.02);
  box-shadow:0 8px 24px rgba(21,66,115,.4);
}
.tile:hover::before{opacity:1}
.tile .bigIcon{
  width:40px;height:40px;
  opacity:.95;
  transition:var(--transition);
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));
}
.tile:hover .bigIcon{transform:scale(1.1) rotate(5deg)}
.tile .label{font-weight:800;font-size:15px;letter-spacing:.02em}

.h1{font-size:40px;margin:14px 0 4px}
.h2{font-size:18px;color:var(--muted);margin:0 0 10px}

.notice{
  font-size:13px;color:#1d2a3a;
  padding:14px 16px;
  border-left:4px solid var(--blue);
  background:linear-gradient(90deg,#e8f0fb 0%,#f0f5fa 100%);
  border-radius:var(--radius);
  line-height:1.6;
  box-shadow:0 2px 8px rgba(11,79,134,.08);
}

.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.input{
  border:1px solid var(--border);
  background:#fff;
  border-radius:var(--radius);
  padding:10px 12px;
  font-size:14px;
  color:var(--text);
  outline:none;
  transition:var(--transition);
  width:100%;
  font-family:inherit;
  line-height:1.5;
}
.input::placeholder{color:var(--slate-400)}
.input:hover{border-color:var(--slate-300)}
.input:focus{
  border-color:var(--police);
  box-shadow:0 0 0 3px var(--police-50);
  outline:none;
}
.input:disabled{background:var(--slate-50);cursor:not-allowed;opacity:.6;color:var(--slate-500)}
textarea.input{
  resize:vertical;
  min-height:100px;
  font-family:inherit;
}
.btn{
  border:1px solid var(--border);
  background:#fff;
  color:var(--slate-700);
  padding:8px 16px;
  border-radius:var(--radius);
  cursor:pointer;
  font-weight:500;
  transition:var(--transition);
  font-size:14px;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  line-height:1.5;
}
.btn:hover{
  background:var(--slate-50);
  border-color:var(--slate-300);
  color:var(--text);
}
.btn:active{transform:scale(0.98)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;pointer-events:none}
.btnPrimary{
  background:var(--police);
  border-color:var(--police);
  color:#fff;
  box-shadow:0 1px 2px 0 rgba(0,0,0,.05);
}
.btnPrimary:hover{
  background:var(--police-hover);
  border-color:var(--police-hover);
  box-shadow:0 1px 3px 0 rgba(0,0,0,.1);
  transform:none;
}
.btnDanger{
  background:var(--red-600);
  border-color:var(--red-600);
  color:#fff;
}
.btnDanger:hover{
  background:var(--red-700);
  border-color:var(--red-700);
}
.btnGhost{
  background:transparent;
  border-color:var(--border);
  color:var(--slate-600);
}
.btnGhost:hover{
  background:var(--slate-50);
  border-color:var(--slate-300);
}

.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:var(--panel);
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--border);
}
.table th,.table td{
  padding:12px 16px;
  border-bottom:1px solid var(--border);
  text-align:left;
  font-size:14px;
  transition:var(--transition-fast);
}
.table th{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:var(--slate-600);
  font-weight:600;
  background:var(--slate-50);
  position:sticky;top:0;z-index:1;
}
.table tbody tr{
  transition:var(--transition-fast);
}
.table tbody tr:hover{
  background:var(--slate-50);
}
.table tbody tr:last-child td{border-bottom:none}
.badge{
  display:inline-flex;align-items:center;justify-content:center;
  padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500;
  background:var(--slate-100);color:var(--slate-700);
  transition:var(--transition-fast);
  border:none;
  line-height:1.2;
}
.badge.red{
  background:var(--red-50);
  color:var(--red-700);
}
.badge.ok{
  background:var(--green-50);
  color:var(--green-700);
}
.badge.warning{
  background:var(--amber-50);
  color:var(--amber-600);
}
.badge.indigo{
  background:var(--indigo-50);
  color:var(--indigo-700);
}
.badge.wok-badge{
  background:#fff7ed;
  color:#c2410c;
  font-weight:700;
}
[data-theme="dark"] .badge.wok-badge{
  background:rgba(194,65,12,.25);
  color:#fdba74;
}

/* WOK-status (Wachten Op Keuren) */
.wok-banner{
  background:linear-gradient(135deg,#ea580c 0%,#c2410c 100%);
  color:#fff;
  padding:16px 20px;
  border-radius:var(--radius);
  margin-bottom:16px;
  box-shadow:0 2px 8px rgba(234,88,12,.35);
}
.wok-banner-text{
  font-size:18px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.wok-infotip{
  font-size:13px;
  margin-top:8px;
  opacity:.95;
}
.wok-action-block{margin-bottom:8px}
.wok-btn-set{
  background:#ea580c;
  border-color:#ea580c;
  color:#fff;
  font-weight:600;
}
.wok-btn-set:hover{
  background:#c2410c;
  border-color:#c2410c;
  color:#fff;
}
.wok-btn-clear{
  background:transparent;
  border:1px solid var(--border);
  color:var(--text);
}
.wok-btn-clear:hover{
  background:var(--slate-50);
  border-color:var(--slate-300);
}
.muted{color:var(--muted)}

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

.wrap{max-width:600px;margin:40px auto;padding:0 18px}
.logo{font-weight:800;font-size:20px;letter-spacing:.05em}

/* ========== Login page ========== */
.login-page{
  min-height:100vh;
  display:flex;
  flex-wrap:wrap;
  background:var(--bg);
}
.login-brand{
  flex:1;
  min-width:320px;
  min-height:40vh;
  background:linear-gradient(145deg, var(--police) 0%, var(--police-hover) 50%, #0f3460 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:48px;
  position:relative;
  overflow:hidden;
}
.login-brand::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  background:repeating-linear-gradient(
    -35deg,
    transparent,
    transparent 40px,
    rgba(255,255,255,.03) 40px,
    rgba(255,255,255,.03) 41px
  );
  pointer-events:none;
}
.login-brand-inner{
  position:relative;
  z-index:1;
  text-align:center;
  max-width:380px;
}
.login-logo{
  font-size:56px;
  font-weight:800;
  letter-spacing:-.02em;
  color:#fff;
  margin-bottom:12px;
  line-height:1.1;
  text-shadow:0 2px 12px rgba(0,0,0,.2);
}
.login-logo-letter{
  color:#fff;
  display:inline-block;
  padding:4px 12px;
  background:rgba(255,255,255,.18);
  border-radius:10px;
  margin-right:2px;
}
.login-logo-rest{letter-spacing:.12em;opacity:.95}
.login-tagline{
  font-size:13px;
  color:rgba(255,255,255,.85);
  letter-spacing:.04em;
  text-transform:uppercase;
  margin-bottom:8px;
  font-weight:500;
}
.login-org{
  font-size:22px;
  font-weight:700;
  color:#fff;
  letter-spacing:.02em;
  margin-bottom:24px;
}
.login-divider{
  width:60px;
  height:3px;
  background:rgba(255,255,255,.5);
  border-radius:2px;
  margin:0 auto 20px;
}
.login-meta{
  font-size:13px;
  color:rgba(255,255,255,.75);
}
.login-datetime{font-weight:500}

.login-form-panel{
  flex:1;
  min-width:300px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:40px 24px;
}
.login-card{
  width:100%;
  max-width:400px;
  background:var(--panel);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  border:1px solid var(--border);
  padding:40px 36px;
  animation:fadeIn 0.5s ease-out;
}
.login-title{
  font-size:28px;
  font-weight:700;
  color:var(--text);
  margin:0 0 8px;
  letter-spacing:-.02em;
}
.login-subtitle{
  font-size:14px;
  color:var(--muted);
  margin:0 0 28px;
  line-height:1.5;
}
.login-fields{
  display:flex;
  flex-direction:column;
  gap:18px;
}
.login-label{
  font-size:13px;
  font-weight:600;
  color:var(--text);
  margin:0;
}
.login-input{
  padding:12px 14px;
  font-size:15px;
  width:100%;
}
.login-err{
  font-size:13px;
  color:var(--danger);
  margin:-4px 0 0;
  min-height:20px;
}
.login-btn{
  width:100%;
  padding:14px 20px;
  font-size:16px;
  font-weight:600;
  margin-top:8px;
  letter-spacing:.02em;
}

[data-theme="dark"] .login-brand{
  background:linear-gradient(145deg, #154273 0%, #1a5294 50%, #0f3460 100%);
}
[data-theme="dark"] .login-card{
  background:var(--panel);
  border-color:var(--border);
  box-shadow:0 25px 50px -12px rgba(0,0,0,.4);
}

@media (max-width: 720px){
  .login-brand{min-height:28vh;padding:32px 24px}
  .login-logo{font-size:42px}
  .login-org{font-size:18px}
  .login-form-panel{padding:32px 20px}
  .login-card{padding:28px 24px}
}

.pre{white-space:pre-wrap;word-break:break-word}
.small{font-size:12px}

/* Loading States */
.loading{
  display:inline-block;
  width:20px;height:20px;
  border:3px solid rgba(11,79,134,.2);
  border-top-color:var(--blue);
  border-radius:50%;
  animation:spin 0.8s linear infinite;
}
.loading-lg{
  width:40px;height:40px;
  border-width:4px;
}

.skeleton{
  background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);
  background-size:200% 100%;
  animation:loading 1.5s ease-in-out infinite;
  border-radius:var(--radius);
}
@keyframes loading{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
.skeleton-text{height:16px;margin:8px 0}
.skeleton-title{height:24px;width:60%;margin:12px 0}
.skeleton-avatar{width:48px;height:48px;border-radius:50%}

/* Toast Notifications */
.toast-container{
  position:fixed;
  top:20px;right:20px;
  z-index:10000;
  display:flex;flex-direction:column;gap:12px;
  pointer-events:none;
}
.toast{
  background:var(--panel);
  border-left:4px solid var(--blue);
  border-radius:var(--radius);
  padding:14px 18px;
  box-shadow:var(--shadow-lg);
  min-width:300px;
  max-width:400px;
  pointer-events:auto;
  animation:slideIn 0.3s ease-out;
  display:flex;align-items:center;gap:12px;
  transition:var(--transition);
}
.toast:hover{transform:translateX(-4px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.toast.success{border-left-color:var(--ok)}
.toast.error{border-left-color:var(--danger)}
.toast.warning{border-left-color:var(--warning)}
.toast-icon{
  width:24px;height:24px;
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  background:rgba(11,79,134,.1);
  color:var(--blue);
}
.toast.success .toast-icon{background:rgba(46,125,50,.1);color:var(--ok)}
.toast.error .toast-icon{background:rgba(198,40,40,.1);color:var(--danger)}
.toast.warning .toast-icon{background:rgba(245,124,0,.1);color:var(--warning)}
.toast-content{flex:1}
.toast-title{font-weight:700;font-size:14px;margin-bottom:2px}
.toast-message{font-size:13px;color:var(--muted)}

/* Alert Styles */
.alert{
  padding:14px 18px;
  border-radius:var(--radius);
  border-left:4px solid;
  margin:12px 0;
  display:flex;align-items:flex-start;gap:12px;
  animation:fadeIn 0.3s ease-out;
}
.alert-danger{
  background:rgba(198,40,40,.08);
  border-left-color:var(--danger);
  color:#b71c1c;
}
.alert-success{
  background:rgba(46,125,50,.08);
  border-left-color:var(--ok);
  color:#1b5e20;
}
.alert-warning{
  background:rgba(245,124,0,.08);
  border-left-color:var(--warning);
  color:#e65100;
}
.alert-info{
  background:rgba(11,79,134,.08);
  border-left-color:var(--blue);
  color:var(--blue);
}

/* Empty States */
.empty-state{
  text-align:center;
  padding:40px 20px;
  color:var(--muted);
}
.empty-state-icon{
  font-size:48px;
  opacity:.3;
  margin-bottom:12px;
}
.empty-state-title{
  font-weight:700;
  font-size:16px;
  margin-bottom:6px;
  color:var(--text);
}
.empty-state-text{
  font-size:14px;
}

/* Action sections styling */
.action-section{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:16px;
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius);
  margin-bottom:16px;
}
.action-section-title{
  font-weight:600;
  font-size:14px;
  color:var(--text);
  margin-bottom:8px;
}

.action-card-btn{
  padding:16px;
  border:1px solid var(--border);
  background:#fff;
  border-radius:var(--radius);
  cursor:pointer;
  transition:var(--transition);
  text-align:left;
  width:100%;
}
.action-card-btn:hover{
  border-color:var(--police);
  background:var(--police-50);
  box-shadow:var(--shadow);
}
.action-card-btn:active{transform:scale(0.98)}

.tab-btn{
  padding:10px 16px;
  border:none;
  background:transparent;
  color:var(--slate-600);
  font-size:14px;
  font-weight:500;
  cursor:pointer;
  border-bottom:2px solid transparent;
  margin-bottom:-1px;
  transition:var(--transition-fast);
  position:relative;
}
.tab-btn:hover{
  color:var(--text);
  background:var(--slate-50);
}
.tab-btn.active{
  color:var(--police);
  font-weight:600;
  border-bottom-color:var(--police);
}

/* Smooth Scroll */
html{scroll-behavior:smooth}

/* Focus Visible */
*:focus-visible{
  outline:2px solid var(--blue);
  outline-offset:2px;
}

/* ========== GMS — Minimal professional ========== */
.gms-page{
  display:flex;
  flex-direction:column;
  min-height:70vh;
  margin:0 -24px -24px -24px;
  background:#0d1117;
  font-size:13px;
}
.gms-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 20px;
  background:#161b22;
  border-bottom:1px solid #30363d;
  color:#c9d1d9;
}
.gms-header-title{
  font-weight:600;
  font-size:14px;
  color:#e6edf3;
}
.gms-header-right{display:flex;gap:16px;align-items:center}
.gms-reset-btn{
  background:transparent;
  border:none;
  color:#8b949e;
  font-size:13px;
  cursor:pointer;
  padding:4px 0;
}
.gms-reset-btn:hover{color:#c9d1d9}
.gms-body{
  display:grid;
  grid-template-columns:280px 1fr 260px;
  flex:1;
  min-height:0;
  border-bottom:1px solid #30363d;
}
@media (max-width: 1100px){ .gms-body{grid-template-columns:240px 1fr 220px} }
@media (max-width: 900px){ .gms-body{grid-template-columns:1fr} }

.gms-left{
  background:#161b22;
  border-right:1px solid #30363d;
  display:flex;
  flex-direction:column;
  min-height:0;
  overflow:hidden;
}
.gms-panel-header{
  font-weight:600;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.04em;
  padding:12px 16px;
  color:#8b949e;
  border-bottom:1px solid #30363d;
}
.gms-tabs{
  display:flex;
  padding:0 16px;
  gap:0;
  border-bottom:1px solid #30363d;
}
.gms-tab{
  padding:10px 12px;
  font-size:13px;
  background:transparent;
  border:none;
  color:#8b949e;
  cursor:pointer;
  margin-bottom:-1px;
  border-bottom:1px solid transparent;
}
.gms-tab-sep{display:none}
.gms-tab:hover{color:#c9d1d9}
.gms-tab.active{
  color:#e6edf3;
  border-bottom-color:#58a6ff;
}
.gms-meldingen-list{
  overflow-y:auto;
  flex:1;
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:1px;
}
.gms-melding-row{
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  gap:12px;
  align-items:center;
  padding:10px 12px;
  background:transparent;
  color:#c9d1d9;
  cursor:pointer;
  font-size:13px;
  border-radius:4px;
}
.gms-melding-row:hover{background:#21262d}
.gms-melding-row.urgent{
  background:rgba(248,81,73,.08);
  border-left:2px solid #f85149;
}
.gms-melding-row.issued{
  background:rgba(63,185,80,.06);
  border-left:2px solid #3fb950;
}
.gms-melding-row.selected{background:#21262d;border-left:2px solid #58a6ff;margin-left:-2px;padding-left:14px}
.gms-melding-id{font-family:ui-monospace,monospace;font-size:11px;color:#8b949e}
.gms-melding-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gms-melding-codes{font-size:11px;color:#8b949e}
.gms-melding-send{width:8px}
.gms-empty{padding:24px 16px;font-size:13px;color:#8b949e;text-align:center}

.gms-center{
  display:flex;
  flex-direction:column;
  background:#0d1117;
  min-height:0;
  overflow:hidden;
}
.gms-map-header{
  padding:10px 16px;
  font-size:12px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:#8b949e;
  border-bottom:1px solid #30363d;
}
.gms-map-wrap{
  flex:0 0 200px;
  min-height:180px;
  background:#161b22;
  border-bottom:1px solid #30363d;
}
.gms-map-placeholder{
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#484f58;
  font-size:12px;
}
.gms-map-label{font-weight:500}
.gms-detail-wrap{
  flex:1;
  display:flex;
  flex-direction:column;
  min-height:0;
  overflow:hidden;
}
.gms-orange-bar{
  padding:12px 16px;
  background:#21262d;
  color:#e6edf3;
  font-weight:500;
  font-size:13px;
  border-bottom:1px solid #30363d;
}
.gms-orange-bar.gms-no-selection{color:#8b949e}
.gms-unit-pills-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:10px 16px;
  border-bottom:1px solid #30363d;
}
.gms-detail-pill{
  padding:4px 10px;
  font-size:12px;
  font-weight:500;
  border-radius:4px;
  background:#21262d;
  color:#c9d1d9;
  border:1px solid #30363d;
}
.gms-detail-pill.ar{border-color:#9e6a03;color:#d4a72c}
.gms-detail-pill.tp{border-color:#1f6feb;color:#58a6ff}
.gms-detail-actions{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  padding:12px 16px;
  border-bottom:1px solid #30363d;
}
.gms-select{
  padding:6px 10px;
  font-size:13px;
  background:#21262d;
  border:1px solid #30363d;
  color:#c9d1d9;
  border-radius:4px;
  min-width:120px;
}
.gms-select:focus{outline:none;border-color:#58a6ff}
.gms-btn-afhandelen{
  padding:6px 12px;
  font-size:13px;
  background:#238636;
  border:1px solid #2ea043;
  color:#fff;
  border-radius:4px;
  cursor:pointer;
}
.gms-btn-afhandelen:hover{background:#2ea043}
.gms-btn-annuleren{
  padding:6px 12px;
  font-size:13px;
  background:transparent;
  border:1px solid #30363d;
  color:#8b949e;
  border-radius:4px;
  cursor:pointer;
}
.gms-btn-annuleren:hover{background:#21262d;color:#c9d1d9;border-color:#484f58}
.gms-log-wrap{
  flex:1;
  min-height:100px;
  background:#161b22;
  padding:12px 16px;
  overflow-y:auto;
  border-bottom:1px solid #30363d;
}
.gms-log-inner{color:#c9d1d9;font-size:13px}
.gms-log-line{
  font-family:ui-monospace,monospace;
  font-size:12px;
  color:#8b949e;
  margin-bottom:6px;
  line-height:1.5;
}
.gms-chat-row{
  display:flex;
  gap:0;
  padding:12px 16px;
  background:#161b22;
  border-top:1px solid #30363d;
}
.gms-chat-input{
  flex:1;
  padding:8px 12px;
  font-size:13px;
  background:#0d1117;
  border:1px solid #30363d;
  color:#c9d1d9;
  border-radius:4px 0 0 4px;
  outline:none;
}
.gms-chat-input:focus{border-color:#58a6ff}
.gms-chat-input::placeholder{color:#484f58}
.gms-send-btn{
  padding:8px 16px;
  font-size:13px;
  font-weight:500;
  background:#21262d;
  border:1px solid #30363d;
  color:#c9d1d9;
  border-radius:0 4px 4px 0;
  cursor:pointer;
}
.gms-send-btn:hover{background:#30363d;border-color:#484f58;color:#e6edf3}

.gms-right{
  background:#161b22;
  border-left:1px solid #30363d;
  padding:0;
  overflow-y:auto;
}
.gms-right .gms-panel-header:not(:first-child){margin-top:0;border-top:1px solid #21262d}
.gms-units-list{padding:8px 16px;max-height:180px;overflow-y:auto}
.gms-unit-row{
  padding:8px 0;
  font-size:13px;
  color:#c9d1d9;
  border-bottom:1px solid #21262d;
}
.gms-unit-row:last-child{border-bottom:none}
.gms-unit-callsign{font-variant-numeric:tabular-nums;font-weight:500}
.gms-verzoeken-list{padding:8px 16px}
.gms-verzoek-row{
  padding:8px 0;
  font-size:12px;
  color:#8b949e;
  border-bottom:1px solid #21262d;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.gms-verzoek-row.green{color:#3fb950}
.gms-verzoek-row.orange{color:#d29922}
.gms-berichten-box{
  min-height:48px;
  margin:0 16px 16px;
  background:#0d1117;
  border:1px solid #30363d;
  border-radius:4px;
}
.gms-instellingen-box{
  padding:12px 16px;
  font-size:12px;
  color:#8b949e;
  margin:0 16px 16px;
  border:1px solid #30363d;
  border-radius:4px;
  background:#0d1117;
}
.gms-footer{
  padding:10px 20px;
  font-size:12px;
  color:#8b949e;
  background:#161b22;
  border-top:1px solid #30363d;
}
.gms-error{padding:12px 16px;color:#f85149;font-size:13px}

.gms-modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.7);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:10000;
  padding:24px;
  animation:fadeIn 0.2s ease-out;
}
.gms-modal-panel{
  background:#161b22;
  border-radius:6px;
  box-shadow:0 8px 24px rgba(0,0,0,.5);
  max-width:420px;
  width:100%;
  border:1px solid #30363d;
}
.gms-modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 20px;
  border-bottom:1px solid #30363d;
}
.gms-modal-head h2{color:#e6edf3;font-size:15px;font-weight:600;margin:0}
.gms-modal-close{
  width:28px;
  height:28px;
  border:none;
  background:#21262d;
  color:#8b949e;
  font-size:18px;
  line-height:1;
  border-radius:4px;
  cursor:pointer;
}
.gms-modal-close:hover{background:#30363d;color:#c9d1d9}
.gms-modal-body{padding:20px;display:flex;flex-direction:column;gap:12px}
.gms-modal-body .input{background:#0d1117;border-color:#30363d;color:#c9d1d9}
.gms-modal-body .input::placeholder{color:#484f58}
.gms-btn-primary{
  background:#238636 !important;
  border:1px solid #2ea043 !important;
  color:#fff !important;
  padding:10px 16px;
  font-weight:500;
}
.gms-btn-primary:hover:not(:disabled){
  background:#2ea043 !important;
  border-color:#2ea043 !important;
  color:#fff !important;
}
.btn-sm{padding:6px 12px;font-size:13px}

/* ========== Progress Bar ========== */
#meos-progress{
  position:fixed;top:0;left:0;right:0;height:3px;z-index:100000;
  background:transparent;pointer-events:none;
}
#meos-progress.active{
  display:block !important;
  background:linear-gradient(90deg,var(--police) 0%,#58a6ff 50%,var(--police) 100%);
  background-size:200% 100%;
  animation:progressSlide 1.5s ease-in-out infinite;
}
@keyframes progressSlide{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}

/* ========== Custom Scrollbar ========== */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--slate-300);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--slate-400)}
[data-theme="dark"] ::-webkit-scrollbar-thumb{background:var(--slate-600)}
[data-theme="dark"] ::-webkit-scrollbar-thumb:hover{background:var(--slate-500)}

/* ========== Mobile Hamburger ========== */
.hamburger{
  display:none;
  background:none;border:none;
  color:var(--text);cursor:pointer;
  padding:8px;border-radius:var(--radius);
  transition:var(--transition-fast);
}
.hamburger:hover{background:var(--slate-100)}
.hamburger svg{width:24px;height:24px;display:block}
.sidebar-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.5);z-index:99;
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
  animation:fadeIn 0.2s ease-out;
}
@media (max-width: 760px){
  .hamburger{display:block}
  .sidebar{
    transform:translateX(-100%);
    transition:transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    z-index:200;
    box-shadow:none;
  }
  .sidebar.open{
    transform:translateX(0);
    box-shadow:4px 0 24px rgba(0,0,0,.2);
  }
  .sidebar-overlay.open{display:block}
  .main{margin-left:0;width:100%}
  .topbar{position:sticky}
}

/* ========== Confirm Dialog ========== */
.confirm-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  z-index:100000;padding:24px;
  animation:fadeIn 0.15s ease-out;
}
.confirm-panel{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  box-shadow:0 25px 50px -12px rgba(0,0,0,.25);
  max-width:420px;width:100%;
  padding:28px;
  animation:fadeIn 0.2s ease-out;
}
.confirm-title{
  font-size:18px;font-weight:700;
  color:var(--text);margin:0 0 8px;
}
.confirm-message{
  font-size:14px;color:var(--muted);
  line-height:1.6;margin:0 0 24px;
}
.confirm-actions{
  display:flex;gap:12px;justify-content:flex-end;
}

/* ========== Modal Backdrop Blur ========== */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  z-index:10000;padding:24px;
  animation:fadeIn 0.2s ease-out;
}
.modal-panel{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  box-shadow:0 25px 50px -12px rgba(0,0,0,.25);
  max-width:800px;width:100%;
  max-height:90vh;overflow:auto;
  position:relative;padding:24px;
  animation:modalSlideUp 0.25s ease-out;
}
@keyframes modalSlideUp{
  from{opacity:0;transform:translateY(20px) scale(0.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.modal-close{
  position:absolute;top:12px;right:12px;
  width:32px;height:32px;
  border:1px solid var(--border);
  background:var(--panel);
  color:var(--muted);
  font-size:18px;line-height:1;
  border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:var(--transition-fast);
}
.modal-close:hover{
  background:var(--red-50);
  border-color:var(--red-600);
  color:var(--red-600);
}

/* ========== Improved Table Styles ========== */
.table tbody tr:nth-child(even){
  background:rgba(0,0,0,.015);
}
[data-theme="dark"] .table tbody tr:nth-child(even){
  background:rgba(255,255,255,.02);
}
.table td{vertical-align:middle}

/* ========== Badge Pulse for Active Alerts ========== */
.badge.red{position:relative}
@keyframes badgePulse{
  0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.4)}
  50%{box-shadow:0 0 0 6px rgba(220,38,38,0)}
}
.badge-pulse{animation:badgePulse 2s ease-in-out infinite}

/* ========== Sidebar Nav Badge Counter ========== */
.nav-badge{
  margin-left:auto;
  background:var(--red-600);
  color:#fff;
  font-size:11px;
  font-weight:700;
  min-width:20px;
  height:20px;
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  padding:0 6px;
  line-height:1;
  animation:fadeIn 0.3s ease-out;
}

/* ========== Keyboard Shortcut Hint ========== */
.kbd{
  display:inline-flex;align-items:center;justify-content:center;
  padding:2px 6px;
  background:var(--slate-100);
  border:1px solid var(--border);
  border-radius:4px;
  font-size:11px;
  font-family:ui-monospace,monospace;
  color:var(--muted);
  line-height:1.4;
}
[data-theme="dark"] .kbd{background:var(--slate-200);border-color:var(--slate-300)}

/* ========== Search Palette (Ctrl+K) ========== */
.search-palette-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  display:flex;align-items:flex-start;justify-content:center;
  padding-top:min(20vh,160px);
  z-index:100001;
  animation:fadeIn 0.1s ease-out;
}
.search-palette{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  box-shadow:0 25px 50px -12px rgba(0,0,0,.25);
  max-width:560px;width:100%;
  overflow:hidden;
  animation:modalSlideUp 0.15s ease-out;
}
.search-palette-input{
  width:100%;
  padding:16px 20px;
  font-size:16px;
  border:none;
  border-bottom:1px solid var(--border);
  background:transparent;
  color:var(--text);
  outline:none;
  font-family:inherit;
}
.search-palette-input::placeholder{color:var(--slate-400)}
.search-palette-results{
  max-height:320px;overflow-y:auto;
  padding:8px;
}
.search-palette-item{
  padding:10px 12px;
  border-radius:var(--radius);
  cursor:pointer;
  display:flex;align-items:center;gap:12px;
  color:var(--text);
  font-size:14px;
  transition:var(--transition-fast);
}
.search-palette-item:hover,.search-palette-item.active{
  background:var(--police-50);
  color:var(--police);
}
.search-palette-item .icon{
  width:20px;height:20px;
  opacity:.6;
  display:flex;align-items:center;justify-content:center;
}
.search-palette-hint{
  padding:10px 16px;
  border-top:1px solid var(--border);
  font-size:12px;
  color:var(--muted);
  display:flex;align-items:center;gap:12px;
}

/* ========== Toast Improvements ========== */
@keyframes toastSlideIn{
  from{opacity:0;transform:translateX(100%)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes toastSlideOut{
  from{opacity:1;transform:translateX(0)}
  to{opacity:0;transform:translateX(100%)}
}
.toast{animation:toastSlideIn 0.3s ease-out}
.toast.removing{animation:toastSlideOut 0.3s ease-out forwards}

/* ========== Print Styles ========== */
@media print{
  body{background:#fff !important;color:#000 !important;font-size:12pt}
  .sidebar,.topbar,.hamburger,.toast-container,.btn,.modal-close,
  .nav,.sidebarFooter,#meos-progress{display:none !important}
  .main{margin-left:0 !important;width:100% !important}
  .content{padding:0 !important;max-width:100% !important}
  .card{box-shadow:none !important;border:1px solid #ddd !important;break-inside:avoid}
  .table{font-size:11pt}
  .table th{background:#f0f0f0 !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  a{text-decoration:none !important}
  .badge{border:1px solid #999 !important;background:#f0f0f0 !important;color:#333 !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .print-only{display:block !important}
}
.print-only{display:none}
.print-header{
  text-align:center;margin-bottom:24px;
  padding-bottom:16px;
  border-bottom:2px solid #000;
}
.print-header h1{font-size:20pt;margin:0 0 4px}
.print-header p{font-size:10pt;margin:0;color:#666}

/* ========== Improved Card Hover ========== */
.card{will-change:box-shadow}

/* ========== Status Indicator Dot ========== */
.status-dot{
  width:8px;height:8px;
  border-radius:50%;
  display:inline-block;
  flex-shrink:0;
}
.status-dot.online{background:#16a34a;box-shadow:0 0 0 3px rgba(22,163,74,.2)}
.status-dot.offline{background:var(--slate-400)}
.status-dot.busy{background:var(--amber-600);box-shadow:0 0 0 3px rgba(217,119,6,.2)}

/* ========== Breadcrumb ========== */
.breadcrumb{
  display:flex;align-items:center;gap:6px;
  font-size:13px;color:var(--muted);
  margin-bottom:16px;
}
.breadcrumb a{
  color:var(--police);
  cursor:pointer;
  transition:var(--transition-fast);
}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb-sep{opacity:.4}

/* ========== Quick Stats Cards ========== */
.stat-card{
  padding:20px;
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius);
  text-align:center;
  transition:var(--transition);
}
.stat-card:hover{
  border-color:var(--police);
  box-shadow:0 4px 12px rgba(21,66,115,.1);
}
.stat-value{
  font-size:32px;font-weight:700;
  color:var(--police);
  line-height:1.2;
  margin-bottom:4px;
}
.stat-label{
  font-size:13px;color:var(--muted);
  font-weight:500;
}

/* ========== Topbar Quick Search Kbd Hint ========== */
.topbar .input-with-kbd{position:relative;display:flex;align-items:center}
.topbar .input-with-kbd .input{padding-right:60px}
.topbar .input-with-kbd .kbd-hint{
  position:absolute;right:10px;
  pointer-events:none;
  display:flex;gap:4px;
}

/* ========== Better Select Styling ========== */
select.input{
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  padding-right:36px;
  cursor:pointer;
}

/* ========== Tooltip ========== */
[data-tooltip]{position:relative}
[data-tooltip]:hover::after{
  content:attr(data-tooltip);
  position:absolute;bottom:calc(100% + 6px);left:50%;
  transform:translateX(-50%);
  background:var(--slate-900);color:#fff;
  padding:4px 10px;border-radius:6px;
  font-size:12px;white-space:nowrap;
  z-index:10001;
  animation:fadeIn 0.15s ease-out;
  pointer-events:none;
}
[data-theme="dark"] [data-tooltip]:hover::after{
  background:var(--slate-100);color:var(--text);
}
