/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/.pnpm/next@15.5.19_react-dom@19.2.7_react@19.2.7__react@19.2.7/node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!../../node_modules/.pnpm/next@15.5.19_react-dom@19.2.7_react@19.2.7__react@19.2.7/node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./app/styles.css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
:root {
  --background: #f4f6f8;
  --panel: #ffffff;
  --panel-muted: #eef2f4;
  --text: #182026;
  --muted: #5c6973;
  --line: #d8e0e5;
  --accent: #0f766e;
  --accent-dark: #134e4a;
  --warning: #9a5b13;
  --sidebar: #ffffff;
  --sidebar-text: #182026;
  --sidebar-muted: #5c6973;
  --sidebar-active: #e6fffa;
  --sidebar-hover: #eef2f4;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  background: var(--background);
  color: var(--text);
  font-family: Arial, Helvetica, sans-serif;
}

button,
input,
select,
textarea {
  font: inherit;
}

.admin-shell {
  display: grid;
  grid-template-columns: 248px minmax(0, 1fr);
  min-height: 100vh;
}

.sidebar {
  background: var(--sidebar);
  border-right: 1px solid var(--line);
  color: var(--sidebar-text);
  height: 100vh;
  overflow: auto;
  padding: 18px 14px;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
}

.brand {
  font-size: 18px;
  font-weight: 760;
  line-height: 1.2;
  margin-bottom: 18px;
}

.brand-text {
  display: block;
}

.org-pill {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  margin-bottom: 16px;
  padding: 10px;
}

.org-pill strong {
  display: block;
  font-size: 13px;
  line-height: 1.35;
}

.org-pill span {
  color: var(--muted);
  display: block;
  font-size: 12px;
  line-height: 1.4;
  margin-top: 2px;
}

.nav-groups {
  display: grid;
  grid-gap: 0;
  gap: 0;
  margin-top: 0;
}

.nav-groups-phone {
  display: none;
}

.nav-group h2 {
  color: var(--sidebar-muted);
  font-size: 11px;
  letter-spacing: 0;
  margin: 22px 10px 8px;
  text-transform: uppercase;
}

.nav-group:first-child h2 {
  margin-top: 0;
}

