:root { --royal:#0d47a1; --soft:#f5f7fb; }
body { background: var(--soft); }
.bg-primary { background: var(--royal)!important; }
.card { border: 0; border-radius: 18px; box-shadow: 0 8px 25px rgba(20,40,80,.08); }
.btn-primary { background: var(--royal); border-color: var(--royal); }
.stat-card .value { font-size: 1.8rem; font-weight: 800; }
#map { height: calc(100vh - 125px); min-height: 620px; border-radius: 18px; }
#miniMap { height: 420px; border-radius: 18px; }
.sidebar-map { max-height: calc(100vh - 125px); overflow:auto; }
.badge-soft { background:#e8f0fe; color:#0d47a1; }
.table-sm td, .table-sm th { vertical-align: middle; }
.login-wrap { min-height: calc(100vh - 80px); display:flex; align-items:center; justify-content:center; }
.login-card { width: 100%; max-width: 430px; }
.marker-dot { border-radius: 50%; border: 2px solid white; box-shadow: 0 2px 8px rgba(0,0,0,.35); }

.map-legend{position:absolute;right:18px;bottom:18px;z-index:500;line-height:1.7}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px}.legend-line{display:inline-block;width:24px;border-top:2px solid #0d6efd;margin-right:6px;vertical-align:middle}.origin-pin{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#0d6efd;color:#fff;border:3px solid #fff;box-shadow:0 2px 10px rgba(0,0,0,.25);font-weight:800}.distance-label span{background:#fff;border:1px solid rgba(13,110,253,.35);box-shadow:0 2px 8px rgba(0,0,0,.12);border-radius:999px;padding:2px 7px;font-size:11px;font-weight:700;color:#0d6efd;white-space:nowrap}.marker-dot{border-radius:50%;border:2px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.25)}
