/* KPI Card Styles */
.kpi-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  margin-bottom: 18px;
  padding: 0 2px;
}
.kpi-card {
  background: #fff;
  border-radius: 2px;
  box-shadow: 0 2px 12px rgba(59,130,246,0.07);
  padding: 10px 14px 8px 14px;
  min-width: 120px;
  flex: 1 1 120px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  border-left: 2px solid var(--kpi-accent, #3b82f6);
  transition: box-shadow 0.18s;
  position: relative;
}
.kpi-card:hover {
  box-shadow: 0 4px 24px rgba(59,130,246,0.13);
}
.kpi-label {
  font-size: 0.92rem;
  font-weight: 500;
  color: #374151;
  margin-bottom: 1px;
}
.kpi-value {
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--kpi-accent, #3b82f6);
  margin-bottom: 1px;
  line-height: 1.1;
}
.kpi-sub {
  font-size: 0.82rem;
  color: #6b7280;
  opacity: 0.8;
}
/* Stats Card (icon + number layout) */
.stats-card {
  border: 0;
  border-radius: 6px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
  transition: box-shadow 0.18s;
}
.stats-card:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,0.11);
}
.stats-icon {
  width: 48px;
  height: 48px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
}

@media (max-width: 900px) {
  .kpi-strip {
    flex-direction: column;
    gap: 8px;
  }
  .kpi-card {
    min-width: 0;
    width: 100%;
    padding: 8px 8px 6px 10px;
  }
}

/* ── Permission Chips (roles/detail.ejs) ─────────────────────────────────── */
.perm-chip {
  display:       inline-flex;
  align-items:   center;
  gap:           5px;
  padding:       4px 10px;
  border-radius: 20px;
  font-size:     0.78rem;
  font-weight:   500;
  cursor:        pointer;
  user-select:   none;
  border:        1.5px solid #d1d5db;
  background:    #f9fafb;
  color:         #6b7280;
  transition:    background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s;
}
.perm-chip i {
  font-size: 0.82rem;
}
.perm-chip:hover:not(.readonly) {
  border-color: #6366f1;
  background:   #eef2ff;
  color:        #4f46e5;
  box-shadow:   0 1px 4px rgba(99,102,241,0.15);
}
.perm-chip.granted {
  background:   #dcfce7;
  border-color: #16a34a;
  color:        #15803d;
  font-weight:  600;
}
.perm-chip.granted:hover:not(.readonly) {
  background:   #bbf7d0;
  border-color: #15803d;
}
.perm-chip.readonly {
  cursor:  default;
  opacity: 0.85;
}

/* Role card hover lift */
.role-card {
  transition: box-shadow 0.18s, transform 0.15s;
}
.role-card:hover {
  box-shadow: 0 6px 24px rgba(0,0,0,0.10) !important;
  transform:  translateY(-2px);
}

/* Avatar initials */
.avatar {
  width:         34px;
  height:        34px;
  border-radius: 50%;
  display:       flex;
  align-items:   center;
  justify-content: center;
  font-size:     0.75rem;
  font-weight:   700;
  flex-shrink:   0;
}