.nav-group ul {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-group a {
  align-items: center;
  border-radius: 6px;
  color: var(--sidebar-muted);
  display: flex;
  font-weight: 600;
  gap: 8px;
  min-height: 36px;
  padding: 8px 10px;
  text-decoration: none;
}

.nav-group a[aria-current="page"],
.nav-group a:hover {
  background: var(--sidebar-hover);
}

.nav-group a[aria-current="page"] {
  background: var(--sidebar-active);
  color: var(--accent);
}

.nav-icon {
  align-items: center;
  display: inline-flex;
  flex-shrink: 0;
  height: 16px;
  justify-content: center;
  opacity: 0.72;
  width: 16px;
}

.nav-group a[aria-current="page"] .nav-icon {
  opacity: 1;
}

.nav-icon svg {
  display: block;
  height: 16px;
  width: 16px;
}

.workspace {
  min-width: 0;
}

.topbar {
  align-items: center;
  background: var(--panel);
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: minmax(190px, 260px) minmax(260px, 1fr) 44px auto;
  min-height: 72px;
  padding: 14px 24px;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 2;
}

.organization-context {
  display: grid;
  grid-gap: 2px;
  gap: 2px;
  min-width: 0;
  overflow-wrap: anywhere;
}

.eyebrow {
  color: var(--muted);
  font-size: 12px;
  margin: 0;
  text-transform: uppercase;
}

.global-search input {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 10px;
  min-height: 42px;
  padding: 0 14px;
  width: 100%;
}

.icon-button,
.user-menu {
  align-items: center;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  display: inline-flex;
  min-height: 42px;
}

.icon-button {
  font-weight: 700;
  justify-content: center;
  width: 42px;
}

.user-menu {
  gap: 10px;
  padding: 0 8px 0 12px;
}

.sign-out-form {
  margin: 0;
}

.user-menu strong {
  align-items: center;
  background: var(--accent-dark);
  border-radius: 6px;
  color: white;
  display: inline-flex;
  height: 28px;
  justify-content: center;
  width: 28px;
}

.content {
  padding: 28px 24px 32px;
}

.dashboard {
  display: grid;
  grid-gap: 20px;
  gap: 20px;
}

.dashboard-header-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dashboard-kpi-grid {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.dashboard-kpi-grid .panel {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.dashboard-kpi-grid span {
  color: var(--muted);
  font-size: 13px;
}

.dashboard-kpi-grid strong {
  font-size: 30px;
  font-weight: 700;
}

.dashboard-kpi-grid p {
  color: var(--muted);
  font-size: 12px;
  margin: 0;
}

.dashboard-panels {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: 1.15fr 0.85fr;
  align-items: start;
}

.dashboard-readiness-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.dashboard-readiness-row {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 10px 12px;
}

.dashboard-readiness-row > div:first-child {
  display: grid;
  grid-gap: 3px;
  gap: 3px;
  min-width: 0;
}

.dashboard-readiness-row strong {
  font-size: 13px;
}

.dashboard-readiness-row > div:first-child > span {
  color: var(--muted);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.dashboard-readiness-row-end {
  align-items: center;
  display: flex;
  flex-shrink: 0;
  gap: 8px;
}

.page-header {
  align-items: center;
  display: flex;
  gap: 16px;
  justify-content: space-between;
  margin-bottom: 4px;
}

.page-header h1 {
  font-size: 30px;
  margin: 4px 0 0;
}

.app-page-header {
  align-items: flex-start;
  margin-bottom: 18px;
}

.app-page-header__content {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
  min-width: 0;
}

.app-page-header__actions {
  display: flex;
  flex-shrink: 0;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.app-section-card {
  padding: 20px;
}

.app-section-card__header {
  gap: 16px;
  margin-bottom: 16px;
}

.app-section-card__heading {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.app-section-card__badge {
  flex-shrink: 0;
}

.app-stat-card {
  align-content: start;
  min-height: 100%;
  padding: 18px;
}

.app-stat-card__label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.app-stat-card__value {
  font-size: 28px;
  line-height: 1.1;
}

.app-stat-card__hint {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.app-empty-state {
  align-items: center;
  background: linear-gradient(180deg, #fbfcfd 0%, #f5f8fa 100%);
  border: 1px dashed #c8d3da;
  border-radius: 12px;
  display: flex;
  gap: 16px;
  justify-content: space-between;
  min-height: 180px;
  padding: 24px;
}

.app-empty-state__body {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  max-width: 560px;
}

.app-empty-state__body strong {
  font-size: 24px;
  line-height: 1.2;
}

.app-empty-state__body p {
  color: var(--muted);
  margin: 0;
}

.app-empty-state__actions {
  display: flex;
  flex-shrink: 0;
  flex-wrap: wrap;
  gap: 8px;
}

.app-form-grid {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  grid-column: 1 / -1;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
}

.app-field {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.app-field__label {
  align-items: center;
  color: var(--muted);
  display: flex;
  font-size: 12px;
  font-weight: 650;
  gap: 8px;
  justify-content: space-between;
}

.app-field input,
.app-field select,
.app-field textarea {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  min-height: 40px;
  padding: 8px 10px;
  width: 100%;
}

.app-field textarea {
  min-height: 96px;
  resize: vertical;
}

.app-field__helper {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.app-form-actions {
  border-top: 1px solid var(--line);
  margin-top: 4px;
  padding-top: 16px;
}

.app-disclosure > summary {
  list-style: none;
}

.app-disclosure > summary::-webkit-details-marker {
  display: none;
}

.page-subtitle {
  color: var(--muted);
  margin: 6px 0 0;
  max-width: 820px;
}

.mobile-posture {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 8px;
  color: var(--warning);
  padding: 10px 12px;
}

.summary-grid {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.summary-grid > div,
.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
}

.summary-grid span,
.panel-header span {
  color: var(--muted);
  font-size: 13px;
}

.summary-grid strong {
  display: block;
  font-size: 34px;
  margin: 8px 0;
}

.summary-grid p {
  color: var(--muted);
  margin: 0;
}

.panel-header {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 12px;
}

.panel-header h2 {
  font-size: 18px;
  margin: 0;
}

.dependency-grid {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 14px;
}

.dependency-grid > div {
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  padding: 12px;
}

.dependency-grid p,
.setup-checklist-item p,
.failure-list small {
  color: var(--muted);
  margin: 0;
}

.dependency-grid a,
.setup-checklist-item a,
.secondary-link {
  color: var(--accent);
  font-weight: 600;
  text-decoration: none;
}

.setup-checklist {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.setup-checklist-item {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto auto;
  padding: 12px;
}

.failure-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.failure-list a {
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  display: grid;
  grid-gap: 4px;
  gap: 4px;
  padding: 12px;
  text-decoration: none;
}

table {
  border-collapse: collapse;
  width: 100%;
}

th,
td {
  border-bottom: 1px solid var(--line);
  padding: 12px 10px;
  text-align: left;
}

th {
  color: var(--muted);
  font-size: 13px;
}

.sr-only {
  clip: rect(0, 0, 0, 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.auth-page {
  align-items: center;
  display: grid;
  min-height: 100vh;
  padding: 24px;
}

.auth-panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  display: grid;
  grid-gap: 20px;
  gap: 20px;
  margin: 0 auto;
  max-width: 420px;
  padding: 28px;
  width: 100%;
}

.auth-panel__header {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.auth-panel h1 {
  font-size: 28px;
  margin: 4px 0 8px;
}

.auth-panel p:last-child {
  color: var(--muted);
  margin: 0;
}

.auth-form {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.auth-form label {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.auth-form span {
  color: var(--muted);
  font-size: 13px;
}

.auth-form input {
  border: 1px solid var(--line);
  border-radius: 10px;
  min-height: 44px;
  padding: 0 12px;
}

.auth-form button {
  background: var(--accent);
  border: 0;
  border-radius: 8px;
  color: white;
  min-height: 42px;
}

.settings-page,
.rbac-page,
.settings-form {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.status-strip {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 4px;
  gap: 4px;
  min-width: 220px;
  padding: 10px 12px;
}

.status-strip span,
.readonly-field span,
.settings-form label span {
  color: var(--muted);
  font-size: 13px;
}

.notice-success,
.notice-error,
.notice-action {
  border-radius: 8px;
  margin: 0;
  padding: 10px 12px;
}

.notice-success {
  background: #ecfdf5;
  border: 1px solid #a7f3d0;
  color: #047857;
}

.notice-error {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  color: var(--warning);
}

.notice-action {
  align-items: center;
  background: #eef6ff;
  border: 1px solid #bfdbfe;
  color: #1d4ed8;
  display: flex;
  gap: 12px;
  justify-content: space-between;
}

.settings-section {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.settings-grid {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.settings-grid-three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.binding-grid {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.binding-prerequisites {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  padding: 10px;
}

.binding-prerequisites span {
  color: var(--muted);
  font-size: 13px;
}

.binding-prerequisites ul {
  margin: 0;
  padding-left: 18px;
}

.binding-prerequisites li {
  line-height: 1.45;
}

.binding-actions {
  align-content: flex-start;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.binding-actions form {
  margin: 0;
}

.readiness-grid {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.readiness-summary,
.readiness-notice,
.readiness-actions,
.readiness-table-wrap,
.readiness-lists,
.readiness-history {
  min-width: 0;
}

.readiness-actions {
  align-content: flex-start;
  display: flex;
  justify-content: flex-end;
}

.readiness-table-wrap,
.readiness-lists,
.readiness-history {
  grid-column: 1 / -1;
}

.readiness-table {
  border-collapse: collapse;
  font-size: 13px;
  width: 100%;
}

.readiness-table th,
.readiness-table td {
  border-bottom: 1px solid var(--line);
  padding: 10px;
  text-align: left;
  vertical-align: top;
}

.readiness-table th {
  color: var(--muted);
  font-weight: 700;
}

.readiness-table td strong,
.readiness-table td small {
  display: block;
}

.readiness-lists {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.readiness-lists span,
.readiness-history span {
  color: var(--muted);
  display: block;
  font-size: 13px;
  margin-bottom: 6px;
}

.readiness-lists ul,
.readiness-history ul {
  margin: 0;
  padding-left: 18px;
}

.status-badge {
  border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex;
  font-size: 12px;
  font-weight: 700;
  padding: 3px 8px;
}

.status-passed {
  background: #ecfdf5;
  color: #047857;
}

.status-warning,
.status-stale,
.status-unknown {
  background: #fffbeb;
  color: #92400e;
}

.status-failed,
.status-blocked,
.status-unavailable {
  background: #fff7ed;
  color: var(--warning);
}

.status-violation,
.status-permission-denied {
  background: #fee2e2;
  color: #991b1b;
}

.button-link {
  align-items: center;
  background: var(--accent);
  border: 0;
  border-radius: 8px;
  color: white;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  min-height: 42px;
  padding: 8px 12px;
  text-decoration: none;
}

.button-link.secondary-action {
  background: var(--panel);
  border: 1px solid var(--line);
  color: var(--text);
}

.button-link:disabled {
  background: #f1f5f9;
  border: 1px solid var(--line);
  color: var(--muted);
  cursor: not-allowed;
}

.settings-form label,
.readonly-field {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.settings-form input,
.settings-form select,
.settings-form textarea {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  min-height: 42px;
  padding: 8px 10px;
  width: 100%;
}

.settings-form textarea {
  min-height: 104px;
  resize: vertical;
}

.readonly-field {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 8px;
  min-height: 74px;
  padding: 10px;
}

.readonly-field small {
  color: var(--warning);
}

.toggle-row {
  align-items: center;
  display: flex !important;
  gap: 10px;
}

.toggle-row input {
  width: auto;
}

.form-actions {
  display: flex;
  justify-content: flex-end;
}

.form-actions button {
  background: var(--accent);
  border: 0;
  border-radius: 8px;
  color: white;
  min-height: 42px;
  padding: 0 16px;
}

.rbac-summary,
.rbac-matrix {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.role-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.role-chip-row span {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text);
  font-size: 13px;
  padding: 5px 10px;
}

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

.rbac-matrix td:first-child {
  min-width: 260px;
}

.rbac-matrix td small {
  color: var(--muted);
  display: block;
  margin-top: 4px;
  white-space: normal;
}

.permission-denied p {
  margin: 0;
}

.muted-line {
  color: var(--muted);
}

.action-feedback {
  border-color: #fca5a5;
  background: #fff1f2;
  color: #7f1d1d;
}

.action-feedback span {
  display: block;
  margin-top: 4px;
}

.preview-box {
  background: #f0f9ff;
  border: 1px solid #bae6fd;
  border-radius: 6px;
  color: var(--text);
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  padding: 12px;
}

.preview-box small {
  color: var(--muted);
}

.users-access-page {
  align-items: stretch;
}

.users-header-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.user-filter-toolbar {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  padding: 12px 20px;
  border-bottom: 1px solid var(--line);
}

.user-filter-toolbar input,
.user-filter-toolbar select {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 6px 10px;
  font-size: 13px;
  background: var(--bg);
  color: var(--text);
  height: 34px;
}

.user-filter-toolbar input {
  min-width: 220px;
}

.user-filter-toolbar button {
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 6px 14px;
  font-size: 13px;
  cursor: pointer;
  height: 34px;
}

.user-filter-toolbar a {
  color: var(--muted);
  font-size: 13px;
  text-decoration: underline;
}

.users-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 16px;
  gap: 16px;
}

.access-tabs {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px;
}

.access-tabs a {
  border-radius: 6px;
  color: var(--text);
  font-weight: 700;
  padding: 8px 10px;
  text-decoration: none;
}

.access-tabs a:hover {
  background: var(--panel-muted);
}

.access-form {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.devices-page,
.inventory-panel {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.inventory-panel {
  padding: 0;
}

.inventory-panel > .panel-header {
  border-bottom: 1px solid var(--line);
  margin: 0;
  padding: 14px 16px;
}

.inventory-header-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.inventory-export-link,
.inventory-sync-form button {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  cursor: pointer;
  font-weight: 700;
  min-height: 34px;
  padding: 8px 12px;
  text-decoration: none;
}

.inventory-sync-form {
  margin: 0;
}

.inventory-toolbar {
  align-items: start;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr);
  padding: 12px 14px 0;
}

.inventory-filter-form {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  grid-template-columns: minmax(240px, 2fr) repeat(auto-fit, minmax(126px, 1fr));
}

.inventory-filter-form label {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
  min-width: 0;
}

.inventory-filter-form label span {
  color: var(--muted);
  font-size: 12px;
}

.inventory-filter-form input {
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  min-height: 34px;
  padding: 7px 8px;
  width: 100%;
}

.inventory-filter-wide {
  grid-column: auto;
}

.inventory-filter-search input {
  background: var(--panel);
}

.inventory-filter-actions {
  align-items: end;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.inventory-filter-actions button,
.inventory-filter-actions a,
.inventory-empty a {
  background: var(--accent);
  border: 0;
  border-radius: 6px;
  color: white;
  min-height: 34px;
  padding: 8px 12px;
  text-decoration: none;
}

.inventory-filter-actions a {
  background: var(--panel);
  border: 1px solid var(--line);
  color: var(--text);
}

.inventory-advanced-filters {
  border: 1px solid var(--line);
  border-radius: 8px;
  grid-column: 1 / -1;
}

.inventory-advanced-filters summary {
  color: var(--text);
  cursor: pointer;
  font-weight: 700;
  list-style-position: inside;
  padding: 9px 10px;
}

.inventory-advanced-grid {
  border-top: 1px solid var(--line);
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  grid-template-columns: repeat(5, minmax(130px, 1fr));
  padding: 10px;
}

.inventory-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.inventory-filter-chips a {
  align-items: center;
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text);
  display: inline-flex;
  gap: 6px;
  min-height: 32px;
  padding: 6px 10px;
  text-decoration: none;
}

.inventory-filter-chips span {
  color: var(--muted);
}

.inventory-filter-chips strong {
  font-weight: 600;
}

.inventory-selection-toolbar {
  align-items: center;
  background: #e8f1ff;
  border-bottom: 1px solid #c7dcff;
  border-top: 1px solid #c7dcff;
  display: flex;
  justify-content: space-between;
  min-height: 42px;
  padding: 10px 14px;
}

.inventory-selection-actions {
  align-items: center;
  display: flex;
  gap: 8px;
}

.inventory-selection-toolbar button {
  background: white;
  border: 1px solid #c7dcff;
  border-radius: 6px;
  color: var(--text);
  font-weight: 600;
  min-height: 34px;
  padding: 6px 12px;
}

.inventory-selection-toolbar .primary-link-button {
  font-size: 14px;
  min-height: 34px;
  padding: 6px 12px;
}

.inventory-empty {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 8px;
  margin: 0 14px;
  padding: 18px;
}

.inventory-empty p {
  color: var(--muted);
  margin-bottom: 12px;
}

.inventory-table-wrap {
  border: 1px solid var(--line);
  border-radius: 8px;
  margin: 0 14px;
  max-width: 100%;
  overflow-x: auto;
}

.inventory-table {
  border-collapse: collapse;
  min-width: 1180px;
  width: 100%;
}

.inventory-table th {
  background: #fafbfc;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 1;
}

.inventory-table th,
.inventory-table td {
  border-bottom: 1px solid var(--line);
  padding: 11px 12px;
  text-align: left;
  vertical-align: middle;
}

.inventory-table th {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.inventory-table tbody tr:last-child td {
  border-bottom: 0;
}

.inventory-table tbody tr:hover {
  background: var(--panel-muted);
}

.inventory-table tbody tr.selected {
  background: #eff6ff;
}

.inventory-primary-cell,
.inventory-stacked-cell {
  display: grid;
  grid-gap: 3px;
  gap: 3px;
  min-width: 0;
}

.inventory-primary-cell strong,
.inventory-stacked-cell strong {
  color: var(--text);
  font-size: 13px;
  line-height: 1.25;
}

.inventory-primary-cell span,
.inventory-stacked-cell span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.inventory-sensitive-note {
  color: var(--muted);
  font-size: 12px;
  padding: 0 14px 2px;
}

.inventory-pagination {
  align-items: center;
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: space-between;
  padding: 0 14px 14px;
}

.inventory-page-size,
.inventory-page-links {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.inventory-page-size a,
.inventory-page-links a {
  align-items: center;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text);
  display: inline-flex;
  font-weight: 700;
  justify-content: center;
  min-height: 32px;
  min-width: 32px;
  padding: 6px 10px;
  text-decoration: none;
}

.inventory-page-size a.active,
.inventory-page-links a.active {
  background: var(--accent);
  border-color: var(--accent);
  color: white;
}

.table-action-button {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--accent);
  min-height: 32px;
  padding: 6px 10px;
}

.device-detail-drawer {
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 14px;
  gap: 14px;
  padding: 14px;
}

.device-detail-drawer .panel-header button {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  min-height: 34px;
  padding: 8px 12px;
}

.device-detail-summary,
.device-evidence-grid {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.device-detail-summary div,
.device-evidence-field {
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  padding: 10px;
}

.device-detail-summary span,
.device-evidence-field span:first-child,
.device-evidence-field small,
.device-timeline span,
.muted-line {
  color: var(--muted);
}

.secondary-link {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--accent);
  display: inline-flex;
  min-height: 34px;
  padding: 8px 12px;
  text-decoration: none;
}

.device-detail-page {
  align-content: start;
}

.device-detail-panel {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.device-detail-tabs {
  border-bottom: 1px solid var(--line);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-bottom: 10px;
}

.device-detail-tabs a {
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  min-height: 34px;
  padding: 8px 12px;
  text-decoration: none;
}

.device-detail-section {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.device-detail-section h2 {
  font-size: 18px;
  margin: 0;
}

.lifecycle-control {
  align-items: end;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  grid-template-columns: minmax(160px, 220px) minmax(220px, 1fr) auto;
  padding: 12px;
}

.lifecycle-control label {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.lifecycle-control label span {
  color: var(--muted);
  font-size: 13px;
}

.lifecycle-control input,
.lifecycle-control select {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  min-height: 38px;
  padding: 8px 10px;
}

.lifecycle-control button {
  background: var(--accent);
  border: 0;
  border-radius: 8px;
  color: #ffffff;
  min-height: 38px;
  padding: 8px 12px;
}

.lifecycle-control button:disabled,
.lifecycle-control input:disabled,
.lifecycle-control select:disabled {
  opacity: 0.62;
}

.form-error {
  color: #b91c1c;
  grid-column: 1 / -1;
  margin: 0;
}

.device-timeline {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  list-style-position: inside;
  margin: 0;
  padding: 0;
}

.device-timeline li {
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  grid-template-columns: auto minmax(0, 1fr);
  padding: 10px;
}

.device-timeline p {
  margin: 4px 0;
}

.audit-reference-table {
  min-width: 720px;
}

.device-applications-section {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.application-status-table-wrap {
  overflow-x: auto;
}

.application-status-table {
  min-width: 1120px;
}

.application-status-table th,
.application-status-table td {
  vertical-align: top;
}

.device-command-catalog {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.command-history-wrap {
  overflow-x: auto;
}

.command-history-table {
  min-width: 980px;
}

.command-history-table th,
.command-history-table td {
  vertical-align: top;
}

.command-history-table td:first-child {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.command-history-table td:first-child span,
.command-history-table td:nth-child(2) span,
.command-history-table td:nth-child(6) span {
  display: block;
}

.command-attempt-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  margin: 8px 0 0;
  padding: 0;
  list-style: none;
  min-width: 220px;
}

.command-attempt-list li {
  display: grid;
  grid-gap: 3px;
  gap: 3px;
  padding: 8px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface-muted);
}

.command-attempt-list li > div {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

.command-attempt-list span {
  overflow-wrap: anywhere;
}

.command-retry-form {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  max-width: 260px;
}

.command-retry-form label {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
  font-weight: 650;
}

.command-retry-form input:not([type="checkbox"]) {
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 10px;
  min-width: 0;
}

.command-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  grid-gap: 12px;
  gap: 12px;
}

.command-card {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  background: #fff;
}

.command-card > div:first-child {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.command-card label {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
  font-weight: 650;
}

.command-card input:not([type="checkbox"]) {
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 10px;
  min-width: 0;
}

.checkbox-row {
  display: flex !important;
  grid-template-columns: none !important;
  align-items: center;
  gap: 8px;
}

.checkbox-row input {
  inline-size: 16px;
  block-size: 16px;
}

.policy-option-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  max-block-size: 280px;
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px;
  background: #fff;
}

.policy-option-row {
  display: grid !important;
  grid-template-columns: 18px minmax(0, 1fr) !important;
  align-items: center;
  grid-gap: 10px;
  gap: 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 10px;
  background: #F9FAFB;
}

.policy-option-row input {
  inline-size: 16px;
  block-size: 16px;
}

.policy-option-row span {
  display: grid;
  grid-gap: 2px;
  gap: 2px;
}

.policy-option-row small {
  color: var(--muted);
  font-weight: 500;
}

.command-result {
  border: 1px solid #BFDBFE;
  background: #EFF6FF;
  color: #1D4ED8;
  border-radius: 6px;
  padding: 8px 10px;
  font-weight: 650;
}

.application-status-table td:nth-child(2),
.application-status-table td:nth-child(10) {
  white-space: normal;
}

.application-row-not-installed,
.application-row-version-mismatch,
.application-row-install-failed,
.application-row-blocked,
.application-row-unknown-stale {
  background: #fff7ed;
}

.users-grid {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.users-grid label,
.inline-access-form,
.role-checkboxes {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.users-grid input,
.users-grid textarea,
.inline-access-form textarea {
  border: 1px solid var(--line);
  border-radius: 8px;
  min-height: 42px;
  padding: 8px 10px;
  width: 100%;
}

.users-grid textarea,
.inline-access-form textarea {
  min-height: 72px;
  resize: vertical;
}

.wide-field {
  grid-column: 1 / -1;
}

.role-checkboxes {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
}

.role-checkboxes legend {
  color: var(--muted);
  font-size: 13px;
  padding: 0 4px;
}

.role-checkboxes label {
  align-items: center;
  display: inline-flex;
  gap: 8px;
  margin-right: 14px;
}

.role-checkboxes input,
.inline-access-form input[type="checkbox"] {
  width: auto;
}

.inline-action-form,
.inline-access-form {
  margin: 6px 0;
}

.inline-access-form {
  border-top: 1px solid var(--line);
  padding-top: 10px;
}

.inline-action-form button,
.inline-access-form button,
.users-grid button {
  background: var(--accent);
  border: 0;
  border-radius: 8px;
  color: white;
  min-height: 36px;
  padding: 0 12px;
}

details summary {
  cursor: pointer;
  font-weight: 700;
}

@media (max-width: 1279px) {
  .admin-shell {
    grid-template-columns: 224px minmax(0, 1fr);
  }

  .topbar {
    grid-template-columns: minmax(170px, 220px) minmax(220px, 1fr) 42px auto;
    padding-inline: 18px;
  }
}

@media (max-width: 1023px) {
  .admin-shell {
    grid-template-columns: 76px minmax(0, 1fr);
  }

  .sidebar {
    padding-inline: 12px;
  }

  .brand,
  .org-pill,
  .nav-group h2,
  .nav-group a span:last-child {
    display: none;
  }

  .nav-group a {
    justify-content: center;
    padding-inline: 0;
  }

  .topbar {
    grid-template-columns: minmax(150px, 1fr) 42px auto;
  }

  .global-search {
    display: none;
  }

  .summary-grid {
    grid-template-columns: 1fr;
  }

  .settings-grid,
  .settings-grid-three,
  .readiness-grid,
  .readiness-lists,
  .dependency-grid,
  .inventory-toolbar,
  .inventory-filter-form,
  .inventory-advanced-grid,
  .users-grid {
    grid-template-columns: 1fr;
  }

  .inventory-filter-wide {
    grid-column: auto;
  }

  .readiness-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 767px) {
  .admin-shell {
    display: block;
  }

  .sidebar {
    min-height: auto;
    overflow-x: auto;
    padding: 10px 12px;
    position: static;
  }

  .brand {
    display: none;
  }

  .nav-groups {
    display: flex;
    gap: 14px;
    margin: 0;
  }

  .nav-groups-primary {
    display: none;
  }

  .nav-groups-phone {
    display: block;
  }

  .nav-group ul {
    display: flex;
  }

  .topbar {
    grid-template-columns: 1fr 42px;
    min-height: 64px;
    padding: 10px 12px;
    position: -webkit-sticky;
    position: sticky;
  }

  .user-menu span {
    display: none;
  }

  .content {
    padding: 16px 12px;
  }

  .page-header {
    align-items: flex-start;
    display: grid;
    grid-gap: 12px;
    gap: 12px;
  }

  .page-header h1 {
    font-size: 24px;
  }

  .panel {
    overflow-x: auto;
  }

  .binding-grid {
    grid-template-columns: 1fr;
  }

  .setup-checklist-item {
    align-items: start;
    grid-template-columns: 1fr;
  }
}

.groups-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.groups-create-section,
.groups-list-section {
  overflow: hidden;
}

.group-create-dialog summary,
.group-archive-confirm summary {
  align-items: center;
  background: var(--accent);
  border-radius: 8px;
  color: white;
  cursor: pointer;
  display: inline-flex;
  font-weight: 700;
  min-height: 38px;
  padding: 8px 12px;
}

.group-dialog-panel {
  border-top: 1px solid var(--line);
  display: grid;
  grid-gap: 14px;
  gap: 14px;
  margin-top: 14px;
  padding-top: 14px;
}

.group-form {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(220px, 1fr) auto;
  grid-gap: 12px;
  gap: 12px;
  align-items: end;
}

.group-form label,
.group-row-form {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.group-form span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
}

.group-form input,
.group-form select,
.group-row-form input {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
  background: var(--panel);
  color: var(--text);
}

.group-form small {
  color: var(--muted);
}

.groups-table-wrap {
  overflow-x: auto;
}

.groups-table {
  width: 100%;
  min-width: 860px;
  border-collapse: collapse;
  font-size: 14px;
}

.groups-table th,
.groups-table td {
  border-top: 1px solid var(--line);
  padding: 10px 12px;
  text-align: left;
  vertical-align: top;
}

.groups-table th {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  background: var(--panel);
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
}

.groups-table td strong,
.groups-table td small {
  display: block;
}

.groups-table td small {
  margin-top: 4px;
  color: var(--muted);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 12px;
}

.group-row-form {
  grid-template-columns: minmax(120px, 1fr) minmax(140px, 1fr) auto;
  margin-bottom: 8px;
}

.group-inline-action {
  align-items: center;
  display: inline-flex;
  gap: 8px;
  margin-top: 8px;
}

.group-manage-members,
.secondary-link {
  color: var(--accent);
  display: inline-flex;
  font-weight: 700;
  margin-top: 6px;
  text-decoration: none;
}

.membership-section {
  overflow: hidden;
}

.membership-action-form {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.membership-toolbar {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.membership-toolbar select {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  min-height: 38px;
  padding: 8px 10px;
}

.membership-table {
  min-width: 720px;
}

.membership-conflicts {
  color: var(--warning);
  margin: 0;
  padding-left: 18px;
}

.group-inline-action span {
  color: var(--muted);
  font-size: 12px;
}

.group-archive-confirm summary {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  color: var(--warning);
  margin-top: 6px;
  min-height: 34px;
  padding: 6px 10px;
}

.enrollment-section-label span,
.enrollment-card-main small,
.enrollment-card-meta {
  color: var(--muted);
}

.enrollment-create-section {
  overflow: hidden;
}
.enrollment-create-section .enrollment-create-form {
  width: 100%;
  grid-column: 1 / -1;
  display: block;
}

.enrollment-create-section .MuiCardContent-root {
  width: 100%;
}
.application-overview-grid {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 16px;
}

.application-stat-card {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  padding: 14px 16px;
}

.application-stat-card span,
.application-stat-card small {
  color: var(--muted);
  font-size: 12px;
}

.application-stat-card > span {
  font-weight: 650;
  text-transform: uppercase;
}

.application-stat-card strong {
  font-size: 22px;
  line-height: 1.1;
}

.application-workflow-grid {
  margin-bottom: 16px;
}

.applications-header-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.application-workflow-card {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  padding: 14px 16px;
}

.application-workflow-card strong {
  font-size: 14px;
}

.application-workflow-card span,
.application-workflow-card small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.application-upload-heading {
  align-items: start;
  display: flex;
  gap: 12px;
  justify-content: space-between;
}

.application-upload-heading h3 {
  font-size: 15px;
  margin: 0;
}

.application-upload-heading p {
  color: var(--muted);
  font-size: 12px;
  margin: 4px 0 0;
}

.application-title-cell {
  align-items: center;
  display: flex;
  gap: 10px;
  min-width: 220px;
}

.application-avatar {
  align-items: center;
  background: var(--panel-muted);
  block-size: 34px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 11px;
  font-weight: 750;
  inline-size: 34px;
  justify-content: center;
}

.application-source-badge {
  border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex;
  font-size: 11px;
  font-weight: 650;
  padding: 3px 8px;
  white-space: nowrap;
}

.application-source-play-public {
  background: #ecfdf5;
  border-color: #a7f3d0;
  color: #14532d;
}

.application-source-play-private {
  background: #eef2ff;
  border-color: #c7d2fe;
  color: #312e81;
}

.application-source-uploaded {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #7c2d12;
}

.application-source-unknown {
  background: var(--panel-muted);
  color: var(--muted);
}

.application-action-stack {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  min-width: 220px;
}

.application-action-stack form {
  align-items: center;
  display: flex;
  gap: 6px;
}

.application-action-stack input[type="text"] {
  border: 1px solid var(--line);
  border-radius: 6px;
  font: inherit;
  inline-size: 150px;
  padding: 7px 8px;
}

.application-action-stack button {
  white-space: nowrap;
}

.enrollment-overview-grid {
  display: grid;
  align-items: stretch;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 16px;
}

.enrollment-stat-card {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  padding: 14px 16px;
}

.enrollment-stat-card span,
.enrollment-stat-card small {
  color: var(--muted);
  font-size: 12px;
}

.enrollment-stat-card > span {
  font-weight: 650;
  text-transform: uppercase;
}

.enrollment-stat-card strong {
  font-size: 22px;
  line-height: 1.1;
}

.enrollment-readiness-grid {
  margin-bottom: 16px;
}

.enrollment-readiness-panel {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.enrollment-readiness-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.enrollment-readiness-row {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 10px 12px;
}

.enrollment-readiness-row div {
  display: grid;
  grid-gap: 3px;
  gap: 3px;
  min-width: 0;
}

.enrollment-readiness-row strong {
  font-size: 13px;
}

.enrollment-readiness-row span:not(.status-badge) {
  color: var(--muted);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.enrollment-create-form {
  align-items: start;
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
}

.enrollment-create-form label {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.enrollment-create-form span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
}

.enrollment-create-form input,
.enrollment-create-form select {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  min-height: 38px;
  padding: 8px 10px;
}

.enrollment-create-form small {
  color: var(--muted);
}

.enrollment-form-note {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 4px;
  gap: 4px;
  grid-column: 1 / -1;
  padding: 12px;
}

.enrollment-form-note strong {
  font-size: 13px;
}

.enrollment-form-note span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 500;
}

.enrollment-config-section {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.enrollment-section-label {
  align-items: baseline;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 12px;
  text-transform: uppercase;
}

.enrollment-section-label span {
  font-weight: 400;
  text-transform: none;
}

.enrollment-card-list {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.enrollment-config-card {
  align-items: flex-start;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  display: flex;
  gap: 14px;
  justify-content: space-between;
  min-width: 0;
  padding: 18px;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}

.enrollment-config-card:hover {
  border-color: #c4d0d8;
  box-shadow: 0 10px 24px rgba(24, 32, 38, 0.04);
}

.enrollment-card-main {
  display: grid;
  flex: 1 1;
  grid-gap: 6px;
  gap: 6px;
  min-width: 0;
}

.enrollment-card-title,
.enrollment-card-meta,
.enrollment-card-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.enrollment-card-title > strong {
  font-size: 16px;
  overflow-wrap: anywhere;
}

.enrollment-card-meta {
  font-size: 12px;
  gap: 12px;
}

.enrollment-card-main small {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 12px;
  overflow-wrap: anywhere;
}

.enrollment-card-summary {
  color: var(--muted);
}

.enrollment-token-progress {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 999px;
  block-size: 8px;
  inline-size: min(320px, 100%);
  overflow: hidden;
}

.enrollment-token-progress span {
  background: var(--accent);
  block-size: 100%;
  display: block;
}

.enrollment-type-badge {
  border-radius: 999px;
  border: 1px solid var(--line);
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
}

.enrollment-type-qr {
  background: #ecfdf5;
  border-color: #a7f3d0;
  color: #14532d;
}

.enrollment-type-zero_touch {
  background: #eef2ff;
  border-color: #c7d2fe;
  color: #312e81;
}

.enrollment-card-actions {
  align-items: flex-start;
  column-gap: 10px;
  row-gap: 10px;
  flex-direction: column;
  justify-content: flex-end;
}

.enrollment-card-button,
.enrollment-action-details summary {
  align-items: center;
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  cursor: pointer;
  display: inline-flex;
  font-size: 13px;
  font-weight: 700;
  min-height: 34px;
  padding: 6px 10px;
  text-decoration: none;
}

.enrollment-artifact-panel {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 10px;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  margin-top: 8px;
  padding: 12px;
}

.enrollment-artifact-panel button,
.enrollment-create-form button {
  background: var(--accent);
  border: 0;
  border-radius: 8px;
  color: white;
  font-weight: 700;
  min-height: 36px;
  padding: 7px 12px;
}

.enrollment-create-form button:disabled {
  opacity: 0.55;
}

.enrollment-artifact-panel {
  min-width: min(420px, calc(100vw - 64px));
}

.enrollment-artifact-panel form {
  margin: 0;
}

.enrollment-artifact-panel a {
  color: var(--accent);
  font-weight: 700;
  text-decoration: none;
}

.enrollment-artifact-panel pre {
  background: #172026;
  border: 1px solid #334155;
  border-radius: 8px;
  color: #eef4f4;
  max-height: 260px;
  overflow: auto;
  padding: 12px;
  white-space: pre-wrap;
  word-break: break-word;
}

.enrollment-qr-preview {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.enrollment-qr-preview img {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
}

.status-active {
  background: #ecfdf5;
  color: #047857;
}

.status-archived {
  background: #fffbeb;
  color: #92400e;
}

.status-pending,
.status-pending_review {
  background: #eff6ff;
  color: #1d4ed8;
}

.status-retired,
.status-decommissioned {
  background: #f3f4f6;
  color: #4b5563;
}

.status-lost {
  background: #fef2f2;
  color: #b91c1c;
}

.policies-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.policy-header-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.primary-link-button {
  align-items: center;
  background: var(--accent);
  border-radius: 6px;
  color: white;
  display: inline-flex;
  font-weight: 700;
  min-height: 38px;
  padding: 8px 12px;
  text-decoration: none;
}

.policies-filter-section,
.policies-list-section,
.policy-create-section,
.policy-summary-section,
.policy-blocked-section {
  overflow: hidden;
}

.policy-template-strip {
  align-items: center;
  background: #f5f3ff;
  border: 1px solid #ddd6fe;
  border-radius: 8px;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 14px 16px;
}

.policy-template-strip strong {
  color: #4c1d95;
  display: block;
  font-size: 13px;
}

.policy-template-strip span {
  color: #6d28d9;
  font-size: 12px;
}

.policy-template-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.policy-template-actions span {
  background: #fff;
  border: 1px solid #ddd6fe;
  border-radius: 6px;
  color: #7c3aed;
  font-weight: 600;
  padding: 6px 10px;
}

.policy-tab-radio {
  opacity: 0;
  pointer-events: none;
  position: absolute;
}

.policy-section-tabs {
  align-self: start;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  overflow: hidden;
}

.policy-section-tabs label {
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  cursor: pointer;
  font-size: 13px;
  font-weight: 650;
  line-height: 1.35;
  min-height: 40px;
  padding: 9px 12px;
}

.policy-section-tabs label:last-child {
  border-bottom: 0;
}

#policy-tab-basic:checked ~ .policy-builder-layout .policy-section-tabs label[for="policy-tab-basic"],
#policy-tab-security:checked ~ .policy-builder-layout .policy-section-tabs label[for="policy-tab-security"],
#policy-tab-restrictions:checked ~ .policy-builder-layout .policy-section-tabs label[for="policy-tab-restrictions"],
#policy-tab-apps:checked ~ .policy-builder-layout .policy-section-tabs label[for="policy-tab-apps"],
#policy-tab-network:checked ~ .policy-builder-layout .policy-section-tabs label[for="policy-tab-network"],
#policy-tab-configuration:checked ~ .policy-builder-layout .policy-section-tabs label[for="policy-tab-configuration"] {
  background: #ecfdf5;
  color: var(--accent);
}

.policy-tab-panels {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.policy-tab-panel {
  display: none;
}

#policy-tab-basic:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-basic,
#policy-tab-security:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-security,
#policy-tab-restrictions:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-restrictions,
#policy-tab-apps:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-apps,
#policy-tab-network:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-network,
#policy-tab-configuration:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-configuration {
  display: grid;
}

.policy-filter-form,
.policy-create-form {
  align-items: end;
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.policy-filter-form {
  grid-template-columns: minmax(180px, 1fr) minmax(180px, 240px) auto auto;
}

.policy-create-form {
  grid-template-columns: minmax(220px, 1fr) minmax(220px, 1fr);
}

.policy-filter-form label,
.policy-create-form label {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.policy-filter-form span,
.policy-create-form span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
}

.policy-filter-form input,
.policy-filter-form select,
.policy-create-form input,
.policy-create-form select {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  min-height: 38px;
  padding: 8px 10px;
}

.policy-create-form small {
  color: var(--muted);
}

.policy-form-actions {
  align-items: center;
  display: flex;
  gap: 10px;
  grid-column: 1 / -1;
  justify-content: flex-end;
}

.policies-table-wrap {
  overflow-x: auto;
}

.policies-table {
  border-collapse: collapse;
  font-size: 14px;
  min-width: 820px;
  width: 100%;
}

.policies-table th,
.policies-table td {
  border-top: 1px solid var(--line);
  padding: 10px 12px;
  text-align: left;
  vertical-align: top;
}

.policies-table th {
  background: var(--panel);
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
}

.policies-table td strong,
.policies-table td small {
  display: block;
}

.policies-table td small {
  color: var(--muted);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 12px;
  margin-top: 4px;
}

.policy-row-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.policies-guidance-section {
  overflow: hidden;
}

.policies-guidance-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.policy-guidance-row {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 10px 12px;
}

.policy-guidance-row div {
  display: grid;
  grid-gap: 3px;
  gap: 3px;
  min-width: 0;
}

.policy-guidance-row strong {
  font-size: 13px;
}

.policy-guidance-row span:not(.status-badge) {
  color: var(--muted);
  font-size: 12px;
}

.policy-summary-grid {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  grid-template-columns: repeat(4, minmax(150px, 1fr));
}

.policy-summary-grid div {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  padding: 12px;
}

.policy-summary-grid strong {
  color: var(--muted);
  font-size: 12px;
}

.policy-validation-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.policy-validation-list li {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 4px;
  gap: 4px;
  padding: 10px 12px;
}

.policy-validation-list strong {
  color: var(--text);
  font-size: 13px;
}

.policy-validation-list span {
  color: var(--muted);
  font-size: 13px;
}

.policy-field-validation-list {
  border-left: 3px solid #dc2626;
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  list-style: none;
  margin: 0;
  padding: 0 0 0 12px;
}

.policy-field-validation-list li {
  display: grid;
  grid-gap: 2px;
  gap: 2px;
}

.policy-field-validation-list strong {
  color: #991b1b;
  font-size: 12px;
}

.policy-field-validation-list span {
  color: var(--text);
  font-size: 13px;
}

.policy-builder-shell {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: 1fr;
}

.policy-builder-menu {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
}

.policy-builder-menu span {
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  display: block;
  font-weight: 650;
  padding: 10px 12px;
}

.policy-builder-menu span.active {
  background: #ecfdf5;
  color: var(--accent);
}

.policy-shell-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.policy-publish-confirmation {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  display: flex;
  flex-basis: 100%;
  font-size: 13px;
  gap: 8px;
  padding: 10px 12px;
}

.policy-publish-confirmation input {
  flex: 0 0 auto;
}

.policy-shell-actions button:disabled {
  background: #f1f5f9;
  border: 1px solid var(--line);
  color: var(--muted);
  cursor: not-allowed;
}

.policy-builder-form {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.policy-builder-layout {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: 190px minmax(0, 1fr);
}

.policy-builder-section {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  padding: 16px;
  scroll-margin-top: 18px;
}

.policy-builder-section:first-of-type {
  border-top: 1px solid var(--line);
  padding-top: 16px;
}

.policy-builder-form .policy-tab-panel {
  display: none;
}

#policy-tab-basic:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-basic,
#policy-tab-security:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-security,
#policy-tab-restrictions:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-restrictions,
#policy-tab-apps:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-apps,
#policy-tab-network:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-network,
#policy-tab-configuration:checked ~ .policy-builder-layout .policy-tab-panels .policy-panel-configuration {
  display: grid;
}

.policy-builder-grid {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.policy-builder-grid label,
.policy-fieldset {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.policy-builder-grid span,
.policy-fieldset legend {
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
}

.policy-builder-grid input,
.policy-builder-grid select,
.policy-builder-grid textarea {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  min-height: 38px;
  padding: 8px 10px;
  width: 100%;
}

.policy-builder-grid textarea {
  min-height: 84px;
  resize: vertical;
}

.policy-builder-grid small {
  color: var(--muted);
}

.policy-app-management {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.policy-app-block {
  border-top: 1px solid var(--line);
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  padding-top: 16px;
}

.policy-app-block:first-child {
  border-top: 0;
  padding-top: 0;
}

.policy-app-block-title {
  color: var(--muted);
  font-size: 12px;
  font-weight: 750;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.policy-app-source-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.policy-source-option {
  align-items: flex-start;
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 6px;
  cursor: pointer;
  display: flex;
  gap: 10px;
  padding: 10px 12px;
}

.policy-source-option input {
  margin-top: 2px;
}

.policy-source-option span {
  display: grid;
  grid-gap: 3px;
  gap: 3px;
}

.policy-source-option strong {
  align-items: center;
  color: var(--text);
  display: flex;
  flex-wrap: wrap;
  font-size: 13px;
  gap: 6px;
}

.policy-source-option em {
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 4px;
  color: #1d4ed8;
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
  padding: 1px 5px;
  text-transform: uppercase;
}

.policy-source-option small {
  color: var(--muted);
  font-size: 12px;
}

.policy-source-option.unavailable {
  cursor: not-allowed;
  opacity: 0.68;
}

.policy-app-entry {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  padding: 12px;
}

.policy-app-entry-header {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.policy-app-entry-header strong {
  color: var(--text);
  font-size: 13px;
}

.policy-toggle-grid {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.policy-toggle-grid label,
.policy-fieldset label {
  align-items: center;
  display: flex;
  gap: 8px;
}

.policy-toggle-grid input,
.policy-fieldset input {
  width: auto;
}

.policy-fieldset {
  border: 1px solid var(--line);
  border-radius: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: 10px;
}

.policy-builder-menu small {
  color: inherit;
  display: block;
  font-size: 11px;
  font-weight: 500;
  margin-top: 2px;
}

.status-draft,
.status-validation_error,
.status-unknown {
  background: #ede9fe;
  color: #6d28d9;
}

.status-published {
  background: #dcfce7;
  color: #15803d;
}

.status-blocked,
.status-failed,
.status-disconnected,
.status-not_started {
  background: #fee2e2;
  color: #b91c1c;
}

@media (max-width: 767px) {
  .group-form,
  .group-row-form,
  .enrollment-create-form,
  .app-form-grid,
  .application-overview-grid,
  .enrollment-overview-grid,
  .policy-filter-form,
  .policy-create-form,
  .policy-summary-grid,
  .policy-builder-shell,
  .policy-builder-layout,
  .policy-builder-grid,
  .policy-toggle-grid,
  .policy-fieldset {
    grid-template-columns: 1fr;
  }

  .page-header,
  .policy-template-strip {
    align-items: stretch;
    flex-direction: column;
  }

  .app-page-header__actions,
  .app-empty-state,
  .enrollment-card-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .policy-header-actions {
    justify-content: flex-start;
  }

  .enrollment-config-card {
    align-items: stretch;
    flex-direction: column;
  }

  .enrollment-card-actions {
    justify-content: flex-start;
  }

  .enrollment-artifact-panel {
    min-width: 0;
    width: 100%;
  }
}

/* secondary-button (outlined, matches secondary-link but button element) */
.secondary-button {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  cursor: pointer;
  font: inherit;
  font-weight: 600;
  min-height: 38px;
  padding: 8px 12px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}

/* geofences two-column layout */
.geofences-layout {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: minmax(0, 1.4fr) minmax(260px, 0.6fr);
  align-items: start;
}

.geofence-evidence-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.geofence-evidence-row {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 10px 12px;
}

.geofence-evidence-row div {
  display: grid;
  grid-gap: 3px;
  gap: 3px;
  min-width: 0;
}

.geofence-evidence-row strong {
  font-size: 13px;
}

.geofence-evidence-row span:not(.status-badge) {
  color: var(--muted);
  font-size: 12px;
  overflow-wrap: anywhere;
}

/* notifications */
.notifications-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.notifications-list-section {
  overflow: hidden;
}

.notification-alert-list {
  display: grid;
  grid-gap: 0;
  gap: 0;
}

.notification-alert-row {
  align-items: center;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 16px;
  justify-content: space-between;
  padding: 12px 0;
}

.notification-alert-row:last-child {
  border-bottom: 0;
}

.notification-alert-title {
  align-items: center;
  display: flex;
  gap: 8px;
  margin-bottom: 4px;
}

.notification-alert-title strong {
  font-size: 14px;
}

.notification-alert-row > div > span {
  color: var(--muted);
  font-size: 13px;
}

.notification-alert-actions {
  align-items: center;
  display: flex;
  flex-shrink: 0;
  gap: 10px;
}

/* audit logs */
.audit-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.audit-filter-section {
  overflow: hidden;
}

.audit-filter-form {
  align-items: end;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.audit-filter-form label {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.audit-filter-form span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
}

.audit-filter-form input {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  min-height: 36px;
  padding: 6px 8px;
}

.audit-filter-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  grid-column: 1 / -1;
}

.audit-layout {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  align-items: start;
}

.audit-list-section,
.audit-detail-section {
  overflow: hidden;
}

.audit-table-wrap {
  overflow-x: auto;
}

.audit-table {
  border-collapse: collapse;
  font-size: 13px;
  min-width: 640px;
  width: 100%;
}

.audit-table th,
.audit-table td {
  border-top: 1px solid var(--line);
  padding: 9px 12px;
  text-align: left;
  vertical-align: top;
}

.audit-table th {
  background: var(--panel);
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
}

.audit-table td small {
  color: var(--muted);
  display: block;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 11px;
  margin-top: 2px;
}

.audit-pagination {
  padding: 12px;
}

.audit-detail-body {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.audit-detail-row {
  display: grid;
  grid-gap: 2px;
  gap: 2px;
}

.audit-detail-row span {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
}

.audit-detail-row strong {
  font-size: 13px;
}

.audit-mono {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 12px;
}

.audit-evidence-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.audit-payload {
  background: var(--panel-muted);
  border: 1px solid var(--line);
  border-radius: 6px;
  font-size: 11px;
  max-height: 280px;
  overflow: auto;
  padding: 10px;
  white-space: pre-wrap;
  word-break: break-all;
}

/* reports */
.reports-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.reports-layout {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  align-items: start;
}

.reports-builder-section,
.reports-status-section {
  overflow: hidden;
}

.reports-builder-list {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.report-builder-form {
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  padding: 14px;
}

.report-builder-header {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.report-builder-header strong {
  font-size: 14px;
}

.report-builder-header span {
  color: var(--muted);
  font-size: 12px;
}

.report-builder-fields {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.report-builder-fields label {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.report-builder-fields span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
}

.report-builder-fields input,
.report-builder-fields select {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  min-height: 36px;
  padding: 6px 8px;
}

.report-status-form {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  margin-bottom: 14px;
}

.report-status-form label {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.report-status-form span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
}

.report-status-form input {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  min-height: 36px;
  padding: 6px 8px;
}

.report-status-result {
  margin-top: 14px;
}

@media (max-width: 767px) {
  .geofences-layout,
  .audit-layout,
  .reports-layout {
    grid-template-columns: 1fr;
  }

  .report-builder-fields {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1023px) {
  .dashboard-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-panels,
  .users-two-col {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .dashboard-kpi-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-readiness-row,
  .notification-alert-row,
  .policy-guidance-row {
    align-items: flex-start;
    flex-direction: column;
  }

  .dashboard-readiness-row-end,
  .notification-alert-actions {
    flex-wrap: wrap;
  }

  .user-filter-toolbar input,
  .user-filter-toolbar select,
  .user-filter-toolbar button {
    width: 100%;
  }
}

