/**
 * IAM Admin shell & data density (tables, cards, nav).
 * Tokens: identra-tokens.css (Identra.Blazor.DesignSystem). Load before this file.
 */
/* App shell */
.iam-app-shell {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.iam-app-body {
  display: flex;
  flex: 1;
  min-height: 0;
}

/* Main column: header + scrollable content (reference dashboard layout) */
.iam-shell-main-column {
  flex: 1;
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

/* Top header */
.iam-top-header {
  height: var(--header-height);
  min-height: var(--header-height);
  background: var(--color-background);
  border-bottom: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 1rem 0 0;
  flex-shrink: 0;
  box-shadow: var(--shadow-sm);
}

.iam-top-header--ref {
  background: #ffffff;
  border-bottom: 1px solid #e2e8f0;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  padding: 0 1.25rem 0 0.75rem;
}

.iam-top-header-left--ref {
  gap: 0.75rem;
}

.iam-top-header-page-title {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 600;
  color: #1e293b;
  line-height: 1.3;
}

.iam-top-header-right--ref {
  flex-wrap: wrap;
  justify-content: flex-end;
}

.iam-dash-edit-widgets {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.4rem 0.85rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #334155;
  background: #fff;
  border: 1px solid #cbd5e1;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.iam-dash-edit-widgets:hover {
  background: #f8fafc;
  border-color: #94a3b8;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.iam-dash-edit-widgets:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.iam-dash-edit-widgets-label {
  white-space: nowrap;
}

@media (max-width: 900px) {
  .iam-dash-edit-widgets-label {
    display: none;
  }
}

.iam-mobile-nav-toggle--in-header {
  display: none;
}

.iam-mobile-nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  margin-left: 0.25rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-background);
  color: var(--color-text);
  cursor: pointer;
  transition: background var(--transition-fast);
}

.iam-mobile-nav-toggle:hover {
  background: var(--color-surface);
}

.iam-top-header-left {
  display: flex;
  align-items: center;
  gap: 1rem;
  min-width: 0;
}

.iam-logo-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0 1rem;
  height: var(--header-height);
  text-decoration: none;
  color: var(--color-text);
  font-weight: 600;
  font-size: 0.95rem;
  transition: background var(--transition-fast);
}

.iam-logo-link:hover {
  background: var(--color-surface);
  color: var(--color-text);
}

.iam-logo-img {
  height: 32px;
  min-height: 32px;
  width: auto;
  display: block;
  object-fit: contain;
  flex-shrink: 0;
}
.iam-logo-text {
  white-space: nowrap;
  font-weight: 600;
  color: var(--color-text);
}

.iam-top-header-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.iam-env-badge {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  padding: 0.2rem 0.5rem;
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text-muted);
}

