/* ── Staff Dashboard ─────────────────────────────────────────── */
.container { padding: 24px; max-width: 1280px; margin: 0 auto; }

.sd-page-header { display: flex; align-items: center; gap: 14px; margin-bottom: 20px; }
.sd-page-icon { font-size: 30px; }
.sd-page-header h1 { margin: 0; font-size: 22px; }
.sd-page-header p { margin: 2px 0 0; color: var(--text-light, #64748b); font-size: 13px; }

/* Filters */
.sd-filters {
  display: flex; flex-wrap: wrap; align-items: flex-end; gap: 12px;
  background: #fff; border: 1px solid var(--border, #e2e8f0); border-radius: 12px;
  padding: 14px 16px; margin-bottom: 20px;
}
.sd-filter { display: flex; flex-direction: column; gap: 4px; }
.sd-filter label { font-size: 11px; font-weight: 600; color: var(--text-light, #64748b); text-transform: uppercase; letter-spacing: .4px; }
.sd-filter select, .sd-filter input {
  border: 1px solid var(--border, #e2e8f0); border-radius: 8px; padding: 8px 10px; font-size: 13px; min-width: 150px; background: #fff;
}

/* Metric cards */
.sd-metrics { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 14px; margin-bottom: 22px; }
.sd-metric {
  background: #fff; border: 1px solid var(--border, #e2e8f0); border-radius: 12px;
  padding: 18px 20px; box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.sd-metric-value { font-size: 30px; font-weight: 700; color: var(--primary, #4a8073); line-height: 1.1; }
.sd-metric-label { font-size: 13px; color: var(--text-light, #64748b); margin-top: 4px; }
.sd-metric-sub { font-size: 12px; color: #94a3b8; margin-top: 2px; }

/* Cards */
.sd-card { background: #fff; border: 1px solid var(--border, #e2e8f0); border-radius: 12px; padding: 18px 20px; margin-bottom: 20px; }
.sd-card-header { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.sd-card-header h2 { margin: 0; font-size: 16px; }
.sd-card-icon { font-size: 18px; }
.sd-sub { font-size: 12px; font-weight: 400; color: #94a3b8; }
.sd-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(360px, 1fr)); gap: 20px; }

/* Bar rows */
.sd-bars { display: flex; flex-direction: column; gap: 9px; }
.sd-bar-row { display: grid; grid-template-columns: 130px 1fr 64px; align-items: center; gap: 10px; }
.sd-bar-label { font-size: 12px; color: #334155; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sd-bar-track { background: #f1f5f9; border-radius: 6px; height: 16px; overflow: hidden; }
.sd-bar-fill { height: 100%; border-radius: 6px; transition: width .3s; }
.sd-bar-val { font-size: 12px; font-weight: 600; text-align: right; color: #334155; }
.sd-empty { color: var(--text-light, #94a3b8); font-size: 13px; padding: 10px 0; }

/* Map */
.sd-map { height: 460px; border-radius: 10px; overflow: hidden; border: 1px solid var(--border, #e2e8f0); background: #f8fafc; }
.sd-hint { font-size: 12px; color: var(--text-light, #64748b); margin-bottom: 10px; }
.sd-unmatched { margin-top: 12px; }
.sd-unmatched-note { font-size: 12px; color: #94a3b8; margin-bottom: 6px; }
.sd-citylist { display: flex; flex-wrap: wrap; gap: 6px; }
.sd-city-pill { font-size: 12px; background: #f1f5f9; border: 1px solid #e2e8f0; border-radius: 999px; padding: 3px 10px; color: #334155; }
.sd-city-pill strong { color: var(--primary, #4a8073); }

/* Specializations */
.sd-spec { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; }
.sd-spec-dept h3 { margin: 0 0 8px; font-size: 14px; }
.sd-spec-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.sd-spec-tag { font-size: 12px; background: #eef6f3; border: 1px solid #cde5dd; border-radius: 999px; padding: 3px 10px; color: #1d5e50; }
.sd-spec-tag strong { color: var(--primary, #4a8073); }

/* States */
.loading-state { display: none; padding: 30px; text-align: center; color: var(--text-light, #64748b); }
.loading-state.visible { display: block; }
.crm-banner { background: #fef2f2; border: 1px solid #fecaca; color: #b91c1c; border-radius: 10px; padding: 12px 16px; margin-bottom: 16px; font-size: 13px; }

/* Leaflet tooltip tweak */
.leaflet-tooltip { font-size: 12px; }
