/* ═══════════════════════════════════════════════════════════════════════════
   RBAC Dashboard — Permissions API
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Layout ────────────────────────────────────────────────────────────── */

.rbac-layout {
  display: flex;
  min-height: calc(100vh - 40px - 64px); /* minus status bar + page header */
  margin: -32px; /* counteract main padding */
  margin-top: 0;
}

.rbac-sidebar {
  width: 250px;
  flex-shrink: 0;
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
  overflow-y: auto;
}

.rbac-main {
  flex: 1;
  padding: 20px 28px;
  overflow-y: auto;
}

/* ─── Sidebar — Actor list ──────────────────────────────────────────────── */

.rbac-actor-group-title {
  padding: 16px 16px 10px;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .8px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 4px;
}

.rbac-actor-btn {
  width: 100%;
  text-align: left;
  border: none;
  padding: 12px 16px;
  cursor: pointer;
  background: transparent;
  border-left: 3px solid transparent;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.rbac-actor-btn:hover {
  background: rgba(99, 102, 241, 0.06);
}

.rbac-actor-btn.active {
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.15), rgba(139, 92, 246, 0.15));
  border-left-color: var(--accent);
}

.rbac-actor-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.rbac-actor-icon.agent {
  background: rgba(168, 85, 247, 0.12);
  color: var(--purple);
}

.rbac-actor-icon.employee {
  background: rgba(59, 130, 246, 0.12);
  color: var(--blue);
}

.rbac-actor-name {
  font-weight: 600;
  font-size: 13px;
  color: var(--text-primary);
}

.rbac-actor-name.inactive {
  color: var(--text-muted);
}

.rbac-actor-desc {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rbac-actor-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.rbac-actor-dot.on {
  background: var(--green);
  box-shadow: 0 0 6px rgba(16, 185, 129, 0.2);
}

.rbac-actor-dot.off {
  background: var(--red);
}

/* ─── Actor header ──────────────────────────────────────────────────────── */

.rbac-actor-header {
  margin-bottom: 16px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.rbac-actor-header h2 {
  margin: 0;
  font-size: 22px;
  font-weight: 700;
}

.rbac-actor-counters {
  display: flex;
  gap: 16px;
  margin-top: 6px;
}

.rbac-actor-counters span {
  font-size: 12px;
  font-family: 'JetBrains Mono', monospace;
}

.rbac-counter-get { color: var(--green); }
.rbac-counter-mut { color: var(--yellow); }
.rbac-counter-blocked { color: var(--text-muted); }

/* Kill switch */
.rbac-kill-switch {
  display: flex;
  align-items: center;
  gap: 10px;
}

.rbac-kill-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.rbac-kill-label.on { color: var(--green); }
.rbac-kill-label.off { color: var(--red); }

/* ─── Toggle component ──────────────────────────────────────────────────── */

.rbac-toggle {
  width: 34px;
  height: 18px;
  border-radius: 9px;
  border: none;
  padding: 0;
  cursor: pointer;
  position: relative;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  flex-shrink: 0;
  background: #374151;
}

.rbac-toggle.on {
  background: var(--green);
}

.rbac-toggle.disabled {
  opacity: 0.3;
  cursor: not-allowed;
  background: var(--bg-tertiary);
}

.rbac-toggle-knob {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #fff;
  transition: left 0.2s;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

.rbac-toggle.on .rbac-toggle-knob {
  left: 17px;
}

/* ─── Skills panel ──────────────────────────────────────────────────────── */

.rbac-skills-panel {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 18px;
  margin-bottom: 16px;
}

.rbac-skills-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.rbac-skills-header-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
}

.rbac-new-skill-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 5px 10px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--bg-tertiary);
  color: var(--text-secondary);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.rbac-new-skill-btn:hover {
  border-color: var(--accent);
}

.rbac-new-skill-btn .icon-accent {
  color: var(--accent);
  display: inline-flex;
}

.rbac-skills-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.rbac-skill-item {
  display: flex;
  align-items: center;
  gap: 4px;
}

.rbac-skill-chip {
  padding: 7px 12px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  align-items: center;
  gap: 6px;
}

.rbac-skill-chip.active {
  /* border-color and bg set via inline style per skill color */
}

.rbac-skill-counter {
  font-size: 10px;
  font-family: 'JetBrains Mono', monospace;
  padding: 1px 5px;
  border-radius: 4px;
}

.rbac-skill-counter.full {
  background: rgba(16, 185, 129, 0.12);
  color: var(--green);
}

.rbac-skill-counter.partial {
  background: rgba(245, 158, 11, 0.12);
  color: var(--yellow);
}

.rbac-skill-counter.none {
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-muted);
}

