.staff-card-wrapper {
  display: grid;
  gap: 2rem;
}

.facility-title {
  font-size: 1.3rem;
  margin-bottom: 1rem;
  font-weight: bold;
}

.position-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1rem;
}

.position-card {
  background: #fff;
  border-radius: 14px;
  padding: 1rem;
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}

.card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.card-header h3 {
  font-size: 1rem;
  margin: 0;
}

.status {
  padding: .25em .75em;
  border-radius: 999px;
  font-size: .75rem;
  white-space: nowrap;
}

.status-none {
  background: #dcfce7;
  color: #166534;
}

.status-normal {
  background: #fef9c3;
  color: #854d0e;
}

.status-emergency {
  background: #fee2e2;
  color: #991b1b;
}

.card-body {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .5rem;
  margin: 1rem 0;
}

.metric span {
  display: block;
  font-size: .75rem;
  color: #6b7280;
}

.metric strong {
  font-size: 1.1rem;
  font-weight: bold;
}

.card-footer {
  text-align: center;
  font-weight: bold;
  padding: .5rem;
  border-radius: 8px;
}

.card-footer.filled {
  background: #ecfeff;
  color: #0369a1;
}

.card-footer.shortage {
  background: #fff1f2;
  color: #9f1239;
}