.iam-env-badge.dev { background: var(--color-info); color: #fff; }
.iam-env-badge.stage { background: var(--color-warning); color: #111; }
.iam-env-badge.prod { background: var(--color-success); color: #fff; }

.iam-header-org-switcher {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}
.iam-header-org-label { text-transform: uppercase; letter-spacing: 0.02em; }
.iam-header-search {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
  font-size: 0.875rem;
  min-width: 160px;
}
.iam-header-search-icon { font-size: 1rem; }
.iam-header-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: none;
  background: none;
  color: var(--color-text-muted);
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-decoration: none;
  transition: background var(--transition-fast), color var(--transition-fast);
}
.iam-header-icon-btn:hover { background: var(--color-surface); color: var(--color-text); }
.iam-header-profile-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: 8px;
  padding-left: 8px;
  border-left: 1px solid var(--color-border);
}
.iam-header-user { font-size: 0.875rem; color: var(--color-text-muted); }
.iam-header-btn { padding: 6px 12px; font-size: 0.8125rem; }

/* Sidebar */
.iam-sidebar {
  width: var(--sidebar-width);
  min-width: var(--sidebar-width);
  background: var(--color-background);
  border-right: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  transition: width var(--transition-normal), min-width var(--transition-normal);
  overflow: hidden;
}

/* Reference: royal blue sidebar, white nav text, pill active state */
.iam-sidebar.iam-sidebar--ref {
  background: linear-gradient(180deg, #1e3a8a 0%, #1d4ed8 55%, #1d4ed8 100%);
  border-right: none;
  box-shadow: 4px 0 24px rgba(30, 58, 138, 0.12);
}

.iam-sidebar-brand {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.65rem 0.5rem 0.65rem 0.65rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  flex-shrink: 0;
}

.iam-sidebar-menu-btn {
  display: none;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  cursor: pointer;
  transition: background var(--transition-fast);
}

.iam-sidebar-menu-btn:hover {
  background: rgba(255, 255, 255, 0.18);
}

@media (min-width: 769px) {
  .iam-sidebar-menu-btn {
    display: inline-flex;
  }
}

.iam-sidebar-brand-link {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  text-decoration: none;
  color: #fff;
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.02em;
  min-width: 0;
  flex: 1;
}

.iam-sidebar-brand-link:hover {
  color: #fff;
}

.iam-sidebar-brand-logo {
  height: 32px;
  width: auto;
  object-fit: contain;
  flex-shrink: 0;
}

.iam-sidebar-brand-text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.iam-sidebar.collapsed .iam-sidebar-brand-logo {
  display: none;
}

.iam-sidebar-footer {
  flex-shrink: 0;
  padding: 0.75rem 0.65rem;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.iam-sidebar-user {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: rgba(255, 255, 255, 0.95);
  font-size: 0.8125rem;
}

.iam-sidebar-user-avatar {
  font-size: 1.75rem;
  color: rgba(255, 255, 255, 0.9);
  flex-shrink: 0;
}

.iam-sidebar-user-name {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.iam-sidebar-user-chevron {
  font-size: 0.75rem;
  opacity: 0.8;
  flex-shrink: 0;
}

.iam-sidebar-user-guest {
  color: #fff;
  font-size: 0.875rem;
  font-weight: 500;
}

.iam-sidebar--ref .iam-sidebar-toggle {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.2);
  color: rgba(255, 255, 255, 0.9);
}

.iam-sidebar--ref .iam-sidebar-toggle:hover {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.35);
  color: #fff;
}

.iam-sidebar--ref .iam-nav-group-title {
  color: rgba(255, 255, 255, 0.45);
  padding-left: 0.85rem;
  padding-right: 0.85rem;
}

.iam-sidebar--ref .iam-nav-item {
  color: rgba(255, 255, 255, 0.88);
  margin-left: 0.35rem;
  margin-right: 0.35rem;
}

.iam-sidebar--ref .iam-nav-item:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}

.iam-sidebar--ref .iam-nav-item.active,
.iam-sidebar--ref a.iam-nav-item.nav-link.active {
  background: #ffffff;
  color: #1d4ed8;
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.iam-sidebar--ref .iam-nav-item .bi {
  color: inherit;
}

.iam-sidebar.collapsed {
  width: var(--sidebar-width-collapsed);
  min-width: var(--sidebar-width-collapsed);
}

.iam-sidebar-nav {
  flex: 1;
  overflow-y: auto;
  padding: 0.5rem 0;
}

.iam-nav-group-title {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  padding: 0.75rem 1rem 0.5rem;
  margin: 0;
}

.iam-sidebar.collapsed .iam-nav-group-title {
  padding: 0.5rem;
  text-align: center;
  overflow: hidden;
  text-overflow: ellipsis;
}

.iam-nav-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 1rem;
  color: var(--color-text-muted);
  text-decoration: none;
  font-size: 0.875rem;
  border-radius: var(--radius-sm);
  margin: 0 0.5rem;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.iam-nav-item:hover {
  background: var(--color-surface);
  color: var(--color-text);
}

.iam-nav-item.active,
a.iam-nav-item.nav-link.active {
  background: var(--color-primary-muted);
  color: var(--color-primary);
  font-weight: 500;
}

.iam-sidebar.collapsed .iam-nav-item {
  justify-content: center;
  padding: 0.6rem;
}

.iam-sidebar.collapsed .iam-nav-item span:not(.bi) {
  display: none;
}

.iam-nav-item .bi { font-size: 1.1rem; flex-shrink: 0; }

.iam-sidebar-toggle {
  margin: 0.5rem;
  padding: 0.5rem;
  width: calc(100% - 1rem);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: background var(--transition-fast);
}
.iam-sidebar-toggle:hover { background: var(--color-border); }
.iam-sidebar.collapsed .iam-sidebar-toggle { width: calc(100% - 0.5rem); margin: 0.5rem 0.25rem; }

/* Page container */
.iam-page-container {
  flex: 1;
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  background: var(--color-page, var(--ids-page-bg));
}

.iam-shell-ref-dashboard .iam-page-container {
  background: #e8ecf3;
}

.iam-page-content {
  flex: 1;
  padding: var(--space-24);
  overflow: auto;
}

/* Content max-width container (enterprise IAM standard) */
.iam-content-wrap {
  max-width: var(--content-max-width);
  margin: 0 auto;
  width: 100%;
}

/* Content area: ensure all child content uses design tokens */
.iam-page-content h1, .iam-page-content h2, .iam-page-content h3 {
  color: var(--color-text);
  font-weight: 600;
}
.iam-page-content p {
  color: var(--color-text-muted);
}
/* Do not style design-system / shell buttons as body links (would paint primary text on primary fill). */
.iam-page-content a:not(.ids-btn) {
  color: var(--color-primary);
}
.iam-page-content a:not(.ids-btn):hover {
  color: var(--color-primary-hover);
}

.iam-page-content a.iam-btn-primary {
  color: #fff;
}
.iam-page-content a.iam-btn-primary:hover {
  color: #fff;
}
.iam-page-content a.iam-btn-secondary {
  color: var(--color-text);
}
.iam-page-content a.iam-btn-secondary:hover {
  color: var(--color-text);
}

/* Page header pattern */
.iam-page-header {
  margin-bottom: 1.5rem;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.iam-page-title {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-text);
}

.iam-breadcrumb {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  margin-bottom: 0.25rem;
}

.iam-page-actions {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

/* Buttons */
.iam-btn-primary {
  background: var(--color-primary);
  color: #fff;
  border: none;
  padding: 0.5rem 1rem;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--transition-fast);
}

.iam-btn-primary:hover {
  background: var(--color-primary-hover);
}

.iam-btn-secondary {
  background: var(--color-surface);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  padding: 0.5rem 1rem;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast);
}

.iam-btn-secondary:hover {
  background: var(--color-border);
}

.iam-btn-danger {
  background: rgba(239, 68, 68, 0.1);
  color: var(--color-error);
  border: 1px solid var(--color-error);
  padding: 0.5rem 1rem;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast);
}
.iam-btn-danger:hover {
  background: rgba(239, 68, 68, 0.2);
}

