:root {
  --bg:#0a0f1a; --surface:#111827; --surface-2:#1e293b; --border:#1f2937;
  --border-2:#334155; --text:#e5e7eb; --dim:#94a3b8; --mute:#64748b;
  --primary:#2563eb; --primary-2:#1d4ed8; --accent:#38bdf8;
  --green:#10b981; --amber:#f59e0b; --red:#ef4444; --purple:#a855f7;
}
* { box-sizing: border-box; }
body { margin:0; font-family:"Segoe UI","Inter",system-ui,Arial,sans-serif; background:var(--bg); color:var(--text); font-size:14px; }
button, input, select { font:inherit; }
input, select { background:#0f172a; color:var(--text); border:1px solid var(--border-2); border-radius:8px; padding:6px 10px; }
button { cursor:pointer; border:1px solid var(--border-2); background:var(--surface); color:var(--text); padding:8px 12px; border-radius:8px; transition:background .15s; }
button:hover { background:var(--surface-2); }
.btn-primary { background:var(--primary); border-color:var(--primary); color:#fff; font-weight:600; }
.btn-primary:hover { background:var(--primary-2); }
.btn-secondary { background:var(--surface); }
h3 { margin:0 0 10px; font-size:14px; }

.topbar {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 20px; background:var(--surface); border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:10;
}
.brand { display:flex; align-items:center; gap:12px; }
.logo {
  width:42px; height:42px; border-radius:10px; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--primary),var(--accent)); font-size:22px;
}
.title { font-weight:700; font-size:18px; }
.sub   { font-size:11px; color:var(--dim); }
.controls { display:flex; gap:8px; align-items:center; }

.pill {
  display:inline-block; padding:3px 10px; border-radius:999px; font-size:11px; font-weight:600;
  border:1px solid transparent;
}
.pill-on  { background:rgba(16,185,129,.18); color:var(--green); border-color:rgba(16,185,129,.35); }
.pill-off { background:rgba(239,68,68,.15); color:var(--red);   border-color:rgba(239,68,68,.3); }
.pill-idle      { background:rgba(148,163,184,.18); color:var(--dim); border-color:rgba(148,163,184,.35); }
.pill-waiting   { background:rgba(245,158,11,.15);  color:var(--amber); border-color:rgba(245,158,11,.3); }
.pill-inTrip    { background:rgba(168,85,247,.15);  color:var(--purple); border-color:rgba(168,85,247,.3); }
.pill-toPickup  { background:rgba(168,85,247,.15);  color:var(--purple); border-color:rgba(168,85,247,.3); }
.pill-toDestination { background:rgba(168,85,247,.15); color:var(--purple); border-color:rgba(168,85,247,.3); }
.pill-atPickup  { background:rgba(56,189,248,.15);  color:var(--accent); border-color:rgba(56,189,248,.3); }
.pill-booking   { background:rgba(245,158,11,.15);  color:var(--amber); border-color:rgba(245,158,11,.3); }

.grid {
  display:grid; gap:14px; padding:14px;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-areas:
    "pass drv op"
    "map  map map"
    "log  log log";
}
.grid > section:nth-child(1) { grid-area: pass; }
.grid > section:nth-child(2) { grid-area: drv; }
.grid > section:nth-child(3) { grid-area: op; }
.map-card { grid-area: map; }
.log-card { grid-area: log; }
@media (max-width: 1100px) {
  .grid { grid-template-columns: 1fr; grid-template-areas: "pass" "drv" "op" "map" "log"; }
}

.card {
  background:var(--surface); border:1px solid var(--border); border-radius:12px;
  padding:14px; min-height:200px;
}
.kpis { display:flex; gap:8px; margin-bottom:10px; flex-wrap:wrap; }
.kpi  { background:var(--surface-2); border:1px solid var(--border); border-radius:8px; padding:6px 10px; font-size:12px; }
.kpi b { font-size:16px; font-weight:700; }
.add-row { display:flex; gap:6px; align-items:center; margin-bottom:8px; }

.table-wrap { max-height:280px; overflow:auto; border:1px solid var(--border); border-radius:8px; }
table { width:100%; border-collapse:collapse; }
th, td { padding:6px 8px; text-align:left; font-size:12px; border-bottom:1px solid var(--border); }
th { background:#0f172a; color:var(--dim); font-size:10px; text-transform:uppercase; letter-spacing:.4px; position:sticky; top:0; }
tr:hover td { background:rgba(37,99,235,.06); }

#map { width:100%; height:380px; border-radius:10px; border:1px solid var(--border); }

#log {
  max-height:260px; overflow:auto; background:#0a0f1a;
  border:1px solid var(--border); border-radius:8px; padding:8px;
  font-family:"Cascadia Code","Consolas",monospace; font-size:12px; line-height:1.6;
}
.log-row { display:grid; grid-template-columns: 70px 80px 1fr; gap:8px; padding:2px 0; }
.log-time { color:var(--mute); }
.log-role { color:var(--accent); }
.log-role.driver    { color:#bbf7d0; }
.log-role.passenger { color:#fbcfe8; }
.log-role.operator  { color:#d8b4fe; }
.log-msg  { color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.log-msg.error { color:var(--red); }

.emoji-pin {
  display:flex; align-items:center; justify-content:center;
  width:26px; height:26px; border-radius:999px; border:2px solid #9ca3af;
  font-size:14px; box-shadow:0 2px 6px rgba(0,0,0,.45);
}
.pin-driver-idle    { background:#bbf7d0; }
.pin-driver-onjob   { background:#fbcfe8; }
.pin-passenger      { background:#fdba74; }
