/* User Management page-specific styles */

.kpi-row-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.75rem;
}

.table-scroll {
  overflow-x: auto;
}

/* Tab toolbar */
.tab-toolbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--border);
}

/* Tab system */
.tab-list {
  display: flex;
  gap: 0.25rem;
  background: var(--bg);
  border-radius: 8px;
  padding: 3px;
}

.tab-btn {
  padding: 0.3rem 0.875rem;
  border-radius: 6px;
  border: none;
  background: none;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  transition: all 0.15s;
  font-family: 'Inter', sans-serif;
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  white-space: nowrap;
}

.tab-btn:hover {
  color: var(--text);
  background: rgba(0,0,0,0.04);
}

.tab-btn.active {
  background: var(--card);
  color: var(--kai-red);
  box-shadow: 0 1px 4px rgba(0,0,0,0.08);
}

.tab-content {
  display: none;
}

.tab-content.active {
  display: block;
}

/* User avatar */
.user-av {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6875rem;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
  text-transform: uppercase;
}

.av-red    { background: linear-gradient(135deg, #DC2626, #F97316); }
.av-blue   { background: linear-gradient(135deg, #2563EB, #06B6D4); }
.av-green  { background: linear-gradient(135deg, #10B981, #059669); }
.av-purple { background: linear-gradient(135deg, #8B5CF6, #6366F1); }
.av-orange { background: linear-gradient(135deg, #F97316, #F59E0B); }
.av-teal   { background: linear-gradient(135deg, #14B8A6, #06B6D4); }

.user-cell {
  display: flex;
  align-items: center;
  gap: 0.625rem;
}

.user-name {
  font-weight: 600;
  color: var(--text);
  font-size: 0.8125rem;
}

.user-id {
  font-size: 0.6875rem;
  color: var(--muted);
  font-family: 'JetBrains Mono', monospace;
}

/* Role badges */
.role-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0.2rem 0.5rem;
  border-radius: 6px;
  font-size: 0.6875rem;
  font-weight: 700;
}

.role-admin   { background: rgba(220,38,38,0.1);  color: #991B1B; }
.role-planner { background: rgba(249,115,22,0.1); color: #9A3412; }
.role-viewer  { background: rgba(16,185,129,0.1); color: #047857; }

/* Action buttons */
.action-cell {
  display: flex;
  gap: 4px;
}

.act-btn {
  padding: 0.2rem 0.5rem;
  border-radius: 5px;
  border: 1px solid var(--border);
  background: none;
  font-size: 0.6875rem;
  cursor: pointer;
  transition: all 0.15s;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-family: 'Inter', sans-serif;
  color: var(--muted);
}

.act-btn:hover { border-color: var(--accent); color: var(--accent); }
.act-btn.danger:hover { border-color: var(--red); color: var(--red); }

/* Organisasi table */
.org-type-badge {
  padding: 0.15rem 0.5rem;
  border-radius: 100px;
  font-size: 0.6875rem;
  font-weight: 600;
}

.org-kp   { background: rgba(220,38,38,0.1);  color: #991B1B; }
.org-daop { background: rgba(37,99,235,0.1);  color: #1E40AF; }
.org-divr { background: rgba(139,92,246,0.1); color: #5B21B6; }

/* RBAC Table */
.rbac-intro {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
  padding: 0.75rem;
  background: var(--bg);
  border-radius: 8px;
  font-size: 0.875rem;
}

.rbac-table th.role-col {
  text-align: center;
  min-width: 100px;
}

.role-admin   { color: #991B1B; }
.role-planner { color: #9A3412; }
.role-viewer  { color: #047857; }

.perm-cell {
  text-align: center;
  font-size: 1rem;
}

.perm-cell-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.2rem 0.5rem;
  border-radius: 5px;
}

.perm-yes      { background: rgba(16,185,129,0.12); color: #047857; }
.perm-readonly { background: rgba(37,99,235,0.12);  color: #1E40AF; }
.perm-no       { background: rgba(239,68,68,0.12);  color: #991B1B; }

.rbac-legend {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  margin-top: 0.875rem;
  padding-top: 0.875rem;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}

.perm-badge {
  padding: 0.2rem 0.625rem;
  border-radius: 5px;
  font-size: 0.75rem;
  font-weight: 600;
}

/* SSO Card */
.sso-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1.5rem;
  align-items: start;
}

@media (max-width: 700px) {
  .sso-grid { grid-template-columns: 1fr; }
}

.sso-server-info {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.sso-server-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.sso-server-lbl {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--muted);
  width: 100px;
  flex-shrink: 0;
}

.sso-server-val {
  font-size: 0.8125rem;
  color: var(--text);
  font-family: 'JetBrains Mono', monospace;
  background: var(--bg);
  padding: 0.15rem 0.5rem;
  border-radius: 4px;
  border: 1px solid var(--border);
}

.sso-conn-badge {
  margin-left: auto;
}

.sso-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.625rem;
}

.sso-stat-item {
  background: var(--bg);
  border-radius: 8px;
  padding: 0.625rem 0.875rem;
  border: 1px solid var(--border);
  text-align: center;
}

.sso-stat-val {
  font-size: 1.125rem;
  font-weight: 800;
  font-family: 'JetBrains Mono', monospace;
  color: var(--text);
}

.sso-stat-lbl {
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
  margin-top: 2px;
}

/* Modal */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 1000;
  align-items: center;
  justify-content: center;
}

.modal-overlay.open {
  display: flex;
}

.modal-box {
  background: var(--card);
  border-radius: 12px;
  width: 480px;
  max-width: 95vw;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  overflow: hidden;
}

.modal-hdr {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal-title {
  font-size: 0.9375rem;
  font-weight: 800;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.modal-close {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 1rem;
  padding: 0.25rem;
  border-radius: 5px;
  transition: all 0.15s;
}

.modal-close:hover { color: var(--red); }

.modal-body {
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}

.form-row {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.form-row-half {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

.form-lbl {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--text);
}

.req {
  color: var(--red);
}

.form-input {
  padding: 0.45rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: 7px;
  font-size: 0.8125rem;
  color: var(--text);
  background: var(--card);
  font-family: 'Inter', sans-serif;
  transition: border-color 0.15s;
  width: 100%;
}

.form-input:focus {
  outline: none;
  border-color: var(--accent);
}

.input-group {
  display: flex;
}

.input-group .form-input {
  border-radius: 7px 0 0 7px;
}

.input-addon {
  padding: 0.45rem 0.75rem;
  border: 1px solid var(--border);
  border-left: none;
  border-radius: 0 7px 7px 0;
  background: var(--bg);
  color: var(--muted);
  cursor: pointer;
  font-size: 0.875rem;
  transition: all 0.15s;
}

.input-addon:hover { background: var(--accent); color: #fff; border-color: var(--accent); }

.form-check {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8125rem;
  color: var(--text);
}

.modal-footer {
  padding: 0.875rem 1.25rem;
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
}

/* KPI animation */
@keyframes countUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.kpi-val.counting {
  animation: countUp 0.4s ease;
}
