:root{--politie:#1f3fa9; --brandweer:#c1172c; --ambulance:#0a7b3e; --eod:#ce6a00; --bg:#f8fafc; --primary:#2b44d6; --muted:#6b7280}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);font-family:system-ui,Roboto,Inter,sans-serif;max-width:100%;overflow-x:hidden}
a{color:var(--primary);text-decoration:none}
.topbar{display:flex;align-items:center;gap:12px;background:#fff;border-bottom:3px solid var(--politie);padding:10px 16px;position:sticky;top:0;z-index:20}
.brand{font-weight:700}.badge{display:inline-grid;place-items:center;background:#111;color:#fff;border-radius:8px;padding:2px 6px;margin-right:6px}
.auth-card{background:#fff;border-radius:14px;box-shadow:0 14px 40px rgba(0,0,0,.06);width:min(880px,100% - 32px);margin:16px auto;padding:16px 16px 22px}
.form-row{display:grid;grid-template-columns:140px 1fr;gap:12px;margin:10px 0}
.form-row input,.form-row select{border:1px solid #e5e7eb;border-radius:10px;padding:12px 12px;font:inherit;background:#fff}
.actions{display:flex;align-items:center;gap:10px;margin-top:10px}
button{border:0;border-radius:10px;padding:10px 14px;font-weight:600;cursor:pointer}
.primary{background:var(--primary);color:#fff}.ghost{background:#eef2ff}.danger{background:#ef4444;color:#fff}.muted{color:var(--muted)}
.userchips .chip,.chip{display:inline-flex;align-items:center;gap:6px;background:#eef2ff;border:1px solid #c7d2fe;color:#1d4ed8;border-radius:999px;padding:6px 10px;font-size:12px}
.userchips{display:flex;align-items:center;gap:8px}
.controls{display:flex;flex-wrap:wrap;gap:8px;width:min(1200px,100% - 32px);margin:10px auto}
#map{width:min(1200px,100% - 32px);height:68vh;margin:8px auto;border-radius:14px;overflow:hidden;background:#dce3f7;border:1px solid #e5e7eb}
.panel{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:12px;margin:10px auto;width:min(1200px,100% - 32px)}
.openlist{padding:0}.panel .panel-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.panel .ghost.small{padding:6px 8px}
.veh-ico{border:0}.veh{display:grid;place-items:center;width:28px;height:28px;border-radius:50%;border:2px solid currentColor;background:#fff;font-size:16px;line-height:1}
.pin{display:grid;place-items:center;width:24px;height:24px;border-radius:50%;border:2px solid #111;background:#fff;font-size:12px;line-height:1}
@media (max-width:720px){#map{height:60vh}.controls{width:calc(100% - 16px);margin:8px auto}.panel{width:calc(100% - 16px)}.form-row{grid-template-columns:110px 1fr}}