/* Button focus (accessibility) */
.iam-btn-primary:focus-visible,
.iam-btn-secondary:focus-visible,
.iam-btn-danger:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.iam-btn-danger:focus-visible { outline-color: var(--color-error); }

/* Cards */
.iam-card {
  background: var(--color-background);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: 1.25rem;
}
.iam-identity-card {
  margin-bottom: var(--space-24);
}

/* Status badges */
.iam-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.5rem;
  font-size: 0.75rem;
  font-weight: 500;
  border-radius: var(--radius-sm);
}

.iam-badge-success { background: rgba(22, 163, 74, 0.15); color: var(--color-success); }
.iam-badge-warning { background: rgba(245, 158, 11, 0.15); color: var(--color-warning); }
.iam-badge-error { background: rgba(239, 68, 68, 0.15); color: var(--color-error); }
.iam-badge-info { background: rgba(6, 182, 212, 0.15); color: var(--color-info); }

/* Tables */
.iam-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.iam-table th,
.iam-table td {
  padding: 0.75rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}

.iam-table th {
  font-weight: 600;
  color: var(--color-text-muted);
  background: var(--color-surface);
}

.iam-table tbody tr:hover {
  background: var(--color-surface);
}

/* Enterprise table density: set on wrapper .iam-data-table[data-density="comfortable|standard|compact"] */
.iam-data-table[data-density="comfortable"] { --table-row-height: var(--table-row-height-comfortable); }
.iam-data-table[data-density="standard"]   { --table-row-height: var(--table-row-height-standard); }
.iam-data-table[data-density="compact"]   { --table-row-height: var(--table-row-height-compact); }
.iam-data-table .table th,
.iam-data-table .table td,
.iam-data-table.iam-table th,
.iam-data-table.iam-table td {
  min-height: var(--table-row-height);
  padding-top: calc((var(--table-row-height) - 1.25em) / 2);
  padding-bottom: calc((var(--table-row-height) - 1.25em) / 2);
}