.rbac-skill-action {
  padding: 3px 6px;
  border-radius: 4px;
  border: none;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  font-family: 'JetBrains Mono', monospace;
}

.rbac-skill-action.on {
  background: rgba(16, 185, 129, 0.12);
  color: var(--green);
}

.rbac-skill-action.off {
  background: rgba(239, 68, 68, 0.12);
  color: var(--red);
}

.rbac-skill-action.edit {
  padding: 3px 6px;
  border-radius: 4px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
}

.rbac-skill-desc {
  margin-top: 10px;
  font-size: 12px;
  color: var(--text-secondary);
}

.rbac-skill-desc .accent {
  font-family: 'JetBrains Mono', monospace;
  color: var(--accent);
}

/* ─── Search bar ────────────────────────────────────────────────────────── */

.rbac-search {
  width: 100%;
  padding: 8px 12px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  margin-bottom: 16px;
  transition: border-color 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.rbac-search:focus {
  border-color: var(--accent);
}

/* ─── Endpoint groups ───────────────────────────────────────────────────── */

.rbac-group {
  margin-bottom: 12px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
}

.rbac-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  background: var(--bg-secondary);
  cursor: pointer;
  user-select: none;
}

.rbac-group-header:hover {
  background: var(--bg-tertiary);
}

.rbac-group-left {
  display: flex;
  align-items: center;
  gap: 8px;
}

.rbac-group-chevron {
  color: var(--text-muted);
  display: inline-flex;
  transition: transform 0.2s;
}

.rbac-group.collapsed .rbac-group-chevron {
  transform: rotate(-90deg);
}

.rbac-group-name {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: .8px;
}

.rbac-group-count {
  font-size: 11px;
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-muted);
}

.rbac-group-body {
  /* visible by default */
}

.rbac-group.collapsed .rbac-group-body {
  display: none;
}

/* ─── Endpoint row ──────────────────────────────────────────────────────── */

.rbac-ep-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 16px;
  border-bottom: 1px solid var(--border);
  border-left: 3px solid transparent;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.rbac-ep-row:last-child {
  border-bottom: none;
}

.rbac-ep-row.highlighted {
  /* bg and border-left set inline per skill color */
}

.rbac-ep-method {
  font-size: 10px;
  font-weight: 700;
  font-family: 'JetBrains Mono', monospace;
  width: 46px;
  text-align: center;
  padding: 2px 0;
  border-radius: 3px;
  flex-shrink: 0;
}