/* Sticky table header and first column */
.iam-data-table-sticky thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--color-surface);
  box-shadow: 0 1px 0 var(--color-border);
}
.iam-data-table-sticky .col-sticky-first,
.iam-data-table-sticky td.col-sticky-first,
.iam-data-table-sticky th.col-sticky-first {
  position: sticky;
  left: 0;
  z-index: 1;
  background: var(--color-background);
}
.iam-data-table-sticky thead th.col-sticky-first { z-index: 3; background: var(--color-surface); }
.iam-data-table-sticky tbody tr:hover td.col-sticky-first { background: var(--color-surface); }

/* Table column hierarchy: apply to cells */
.iam-col-primary   { font-weight: 600; color: var(--color-text); }
.iam-col-secondary { color: var(--color-text-muted); }
.iam-col-metadata  { font-size: 0.8125rem; color: var(--color-text-muted); opacity: 0.9; }

/* Bulk selection column */
.iam-data-table .col-bulk { width: 2.5rem; text-align: center; vertical-align: middle; }

/* Table toolbar (filters, density toggle, bulk actions) */
.iam-table-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-16);
  flex-wrap: wrap;
  margin-bottom: var(--space-12);
  padding: var(--space-8) 0;
}
.iam-table-toolbar-left,
.iam-table-toolbar-right { display: flex; align-items: center; gap: var(--space-8); }

/* Slide-out detail panel (right side) */
.iam-detail-panel-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.25);
  z-index: 200;
  animation: iam-fade-in var(--transition-normal);
}
.iam-detail-panel {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(var(--detail-panel-width), 100vw);
  max-width: 100%;
  background: var(--color-background);
  border-left: 1px solid var(--color-border);
  box-shadow: var(--shadow-lg);
  z-index: 201;
  display: flex;
  flex-direction: column;
  animation: iam-slide-in-right var(--transition-normal);
}
.iam-detail-panel-header {
  padding: var(--space-16) var(--space-24);
  border-bottom: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}
.iam-detail-panel-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-24);
}
@keyframes iam-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes iam-slide-in-right { from { transform: translateX(100%); } to { transform: translateX(0); } }

/* Activity timeline */
.iam-timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  border-left: 2px solid var(--color-border);
  margin-left: 0.5rem;
  padding-left: var(--space-24);
}
.iam-timeline-item {
  position: relative;
  padding-bottom: var(--space-16);
}
.iam-timeline-item::before {
  content: '';
  position: absolute;
  left: calc(-1 * (var(--space-24) + 0.5rem));
  top: 0.4rem;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-primary);
}
.iam-timeline-item-time   { font-size: 0.75rem; color: var(--color-text-muted); margin-bottom: 2px; }
.iam-timeline-item-actor   { font-weight: 500; color: var(--color-text); }
.iam-timeline-item-action  { color: var(--color-text-muted); }
.iam-timeline-item-object  { color: var(--color-text-muted); font-size: 0.875rem; }
.iam-timeline-item-status  { margin-top: 4px; }

/* Form sections and progressive disclosure */
.iam-form-section {
  margin-bottom: var(--space-24);
  padding-bottom: var(--space-24);
  border-bottom: 1px solid var(--color-border);
}
.iam-form-section:last-child { border-bottom: 0; margin-bottom: 0; padding-bottom: 0; }
.iam-form-section-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text);
  margin: 0 0 var(--space-12);
}
.iam-field-error { font-size: 0.75rem; color: var(--color-error); margin-top: 4px; }
.iam-field-hint  { font-size: 0.75rem; color: var(--color-text-muted); margin-top: 4px; }
.iam-required::after { content: ' *'; color: var(--color-error); }
.iam-form-group-with-help { display: flex; align-items: flex-start; gap: var(--space-8); }
.iam-form-group-with-help .iam-help-trigger {
  flex-shrink: 0;
  color: var(--color-text-muted);
  cursor: help;
  padding: 4px;
}

/* Step-based wizard (visual only) */
.iam-wizard-steps {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: var(--space-24);
  flex-wrap: wrap;
}
.iam-wizard-step {
  display: flex;
  align-items: center;
  font-size: 0.875rem;
  color: var(--color-text-muted);
}
.iam-wizard-step.active { font-weight: 600; color: var(--color-primary); }
.iam-wizard-step.done { color: var(--color-success); }
.iam-wizard-step-num {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: var(--space-8);
}
.iam-wizard-step.active .iam-wizard-step-num { background: var(--color-primary-muted); border-color: var(--color-primary); color: var(--color-primary); }
.iam-wizard-step.done .iam-wizard-step-num { background: var(--color-success); border-color: var(--color-success); color: #fff; }
.iam-wizard-step + .iam-wizard-step::before {
  content: '';
  width: 2rem;
  height: 1px;
  background: var(--color-border);
  margin-right: var(--space-8);
}

/* Content tabs (panel navigation) — reuse tokens only */
.iam-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-24);
  flex-wrap: wrap;
}
.iam-tab {
  padding: var(--space-8) var(--space-16);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text-muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}
.iam-tab:hover { color: var(--color-text); }
.iam-tab.active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}

/* Table row actions: visible icons + vertical separators (no overflow/clipping in tbody) */
.iam-row-actions-inline {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0;
  vertical-align: middle;
}

.iam-row-actions-inline > * + * {
  border-left: 1px solid var(--color-border);
  margin-left: 0.35rem;
  padding-left: 0.45rem;
}

.iam-row-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text-muted);
  text-decoration: none;
  cursor: pointer;
  flex-shrink: 0;
  box-sizing: border-box;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.iam-row-action:hover:not(:disabled) {
  background: var(--color-surface);
  color: var(--color-primary);
}

.iam-row-action:focus {
  outline: none;
}

.iam-row-action:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.iam-row-action:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.iam-row-action--danger:hover:not(:disabled) {
  color: var(--color-error);
  background: rgba(239, 68, 68, 0.08);
}

.iam-row-action .bi {
  font-size: 1.125rem;
  line-height: 1;
}

/* Beat .iam-page-content a link color for icon action cells */
.iam-page-content a.iam-row-action {
  color: var(--color-text-muted);
}

.iam-page-content a.iam-row-action:hover {
  color: var(--color-primary);
}

.iam-page-content a.iam-row-action--danger:hover {
  color: var(--color-error);
}

/* Table cell truncation */
.iam-cell-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Form layout: two columns on wide screens */
.iam-form-grid {
  display: grid;
  gap: var(--space-24);
}
@media (min-width: 768px) {
  .iam-form-grid.iam-form-grid-2 { grid-template-columns: 1fr 1fr; }
}