.rbac-ep-path {
  font-size: 11px;
  font-family: 'JetBrains Mono', monospace;
  flex: 0 0 260px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rbac-ep-path.on { color: var(--text-primary); }
.rbac-ep-path.off { color: var(--text-muted); }

.rbac-ep-desc {
  font-size: 12px;
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rbac-ep-desc.on { color: var(--text-secondary); }
.rbac-ep-desc.off { color: var(--text-muted); }

.rbac-ep-sens {
  font-size: 9px;
  font-weight: 700;
  font-family: 'JetBrains Mono', monospace;
  padding: 1px 5px;
  border-radius: 3px;
  flex-shrink: 0;
}

.rbac-ep-highlight-dot {
  font-size: 9px;
  flex-shrink: 0;
}

/* ─── Scopes preview ────────────────────────────────────────────────────── */

.rbac-scopes-panel {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 18px;
  margin-top: 8px;
}

.rbac-scopes-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 8px;
}

.rbac-scopes-list {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.rbac-scope-badge {
  font-size: 10px;
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-secondary);
  background: var(--bg-tertiary);
  padding: 2px 6px;
  border-radius: 4px;
}

.rbac-scopes-empty {
  font-size: 12px;
  color: var(--text-muted);
  font-style: italic;
}

/* ─── Save button (in page header) ──────────────────────────────────────── */

.rbac-save-btn {
  padding: 10px 20px;
  border: none;
  border-radius: 8px;
  background: var(--accent);
  color: #fff;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.rbac-save-btn:hover {
  filter: brightness(1.15);
}

.rbac-save-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ─── Skill editor modal ────────────────────────────────────────────────── */

.rbac-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 600;
}

.rbac-modal {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 14px;
  width: 720px;
  max-width: 95vw;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
  animation: crmFadeIn 0.2s ease;
}

.rbac-modal-header {
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.rbac-modal-header h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
}

.rbac-modal-close {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-muted);
  padding: 4px;
  display: flex;
  align-items: center;
}

.rbac-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px 24px;
}

.rbac-modal-footer {
  padding: 16px 24px;
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* Modal form fields */
.rbac-field-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 4px;
  display: block;
}

.rbac-field-input {
  width: 100%;
  padding: 8px 12px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.rbac-field-input:focus {
  border-color: var(--accent);
}

/* Color picker */
.rbac-color-picker {
  display: flex;
  gap: 6px;
}

.rbac-color-swatch {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  border: 2px solid transparent;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.rbac-color-swatch.active {
  border-color: #fff;
}

/* Icon picker */
.rbac-icon-picker {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}

.rbac-icon-btn {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.rbac-icon-btn.active {
  background: var(--bg-tertiary);
  border-color: var(--border);
}

/* Endpoint selector in modal */
.rbac-ep-selector {
  max-height: 280px;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg-primary);
}

.rbac-ep-selector-group {
  padding: 6px 12px;
  font-size: 10px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .8px;
  background: var(--bg-secondary);
  position: sticky;
  top: 0;
  z-index: 1;
}

.rbac-ep-selector-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  cursor: pointer;
  transition: background 0.15s;
}

.rbac-ep-selector-row:hover {
  background: rgba(255, 255, 255, 0.03);
}

.rbac-ep-selector-row.selected {
  /* bg set inline based on skill color */
}

/* Checkbox */
.rbac-checkbox {
  width: 18px;
  height: 18px;
  border-radius: 4px;
  border: 2px solid var(--border);
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  flex-shrink: 0;
}

.rbac-checkbox.checked {
  /* border + bg set inline per color */
}

.rbac-checkbox svg {
  width: 12px;
  height: 12px;
}

/* Modal buttons */
.rbac-btn-cancel {
  padding: 8px 16px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--bg-tertiary);
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.rbac-btn-save {
  padding: 8px 16px;
  border-radius: 6px;
  border: none;
  background: var(--accent);
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.rbac-btn-save:disabled {
  opacity: 0.4;
}

.rbac-btn-delete {
  padding: 8px 14px;
  border-radius: 6px;
  border: 1px solid rgba(239, 68, 68, 0.3);
  background: transparent;
  color: var(--red);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* ─── Empty state ───────────────────────────────────────────────────────── */

.rbac-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  color: var(--text-muted);
}

.rbac-empty-icon {
  margin-bottom: 12px;
  opacity: 0.5;
}

/* ─── page-read-only overrides ──────────────────────────────────────────── */

.page-read-only .rbac-toggle,
.page-read-only .rbac-save-btn,
.page-read-only .rbac-new-skill-btn,
.page-read-only .rbac-skill-action,
.page-read-only .rbac-btn-save,
.page-read-only .rbac-btn-delete {
  pointer-events: none;
  opacity: 0.4;
}