/* Page footer actions (sticky optional) */
.iam-form-actions {
  display: flex;
  gap: var(--space-12);
  align-items: center;
  flex-wrap: wrap;
  margin-top: var(--space-24);
  padding-top: var(--space-24);
  border-top: 1px solid var(--color-border);
}

/* Paging bar */
.iam-paging {
  display: flex;
  align-items: center;
  gap: var(--space-12);
  margin-top: var(--space-16);
  padding-top: var(--space-16);
  border-top: 1px solid var(--color-border);
  font-size: 0.875rem;
  color: var(--color-text-muted);
}
.iam-paging .iam-paging-info { margin-right: auto; }

/* Permission tree (hierarchical) */
.iam-permission-tree {
  list-style: none;
  margin: 0;
  padding: 0;
}
.iam-permission-tree ul { list-style: none; margin: 0; padding-left: var(--space-24); border-left: 1px solid var(--color-border); margin-left: 0.5rem; }
.iam-permission-tree li { margin-bottom: var(--space-4); }
.iam-permission-tree-node {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  padding: var(--space-4) 0;
}
.iam-permission-tree-node input[type="checkbox"] { flex-shrink: 0; }
.iam-permission-tree-inherited { font-size: 0.75rem; color: var(--color-text-muted); margin-left: 1.5rem; }

/* Security status indicators (always pair with label or icon) */
.iam-status-success,
.iam-status-warning,
.iam-status-error,
.iam-status-info {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 8px;
  font-size: 0.75rem;
  font-weight: 500;
  border-radius: var(--radius-sm);
}
.iam-status-success { background: rgba(22, 163, 74, 0.15); color: var(--color-success); }
.iam-status-warning { background: rgba(245, 158, 11, 0.15); color: var(--color-warning); }
.iam-status-error   { background: rgba(239, 68, 68, 0.15); color: var(--color-error); }
.iam-status-info   { background: rgba(6, 182, 212, 0.15); color: var(--color-info); }
.iam-status-success .bi::before,
.iam-status-warning .bi::before,
.iam-status-error .bi::before,
.iam-status-info .bi::before { font-size: 0.875rem; }

/* Loading */
.loading {
  padding: 2rem;
  text-align: center;
  color: var(--color-text-muted);
}

/* Row actions (Edit | Secondary link pattern) */
.iam-row-actions {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  flex-wrap: wrap;
}
.iam-row-actions .iam-row-actions-sep {
  color: var(--color-border);
  font-size: 0.875rem;
  user-select: none;
}

/* Mobile nav overlay (below header, above main content) */
.iam-sidebar-overlay {
  display: none;
}

.iam-sidebar-overlay.is-open {
  display: none;
}

/* Shell: single visible page title (top bar); keep in-page heading for a11y */
.iam-shell-ref-dashboard .iam-page-header .iam-page-title,
.iam-shell-ref-dashboard .iam-page-header .ids-page-title {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Responsive */
@media (max-width: 768px) {
  .iam-mobile-nav-toggle {
    display: inline-flex;
  }

  .iam-mobile-nav-toggle--in-header {
    display: inline-flex;
  }

  .iam-header-org-switcher,
  .iam-header-search { display: none; }

  .iam-sidebar-overlay.is-open {
    display: block;
    position: fixed;
    left: 0;
    right: 0;
    top: var(--header-height);
    bottom: 0;
    z-index: 90;
    background: rgba(15, 23, 42, 0.45);
  }

  .iam-sidebar {
    position: fixed;
    left: 0;
    top: var(--header-height);
    bottom: 0;
    z-index: 100;
    transform: translateX(-100%);
    box-shadow: var(--shadow-lg);
  }
  .iam-sidebar.open {
    transform: translateX(0);
  }
  .iam-page-content { padding: var(--space-16); }
}
