:root {
  --bg: #f4f7fb;
  --surface: #ffffff;
  --surface-soft: #f8fafc;
  --border: #dce5ef;
  --text: #142033;
  --muted: #607086;
  --primary: #1268b3;
  --primary-dark: #0d4f88;
  --accent: #0f8b6f;
  --danger: #b42318;
  --sidebar: #172033;
  --sidebar-2: #202b40;
  --sidebar-hover: #2a3852;
  --shadow: 0 18px 45px rgba(15, 23, 42, .08);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: "Segoe UI", Tahoma, Arial, sans-serif;
}

.app-sidebar {
  position: fixed;
  inset-block: 0;
  inset-inline-start: 0;
  width: 310px;
  background: var(--sidebar);
  color: #fff;
  overflow-y: auto;
  padding: 18px 14px;
  border-inline-end: 1px solid rgba(255, 255, 255, .08);
}

.brand {
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 4px 4px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.brand-mark {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--primary);
  color: #fff;
  font-weight: 900;
  font-size: 22px;
}

.brand strong { display: block; font-size: 20px; }
.brand span { display: block; color: #cbd5e1; font-size: 13px; }

.side-nav { margin-top: 14px; padding-bottom: 20px; }
.nav-section { margin-top: 8px; }

.nav-group-toggle {
  width: 100%;
  border: 0;
  background: transparent;
  color: #aebbd0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0;
  text-align: start;
}

.nav-group-toggle i { transition: transform .18s ease; font-size: 12px; }
.nav-group-toggle:not(.collapsed) i { transform: rotate(180deg); }

.side-nav .nav-link {
  color: #e8edf4;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border-radius: 8px;
  margin-bottom: 3px;
  text-decoration: none;
  min-height: 42px;
  border: 1px solid transparent;
}

.side-nav .nav-link:hover { background: var(--sidebar-hover); color: #fff; }
.side-nav .nav-link.active {
  background: #eef6ff;
  color: var(--primary-dark);
  border-color: rgba(18, 104, 179, .2);
  font-weight: 800;
}

.root-link { margin-bottom: 10px; background: var(--sidebar-2); }

.nav-item-icon,
.module-icon {
  width: 30px;
  height: 30px;
  display: inline-grid;
  place-items: center;
  border-radius: 8px;
  background: rgba(255, 255, 255, .08);
  color: inherit;
  flex: 0 0 30px;
}

.nav-link.active .nav-item-icon { background: rgba(18, 104, 179, .12); }

.app-main {
  margin-inline-start: 310px;
  min-height: 100vh;
  padding: 20px;
}

.topbar,
.module-toolbar,
.crud-panel,
.data-panel,
.report-actions,
.hero-panel,
.metric-card,
.dashboard-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow);
}

.topbar {
  min-height: 82px;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.topbar h1 { margin: 0; font-size: 24px; font-weight: 900; }
.topbar p { margin: 3px 0 0; color: var(--muted); }
.top-actions { display: flex; align-items: center; gap: 10px; }

.user-chip,
.counter-chip,
.page-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: #edf7f4;
  color: #0b6b56;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 800;
}

.content-shell { margin-top: 18px; }

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

.hero-panel {
  grid-column: span 4;
  padding: 26px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.hero-panel h2 { font-size: 32px; font-weight: 900; margin: 6px 0; }
.hero-panel p { color: var(--muted); margin: 0; max-width: 820px; }
.eyebrow { color: var(--accent); font-weight: 900; font-size: 13px; }

.metric-card {
  padding: 18px;
  text-decoration: none;
  color: var(--text);
  min-height: 120px;
  display: grid;
  gap: 10px;
}

.metric-card:hover { border-color: rgba(18, 104, 179, .35); color: var(--text); transform: translateY(-1px); }
.metric-card span { display: block; color: var(--muted); }
.metric-card strong { display: block; font-size: 30px; font-weight: 900; }
.metric-card i { color: var(--primary); font-size: 24px; }

.dashboard-panel {
  grid-column: span 2;
  padding: 18px;
}

.full-width-panel { grid-column: 1 / -1; }

.ops-hero { margin-bottom: 14px; }
.ops-hero-icon {
  font-size: 54px;
  color: var(--primary);
}

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

.ops-card,
.matrix-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow);
}

.ops-card {
  min-height: 150px;
  padding: 18px;
  display: grid;
  gap: 8px;
  text-decoration: none;
  color: var(--text);
}

.ops-card:hover {
  color: var(--text);
  border-color: rgba(18, 104, 179, .45);
  transform: translateY(-1px);
}

.ops-card i {
  color: var(--primary);
  font-size: 28px;
}

.ops-card strong { font-size: 18px; font-weight: 900; }
.ops-card span { color: var(--muted); }
.ops-actions {
  margin-top: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.compact-field {
  min-width: 260px;
  margin: 0;
}

.matrix-card {
  overflow: hidden;
}

.matrix-title {
  min-height: 52px;
  padding: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: #eef6ff;
  color: var(--primary-dark);
}

.permission-list {
  display: grid;
  gap: 2px;
  padding: 10px;
}

.permission-check {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 9px;
  border-radius: 8px;
  color: var(--text);
}

.permission-check:hover { background: var(--surface-soft); }
.permission-check span { display: grid; gap: 2px; }
.permission-check small { color: var(--muted); direction: ltr; }

.sticky-actions {
  position: sticky;
  bottom: 0;
  z-index: 10;
  padding: 12px;
  background: rgba(244, 247, 251, .92);
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: flex-end;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 4px 9px;
  border-radius: 999px;
  background: #edf7f4;
  color: #0b6b56;
  font-weight: 900;
}

.audit-json {
  min-width: 150px;
}

.audit-json summary {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--primary-dark);
  font-weight: 800;
  list-style: none;
  user-select: none;
}

.audit-json summary::-webkit-details-marker { display: none; }

.audit-json pre {
  margin: 8px 0 0;
  max-width: 420px;
  max-height: 180px;
  overflow: auto;
  white-space: pre-wrap;
  direction: ltr;
  text-align: left;
  font-size: 11px;
  color: #334155;
  background: #f8fafc;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px;
}

.dashboard-panel h3,
.grid-header h3,
.report-actions h3,
.crud-title h3 {
  margin: 4px 0 0;
  font-size: 18px;
  font-weight: 900;
}

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

.module-title-block {
  display: flex;
  align-items: center;
  gap: 12px;
}

.module-title-block .module-icon {
  width: 52px;
  height: 52px;
  background: #eaf4ff;
  color: var(--primary);
  font-size: 24px;
}

.module-header h2 { margin: 4px 0 0; font-size: 25px; font-weight: 900; }
.module-header p { margin: 4px 0 0; color: var(--muted); }

.endpoint-chip {
  max-width: 44%;
  background: #f1f5f9;
  color: var(--muted);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  direction: ltr;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.module-toolbar {
  padding: 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
}

.search-form,
.toolbar-actions,
.app-alert,
.btn,
.pager-actions,
.page-size {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.search-form { display: flex; flex: 1 1 auto; }
.input-icon { position: relative; width: min(460px, 100%); }
.input-icon i { position: absolute; inset-inline-start: 12px; top: 50%; transform: translateY(-50%); color: var(--muted); }
.input-icon .form-control { padding-inline-start: 38px; }

.crud-panel { padding: 16px; margin-bottom: 14px; }
.report-actions {
  padding: 14px 16px;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.crud-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.crud-form {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.field {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.field .form-control,
.field .form-select {
  color: var(--text);
  font-weight: 600;
  min-height: 40px;
}

.switch-row {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
}

.crud-actions {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
}

.attachment-panel {
  border-inline-start: 4px solid var(--accent);
}

.attachment-form,
.attachment-delete {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(260px, 1fr) auto;
  align-items: end;
  gap: 12px;
  margin-bottom: 10px;
}

.documents-upload {
  grid-template-columns: repeat(4, minmax(180px, 1fr));
}

.inline-actions {
  grid-column: auto;
  justify-content: flex-start;
}

.attachment-delete {
  grid-template-columns: minmax(220px, 1fr) auto;
  margin-bottom: 0;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}

.data-panel { overflow: hidden; }
.grid-header,
.grid-footer {
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--border);
}

.grid-footer { border-top: 1px solid var(--border); border-bottom: 0; background: var(--surface-soft); }
.pager-summary, .page-size { color: var(--muted); font-weight: 800; }

.data-table { margin: 0; min-width: 900px; }
.data-table thead th {
  background: #243044;
  color: #fff;
  font-size: 13px;
  padding: 14px;
  white-space: nowrap;
}
.data-table tbody td { padding: 12px 14px; border-color: var(--border); vertical-align: middle; }
.data-table tbody tr:hover { background: #f8fbff; }
.selectable-row {
  cursor: pointer;
}

.selectable-row:hover {
  background: #eef7ff;
}

.selectable-row:focus-visible {
  outline: 3px solid rgba(13, 110, 253, 0.25);
  outline-offset: -3px;
}

.selectable-row td:first-child::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  margin-inline-end: 8px;
  border-radius: 999px;
  background: #0d6efd;
  opacity: 0;
  vertical-align: middle;
}

.selectable-row:hover td:first-child::before {
  opacity: 1;
}
.actions-col { width: 210px; }

.row-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}

.row-actions form { margin: 0; }

.empty-row {
  height: 86px;
  text-align: center;
  color: var(--muted);
  font-weight: 800;
}

.empty-row i { color: var(--primary); margin-inline-end: 6px; }

.empty-state {
  min-height: 260px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 32px;
  color: var(--muted);
}

.empty-state.compact { min-height: 180px; background: var(--surface); border: 1px solid var(--border); border-radius: 8px; }
.empty-state h2 { color: var(--text); margin: 10px 0 6px; font-size: 23px; }
.empty-state p { max-width: 560px; margin: 0; }
.empty-icon { color: var(--primary); font-size: 42px; }

.barcode-cell {
  direction: ltr;
  font-family: "Consolas", "Courier New", monospace;
  letter-spacing: 1px;
  font-weight: 900;
}

.workflow-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(320px, .75fr);
  gap: 16px;
  margin-bottom: 16px;
}

.workflow-stack {
  display: grid;
  gap: 16px;
}

.workflow-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 18px;
  box-shadow: var(--shadow-sm);
}

.compact-workflow {
  align-self: start;
}

.workflow-title {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.workflow-title i {
  width: 42px;
  height: 42px;
  display: inline-grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-size: 22px;
}

.workflow-title h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 900;
}

.workflow-title span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.ops-alert {
  display: flex;
  align-items: center;
  gap: 10px;
  border-radius: 8px;
  font-weight: 800;
}

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

.form-grid.one-col {
  grid-template-columns: 1fr;
}

.form-grid label,
.line-row label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
}

.span-2 {
  grid-column: span 2;
}

.line-table {
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 14px;
}

.line-head,
.line-row {
  display: grid;
  grid-template-columns: minmax(220px, 1.3fr) minmax(110px, .5fr) minmax(110px, .5fr) minmax(160px, .9fr);
  gap: 8px;
  align-items: center;
  padding: 10px;
}

.line-head {
  background: #243044;
  color: #fff;
  font-weight: 900;
  font-size: 13px;
}

.line-row {
  border-top: 1px solid var(--border);
  background: #fff;
}

.line-row:nth-child(even) {
  background: #f8fbff;
}

.inventory-lines {
  grid-template-columns: minmax(220px, 1.3fr) minmax(100px, .45fr) minmax(100px, .45fr) minmax(160px, .9fr);
}

.mini-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  gap: 8px;
  margin-bottom: 8px;
}

.professional-table thead th {
  background: #243044;
  color: #fff;
  border: 0;
  white-space: nowrap;
}

.professional-table td,
.professional-table th {
  padding: 12px;
  vertical-align: middle;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 4px 10px;
  border-radius: 999px;
  background: #eef6ff;
  color: var(--primary-dark);
  font-size: 12px;
  font-weight: 900;
}

.kpi-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.kpi-strip div {
  background: var(--surface-soft);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px;
}

.kpi-strip span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.kpi-strip strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 20px;
}

.compact-kpis {
  margin-top: 12px;
}

.bulk-area {
  min-height: 220px;
  direction: ltr;
  font-family: "Consolas", "Courier New", monospace;
}

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

.rank-list div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  background: #f8fbff;
  border: 1px solid var(--border);
  border-radius: 8px;
}

.rank-list.warning div {
  background: #fff8ed;
}

.login-body {
  min-height: 100vh;
  display: grid;
  place-items: center;
  background: #eef3f8;
}

.login-card {
  width: min(420px, 92vw);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 28px;
  box-shadow: var(--shadow);
}

.login-brand { margin-bottom: 24px; }
.hint { color: var(--muted); margin: 14px 0 0; text-align: center; font-size: 13px; }
.btn-primary { background: var(--primary); border-color: var(--primary); }
.btn-primary:hover { background: var(--primary-dark); border-color: var(--primary-dark); }
.btn-success { background: var(--accent); border-color: var(--accent); }
.btn-danger, .btn-outline-danger:hover { background: var(--danger); border-color: var(--danger); }

.context-note {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin: 0 0 14px;
  padding: 14px 16px;
  background: #fff8ed;
  border: 1px solid #fed7aa;
  border-radius: 8px;
  color: #7c2d12;
}

.context-note i {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #ffedd5;
  color: #c2410c;
  flex: 0 0 34px;
}

.context-note strong,
.context-note span {
  display: block;
}

.context-note span {
  color: #9a3412;
  margin-top: 4px;
}

.smart-select-wrap {
  position: relative;
  width: 100%;
}

.smart-select-native {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.smart-select-trigger {
  width: 100%;
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 12px;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  text-align: start;
  font-weight: 700;
  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.smart-select-trigger:hover,
.smart-select-trigger:focus {
  border-color: rgba(18, 104, 179, .65);
  box-shadow: 0 0 0 4px rgba(18, 104, 179, .12);
  outline: 0;
}

.smart-select-trigger span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.smart-select-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.smart-select-modal.open {
  display: flex;
}

.smart-select-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .48);
  backdrop-filter: blur(3px);
}

.smart-select-dialog {
  position: relative;
  width: min(760px, 96vw);
  max-height: min(720px, 90vh);
  display: grid;
  grid-template-rows: auto auto auto minmax(0, 1fr);
  gap: 12px;
  background: #fff;
  border: 1px solid rgba(203, 213, 225, .9);
  border-radius: 8px;
  box-shadow: 0 30px 80px rgba(15, 23, 42, .28);
  padding: 16px;
  animation: smartSelectIn .14s ease-out;
}

.smart-select-head,
.smart-select-search {
  display: flex;
  align-items: center;
  gap: 10px;
}

.smart-select-head {
  justify-content: space-between;
}

.smart-select-head h3 {
  margin: 2px 0 0;
  font-size: 20px;
  font-weight: 900;
}

.smart-select-search {
  position: relative;
}

.smart-select-search i {
  position: absolute;
  inset-inline-start: 14px;
  color: var(--muted);
}

.smart-select-search input {
  min-height: 46px;
  padding-inline-start: 42px;
}

.smart-select-count {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.smart-select-list {
  overflow: auto;
  display: grid;
  gap: 8px;
  padding-inline-end: 4px;
}

.smart-select-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 46px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #f8fafc;
  color: var(--text);
  text-align: start;
  transition: background .14s ease, border-color .14s ease, transform .14s ease;
}

.smart-select-option:hover,
.smart-select-option.selected {
  background: #eef6ff;
  border-color: rgba(18, 104, 179, .45);
  transform: translateY(-1px);
}

.smart-select-option span {
  font-weight: 900;
}

.smart-select-option small {
  color: var(--muted);
  direction: ltr;
}

.smart-select-empty {
  min-height: 120px;
  display: grid;
  place-items: center;
  gap: 8px;
  color: var(--muted);
  background: #f8fafc;
  border: 1px dashed var(--border);
  border-radius: 8px;
}

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

.summary-tile {
  min-height: 104px;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  grid-template-rows: auto auto;
  align-items: center;
  gap: 4px 10px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}

.summary-tile i {
  grid-row: span 2;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  font-size: 20px;
}

.summary-tile span {
  color: var(--muted);
  font-weight: 800;
}

.summary-tile strong {
  font-size: 28px;
  line-height: 1;
  font-weight: 900;
}

.summary-tile.teal i { background: #dcfce7; color: #15803d; }
.summary-tile.blue i { background: #dbeafe; color: #1d4ed8; }
.summary-tile.amber i { background: #fef3c7; color: #b45309; }
.summary-tile.slate i { background: #e2e8f0; color: #334155; }

.permission-toolbar {
  align-items: end;
}

.permission-search-field {
  min-width: min(420px, 100%);
  flex: 1 1 360px;
}

.matrix-card {
  overflow: hidden;
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.matrix-card:hover {
  transform: translateY(-1px);
  border-color: rgba(18, 104, 179, .35);
}

.matrix-title {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px;
  background: #f8fafc;
  border-bottom: 1px solid var(--border);
}

.matrix-title i {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
}

.permission-list {
  display: grid;
  gap: 8px;
  padding: 12px;
}

.permission-check {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 54px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
  transition: background .14s ease, border-color .14s ease, transform .14s ease;
}

.permission-check:hover {
  background: #f8fbff;
  border-color: rgba(18, 104, 179, .32);
}

.permission-check:has(input:checked) {
  background: #edf7f4;
  border-color: rgba(15, 139, 111, .38);
}

.permission-check span,
.permission-check strong,
.permission-check small {
  display: block;
}

.permission-check strong {
  color: var(--text);
}

.permission-check small {
  margin-top: 2px;
  color: var(--muted);
  direction: ltr;
  text-align: start;
}

.executive-dashboard {
  display: grid;
  gap: 14px;
}

.executive-hero {
  min-height: 240px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 230px;
  gap: 20px;
  align-items: stretch;
  padding: 24px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(18, 104, 179, .10), rgba(15, 139, 111, .08)),
    #fff;
  box-shadow: var(--shadow);
}

.executive-hero h2 {
  max-width: 780px;
  margin: 8px 0;
  font-size: clamp(30px, 4vw, 52px);
  line-height: 1.12;
  font-weight: 950;
  letter-spacing: 0;
}

.executive-hero p {
  max-width: 920px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.9;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.dashboard-date {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  min-height: 180px;
  border: 1px solid rgba(18, 104, 179, .18);
  border-radius: 8px;
  background: #f8fbff;
  color: var(--primary);
}

.dashboard-date i {
  font-size: 42px;
}

.dashboard-date span {
  color: var(--muted);
  font-weight: 800;
}

.dashboard-date strong {
  direction: ltr;
  font-size: 24px;
  color: var(--text);
}

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

.action-tile {
  min-height: 118px;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  grid-template-rows: auto auto;
  gap: 4px 10px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  text-decoration: none;
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.action-tile:hover {
  transform: translateY(-2px);
  border-color: rgba(18, 104, 179, .35);
  box-shadow: 0 18px 34px rgba(15, 23, 42, .10);
}

.action-tile i {
  grid-row: span 2;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-size: 20px;
}

.action-tile strong {
  font-size: 16px;
  font-weight: 900;
}

.action-tile span {
  color: var(--muted);
  line-height: 1.65;
}

.module-icon-grid,
.professional-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.module-icon-card,
.professional-card {
  min-height: 136px;
  display: grid;
  align-content: start;
  gap: 8px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  text-decoration: none;
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.module-icon-card:hover,
.professional-card:hover {
  transform: translateY(-2px);
  border-color: rgba(18, 104, 179, .35);
  box-shadow: 0 18px 34px rgba(15, 23, 42, .10);
}

.module-icon-card i,
.professional-card i {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-size: 22px;
}

.module-icon-card strong,
.professional-card strong {
  font-weight: 950;
}

.module-icon-card span,
.professional-card span {
  color: var(--muted);
  line-height: 1.65;
}

.professional-panel {
  grid-column: span 2;
}

.wide-panel {
  grid-column: span 2;
}

.section-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}

.section-stat-card {
  min-height: 148px;
  padding: 16px;
  display: grid;
  gap: 8px;
  align-content: space-between;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  text-decoration: none;
  box-shadow: 0 18px 36px rgba(15, 23, 42, .07);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.section-stat-card:hover {
  transform: translateY(-2px);
  border-color: rgba(18, 104, 179, .35);
  box-shadow: 0 24px 46px rgba(15, 23, 42, .12);
}

.section-stat-card i {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-size: 22px;
}

.section-stat-card span {
  color: var(--muted);
  font-weight: 800;
}

.section-stat-card strong {
  font-size: 26px;
  font-weight: 950;
  line-height: 1.15;
}

.section-stat-card small {
  color: var(--muted);
  font-weight: 750;
  line-height: 1.6;
}

.section-stat-card.students i { background: #ecfdf5; color: #047857; }
.section-stat-card.academic i { background: #eef2ff; color: #4338ca; }
.section-stat-card.attendance i { background: #fff7ed; color: #c2410c; }
.section-stat-card.finance i { background: #f0fdf4; color: #15803d; }
.section-stat-card.accounting i { background: #f8fafc; color: #334155; }
.section-stat-card.exams i { background: #fefce8; color: #a16207; }
.section-stat-card.inventory i { background: #eff6ff; color: #1d4ed8; }
.section-stat-card.portal i { background: #fdf2f8; color: #be185d; }

.panel-title-row {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.live-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 10px;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-weight: 850;
  white-space: nowrap;
}

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

.ops-alert {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) 20px;
  align-items: center;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  text-decoration: none;
}

.ops-alert .alert-count {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-size: 20px;
  font-weight: 950;
}

.ops-alert strong {
  display: block;
  margin-bottom: 4px;
  font-weight: 950;
}

.ops-alert small {
  color: var(--muted);
  line-height: 1.7;
}

.ops-alert.danger .alert-count { background: #fef2f2; color: #dc2626; }
.ops-alert.warning .alert-count { background: #fff7ed; color: #c2410c; }
.ops-alert.info .alert-count { background: #eef6ff; color: var(--primary); }

.empty-alert {
  grid-column: 1 / -1;
  min-height: 120px;
  display: grid;
  place-items: center;
  gap: 6px;
  padding: 20px;
  border: 1px dashed var(--border);
  border-radius: 8px;
  background: #f8fbff;
  text-align: center;
}

.empty-alert i {
  color: #059669;
  font-size: 34px;
}

.empty-alert span {
  color: var(--muted);
}

.mini-stat-list {
  display: grid;
  gap: 9px;
  margin-top: 14px;
}

.mini-stat-list div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
}

.mini-stat-list span {
  color: var(--muted);
  font-weight: 800;
}

.mini-stat-list strong {
  color: var(--text);
  font-weight: 950;
  direction: ltr;
}

.status-card {
  min-height: 170px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  text-align: center;
}

.status-card i {
  font-size: 40px;
}

.status-card strong {
  font-size: 22px;
  font-weight: 950;
}

.status-card span {
  color: var(--muted);
  direction: ltr;
}

.status-card.ok i,
.status-card.ok strong {
  color: #047857;
}

.status-card.warn i,
.status-card.warn strong {
  color: #c2410c;
}

.workspace-hero {
  align-items: center;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.hero-actions .btn,
.panel-title-row .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 850;
}

.workspace-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.workspace-stat {
  display: grid;
  gap: 7px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}

.workspace-stat i {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-size: 22px;
}

.workspace-stat span,
.workspace-stat small {
  color: var(--muted);
  font-weight: 800;
}

.workspace-stat strong {
  font-size: 20px;
  font-weight: 950;
}

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

.workflow-card {
  position: sticky;
  top: 16px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}

.workflow-card h3 {
  margin: 4px 0 14px;
  font-size: 22px;
  font-weight: 950;
}

.process-steps {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: step;
}

.process-steps li {
  position: relative;
  display: grid;
  gap: 4px;
  padding: 12px 44px 12px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #f8fbff;
}

.process-steps li::before {
  counter-increment: step;
  content: counter(step);
  position: absolute;
  inset-inline-start: auto;
  inset-inline-end: 12px;
  top: 12px;
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #0f766e;
  color: #fff;
  font-size: 13px;
  font-weight: 950;
}

.process-steps strong {
  font-weight: 950;
}

.process-steps span {
  color: var(--muted);
  line-height: 1.65;
}

.workspace-tabs {
  position: relative;
  min-width: 0;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}

.workspace-tabs > input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.tab-labels {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}

.tab-labels label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 10px 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #f8fbff;
  color: var(--text);
  cursor: pointer;
  font-weight: 900;
  transition: background .16s ease, border-color .16s ease, color .16s ease, transform .16s ease;
}

.tab-labels label:hover {
  transform: translateY(-1px);
  border-color: #93c5fd;
  background: #eef6ff;
  color: var(--primary);
}

.tab-panels {
  min-height: 340px;
}

.tab-panel {
  display: none;
  animation: smartSelectIn .18s ease;
}

.student-workspace-tabs #student-tab-overview:checked ~ .tab-labels label[for="student-tab-overview"],
.student-workspace-tabs #student-tab-family:checked ~ .tab-labels label[for="student-tab-family"],
.student-workspace-tabs #student-tab-finance:checked ~ .tab-labels label[for="student-tab-finance"],
.student-workspace-tabs #student-tab-academic:checked ~ .tab-labels label[for="student-tab-academic"],
.student-workspace-tabs #student-tab-files:checked ~ .tab-labels label[for="student-tab-files"],
.student-workspace-tabs #student-tab-followup:checked ~ .tab-labels label[for="student-tab-followup"],
.fees-workspace-tabs #fees-tab-student:checked ~ .tab-labels label[for="fees-tab-student"],
.fees-workspace-tabs #fees-tab-plan:checked ~ .tab-labels label[for="fees-tab-plan"],
.fees-workspace-tabs #fees-tab-collect:checked ~ .tab-labels label[for="fees-tab-collect"],
.fees-workspace-tabs #fees-tab-discount:checked ~ .tab-labels label[for="fees-tab-discount"],
.fees-workspace-tabs #fees-tab-reports:checked ~ .tab-labels label[for="fees-tab-reports"],
.accounting-workspace-tabs #acc-tab-chart:checked ~ .tab-labels label[for="acc-tab-chart"],
.accounting-workspace-tabs #acc-tab-vouchers:checked ~ .tab-labels label[for="acc-tab-vouchers"],
.accounting-workspace-tabs #acc-tab-journal:checked ~ .tab-labels label[for="acc-tab-journal"],
.accounting-workspace-tabs #acc-tab-controls:checked ~ .tab-labels label[for="acc-tab-controls"],
.accounting-workspace-tabs #acc-tab-reports:checked ~ .tab-labels label[for="acc-tab-reports"] {
  border-color: #0f766e;
  background: #ecfdf5;
  color: #047857;
}

.student-workspace-tabs #student-tab-overview:checked ~ .tab-panels [data-tab="overview"],
.student-workspace-tabs #student-tab-family:checked ~ .tab-panels [data-tab="family"],
.student-workspace-tabs #student-tab-finance:checked ~ .tab-panels [data-tab="finance"],
.student-workspace-tabs #student-tab-academic:checked ~ .tab-panels [data-tab="academic"],
.student-workspace-tabs #student-tab-files:checked ~ .tab-panels [data-tab="files"],
.student-workspace-tabs #student-tab-followup:checked ~ .tab-panels [data-tab="followup"],
.fees-workspace-tabs #fees-tab-student:checked ~ .tab-panels [data-tab="student"],
.fees-workspace-tabs #fees-tab-plan:checked ~ .tab-panels [data-tab="plan"],
.fees-workspace-tabs #fees-tab-collect:checked ~ .tab-panels [data-tab="collect"],
.fees-workspace-tabs #fees-tab-discount:checked ~ .tab-panels [data-tab="discount"],
.fees-workspace-tabs #fees-tab-reports:checked ~ .tab-panels [data-tab="reports"],
.accounting-workspace-tabs #acc-tab-chart:checked ~ .tab-panels [data-tab="chart"],
.accounting-workspace-tabs #acc-tab-vouchers:checked ~ .tab-panels [data-tab="vouchers"],
.accounting-workspace-tabs #acc-tab-journal:checked ~ .tab-panels [data-tab="journal"],
.accounting-workspace-tabs #acc-tab-controls:checked ~ .tab-panels [data-tab="controls"],
.accounting-workspace-tabs #acc-tab-reports:checked ~ .tab-panels [data-tab="reports"] {
  display: block;
}

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

.guided-item,
.guided-link,
.collection-card {
  display: grid;
  gap: 8px;
  min-height: 150px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #f8fbff;
  color: var(--text);
  text-decoration: none;
}

.guided-link:hover {
  border-color: #93c5fd;
  background: #eef6ff;
  color: var(--text);
}

.guided-item i,
.guided-link i,
.collection-card i {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-size: 22px;
}

.guided-item strong,
.guided-link strong,
.collection-card strong {
  font-size: 18px;
  font-weight: 950;
}

.guided-item span,
.guided-link span,
.collection-card span {
  color: var(--muted);
  line-height: 1.7;
  font-weight: 750;
}

.payment-strip,
.collection-board {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.payment-strip div {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 4px 10px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}

.payment-strip span {
  grid-row: span 2;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #0f766e;
  color: #fff;
  font-weight: 950;
}

.payment-strip strong {
  font-weight: 950;
}

.payment-strip small {
  color: var(--muted);
  font-weight: 750;
}

.collection-board {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 14px;
}

.collection-card.primary {
  border-color: #99f6e4;
  background: #ecfdf5;
}

.workspace-command-bar {
  display: grid;
  grid-template-columns: minmax(260px, .8fr) minmax(420px, 1.2fr);
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}

.workspace-command-title {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
}

.workspace-command-title > i {
  width: 42px;
  height: 42px;
  display: grid;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-size: 22px;
}

.workspace-command-title h2 {
  margin: 0;
  overflow: hidden;
  font-size: 22px;
  font-weight: 950;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.workspace-control-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.workspace-control-strip div {
  display: grid;
  gap: 6px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}

.workspace-control-strip i {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-size: 22px;
}

.workspace-control-strip span {
  color: var(--muted);
  font-weight: 800;
}

.workspace-control-strip strong {
  font-size: 20px;
  font-weight: 950;
}

.workspace-stage-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.workspace-stage-chip {
  min-height: 112px;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  grid-template-rows: auto auto;
  align-items: center;
  gap: 7px 12px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  text-align: start;
  box-shadow: var(--shadow);
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}

.workspace-stage-chip:hover,
.workspace-stage-chip.is-active {
  transform: translateY(-1px);
  border-color: rgba(15, 118, 110, .45);
  background: #ecfdf5;
}

.workspace-stage-chip i {
  grid-row: span 2;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-size: 22px;
}

.workspace-stage-chip.is-active i {
  background: #d1fae5;
  color: #047857;
}

.workspace-stage-chip strong,
.workspace-stage-chip small,
.workspace-stage-chip em {
  display: block;
}

.workspace-stage-chip strong {
  font-size: 16px;
  font-weight: 950;
}

.workspace-stage-chip small {
  margin-top: 3px;
  color: var(--muted);
  line-height: 1.55;
  font-weight: 750;
}

.workspace-stage-chip em {
  grid-column: 2;
  color: #0f766e;
  font-style: normal;
  font-size: 12px;
  font-weight: 900;
}

.unified-workspace {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.unified-workspace > input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.workspace-tab-rail {
  position: sticky;
  top: 14px;
  display: grid;
  gap: 8px;
  max-height: calc(100vh - 36px);
  overflow: auto;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}

.workspace-rail-stage {
  display: none;
  gap: 8px;
}

.workspace-rail-stage.is-active {
  display: grid;
}

.workspace-rail-heading {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  padding: 8px 10px;
  border-radius: 8px;
  background: #f1f5f9;
  color: var(--text);
}

.workspace-rail-heading i {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #fff;
  color: var(--primary);
}

.workspace-rail-heading strong,
.workspace-rail-heading small {
  display: block;
}

.workspace-rail-heading strong {
  font-weight: 950;
}

.workspace-rail-heading small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.workspace-tab-rail label {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  min-height: 52px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #f8fbff;
  cursor: pointer;
  font-weight: 900;
  transition: background .16s ease, border-color .16s ease, color .16s ease;
}

.workspace-tab-rail label:hover,
.workspace-tab-rail label.is-active {
  border-color: #0f766e;
  background: #ecfdf5;
  color: #047857;
}

.workspace-tab-rail i {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
  font-size: 18px;
}

.workspace-tab-rail label.is-active i {
  background: #d1fae5;
  color: #047857;
}

.workspace-tab-rail small {
  direction: ltr;
  color: var(--muted);
  font-weight: 850;
}

.workspace-panels {
  min-width: 0;
}

.workspace-panel {
  display: none;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
  animation: smartSelectIn .18s ease;
}

.workspace-panel.is-active {
  display: block;
}

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

.workspace-guide-step {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}

.workspace-guide-step > span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 8px;
  background: #e8f8f3;
  color: var(--primary);
  font-weight: 950;
}

.workspace-guide-step strong {
  display: block;
  color: var(--text);
  font-size: 15px;
  margin-bottom: 4px;
}

.workspace-guide-step p {
  margin: 0;
  color: var(--muted);
  font-weight: 750;
  line-height: 1.7;
}

.workspace-module-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
  padding: 16px;
  border-bottom: 1px solid var(--border);
}

.workspace-module-head h3,
.workspace-module-head p {
  margin: 0;
}

.workspace-module-head p {
  color: var(--muted);
  font-weight: 750;
}

.workspace-search {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 440px;
}

.workspace-module-grid {
  display: grid;
  grid-template-columns: minmax(320px, 430px) minmax(0, 1fr);
  gap: 14px;
  padding: 16px;
}

.workspace-form-card,
.workspace-data-card {
  min-width: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
}

.workspace-form-card {
  padding: 14px;
  background: #f8fbff;
}

.bulk-attendance-card {
  display: grid;
  gap: 14px;
}

.bulk-attendance-card .crud-title p {
  margin: 4px 0 0;
  color: var(--muted);
  font-weight: 750;
}

.bulk-attendance-icon {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #ecfdf5;
  color: #047857;
  font-size: 24px;
}

.bulk-attendance-filters {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(150px, .55fr);
  gap: 10px;
}

.bulk-attendance-actions,
.bulk-attendance-toolbar-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.bulk-attendance-summary,
.bulk-attendance-message {
  padding: 10px 12px;
  border: 1px solid #bfdbfe;
  border-radius: 8px;
  background: #eff6ff;
  color: #1d4ed8;
  font-weight: 850;
}

.bulk-attendance-message.is-error {
  border-color: #fecaca;
  background: #fef2f2;
  color: #b91c1c;
}

.bulk-attendance-modal {
  position: fixed;
  inset: 0;
  z-index: 1060;
  display: grid;
  place-items: center;
  padding: 20px;
}

.bulk-attendance-modal[hidden] {
  display: none;
}

.bulk-attendance-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .48);
}

.bulk-attendance-dialog {
  position: relative;
  z-index: 1;
  width: min(1180px, 96vw);
  max-height: 88vh;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 24px 80px rgba(15, 23, 42, .26);
}

.bulk-attendance-head,
.bulk-attendance-toolbar {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
}

.bulk-attendance-head h3,
.bulk-attendance-head p {
  margin: 0;
}

.bulk-attendance-head p {
  color: var(--muted);
  font-weight: 750;
}

.bulk-attendance-toolbar {
  align-items: center;
  background: #f8fbff;
}

.bulk-attendance-counts {
  color: #0f766e;
  font-weight: 950;
}

.bulk-attendance-list {
  overflow: auto;
  display: grid;
  gap: 8px;
  padding: 12px;
  background: #f1f5f9;
}

.bulk-attendance-row {
  display: grid;
  grid-template-columns: minmax(230px, .8fr) minmax(430px, 1.2fr) minmax(220px, .7fr);
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
}

.bulk-student-cell {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.bulk-student-cell strong,
.bulk-student-cell small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.bulk-student-cell small {
  color: var(--muted);
  font-weight: 800;
}

.bulk-row-number {
  width: 34px;
  height: 34px;
  display: grid;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 8px;
  background: #e0f2fe;
  color: #075985;
  font-weight: 950;
}

.bulk-status-group {
  display: grid;
  grid-template-columns: repeat(5, minmax(78px, 1fr));
  gap: 6px;
}

.bulk-status-btn {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #f8fafc;
  color: #334155;
  font-weight: 900;
}

.bulk-status-btn.is-active {
  color: #fff;
  box-shadow: 0 10px 22px rgba(15, 23, 42, .14);
}

.bulk-status-btn.present.is-active { background: #059669; border-color: #059669; }
.bulk-status-btn.absent.is-active { background: #dc2626; border-color: #dc2626; }
.bulk-status-btn.late.is-active { background: #d97706; border-color: #d97706; }
.bulk-status-btn.excused.is-active { background: #2563eb; border-color: #2563eb; }
.bulk-status-btn.early.is-active { background: #7c3aed; border-color: #7c3aed; }

.bulk-reason-input {
  min-width: 0;
}

.bulk-attendance-empty {
  min-height: 180px;
  display: grid;
  place-items: center;
  gap: 8px;
  color: var(--muted);
  font-weight: 850;
}

.workspace-data-card {
  overflow: hidden;
}

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

.workspace-crud-form .field {
  display: grid;
  gap: 7px;
}

.workspace-crud-form .field span:first-child {
  color: var(--muted);
  font-weight: 850;
}

.workspace-crud-form .crud-actions {
  grid-column: 1 / -1;
}

.compact-grid-header {
  padding: 14px;
}

.compact-grid-header h4 {
  margin: 0;
  font-size: 20px;
  font-weight: 950;
}

.workspace-table {
  margin-bottom: 0;
}

.workspace-table td,
.workspace-table th {
  white-space: nowrap;
}

.readonly-card {
  min-height: 190px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  text-align: center;
  color: var(--muted);
}

.readonly-card i {
  font-size: 36px;
  color: var(--primary);
}

.workspace-focus-strip {
  display: grid;
  gap: 12px;
  margin-bottom: 16px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}

.workspace-global-context {
  display: grid;
  grid-template-columns: minmax(260px, .8fr) minmax(420px, 1.2fr);
  gap: 14px;
  align-items: end;
}

.context-copy h3,
.context-copy p,
.focus-title h3,
.focus-title p {
  margin: 0;
}

.context-copy p,
.focus-title p {
  color: var(--muted);
  font-weight: 760;
}

.workspace-global-search {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.workspace-context-input {
  flex: 1 1 420px;
  min-width: 260px;
}

.workspace-focus-summary {
  display: grid;
  grid-template-columns: minmax(280px, .85fr) minmax(0, 1.15fr);
  gap: 12px;
  align-items: stretch;
}

.focus-title,
.focus-badges {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #f8fbff;
}

.focus-title > i {
  width: 48px;
  height: 48px;
  display: grid;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 8px;
  background: #ecfdf5;
  color: #047857;
  font-size: 24px;
}

.focus-title h3 {
  overflow: hidden;
  font-size: 22px;
  font-weight: 950;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.focus-badges {
  flex-wrap: wrap;
  background: #fff;
}

.focus-badge {
  display: inline-grid;
  grid-template-columns: 30px auto;
  align-items: center;
  gap: 2px 8px;
  min-height: 48px;
  padding: 8px 10px;
  border: 1px solid #dbeafe;
  border-radius: 8px;
  background: #eff6ff;
  color: var(--text);
}

.focus-badge i {
  grid-row: span 2;
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #fff;
  color: var(--primary);
}

.focus-badge small {
  color: var(--muted);
  font-weight: 850;
}

.focus-badge strong {
  max-width: 190px;
  overflow: hidden;
  font-weight: 950;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.workspace-jump-tabs {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 2px;
}

.workspace-jump-tab {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 9px;
  min-height: 44px;
  padding: 9px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  text-decoration: none;
  font-weight: 900;
  white-space: nowrap;
}

.workspace-jump-tab:hover,
.workspace-jump-tab.is-active {
  border-color: #0f766e;
  background: #ecfdf5;
  color: #047857;
}

.workspace-jump-tab i {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: #eef6ff;
  color: var(--primary);
}

.workspace-jump-tab small {
  color: var(--muted);
  font-weight: 850;
}

.workspace-stage-strip {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  margin-bottom: 16px;
  padding: 6px 2px 10px;
  border-bottom: 1px solid var(--border);
}

.workspace-stage-chip {
  min-height: 48px;
  display: inline-flex;
  flex: 0 0 auto;
  grid-template-columns: none;
  grid-template-rows: none;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  box-shadow: none;
  white-space: nowrap;
}

.workspace-stage-chip i {
  grid-row: auto;
  width: 32px;
  height: 32px;
  font-size: 17px;
}

.workspace-stage-chip small {
  display: none;
}

.workspace-stage-chip em {
  grid-column: auto;
  padding: 4px 8px;
  border-radius: 999px;
  background: #f1f5f9;
}

.unified-workspace {
  display: grid;
  grid-template-columns: 1fr;
}

.workspace-tab-rail {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  gap: 10px;
  max-height: none;
  overflow-x: auto;
  overflow-y: hidden;
  margin-bottom: 12px;
  padding: 10px;
  background: rgba(255, 255, 255, .97);
  backdrop-filter: blur(10px);
}

.workspace-rail-stage,
.workspace-rail-stage.is-active {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 8px;
}

.workspace-rail-heading {
  display: inline-flex;
  flex: 0 0 auto;
  min-height: 44px;
  padding: 8px 10px;
  white-space: nowrap;
}

.workspace-rail-heading small {
  display: none;
}

.workspace-tab-rail label {
  display: inline-flex;
  flex: 0 0 auto;
  grid-template-columns: none;
  min-height: 46px;
  padding: 9px 12px;
  white-space: nowrap;
}

.workspace-tab-rail label span {
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.workspace-tab-rail i {
  width: 34px;
  height: 34px;
  font-size: 17px;
}

.workspace-module-tools {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-width: 280px;
}

.context-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  max-width: 360px;
  min-height: 38px;
  padding: 7px 10px;
  border: 1px solid #ccfbf1;
  border-radius: 8px;
  background: #f0fdfa;
  color: #0f766e;
  text-decoration: none;
  font-weight: 900;
}

.context-chip span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.row-actions .btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  border-radius: 8px;
  font-weight: 850;
}

.workspace-tab-rail,
.workspace-jump-tabs,
.workspace-stage-strip {
  flex-wrap: wrap;
  overflow-x: visible;
  overflow-y: visible;
  align-content: flex-start;
}

.workspace-tab-rail {
  max-height: none;
}

.workspace-tab-rail label,
.workspace-jump-tab,
.workspace-stage-chip {
  flex: 1 1 180px;
  max-width: 260px;
  min-width: 170px;
}

.workspace-tab-rail label span,
.workspace-jump-tab span {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  line-height: 1.35;
}

.workspace-module-grid {
  grid-template-columns: 1fr;
}

.workspace-crud-form {
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.workspace-data-card .table-responsive {
  overflow-x: visible;
}

.workspace-table {
  table-layout: fixed;
  width: 100%;
}

.workspace-table td,
.workspace-table th {
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: normal;
}

.workspace-table .actions-col,
.workspace-table .row-actions {
  width: 180px;
}

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

.file-upload-field {
  display: grid;
  gap: 8px;
}

.file-upload-field.is-dragging {
  padding: 8px;
  border: 1px dashed #0f766e;
  border-radius: 8px;
  background: #ecfdf5;
}

.file-upload-field small {
  color: var(--muted);
  font-weight: 750;
}

.file-upload-preview,
.grid-file-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.file-upload-empty {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 7px 10px;
  border: 1px dashed #bfdbfe;
  border-radius: 8px;
  background: #eff6ff;
  color: #1d4ed8;
  font-weight: 850;
}

.file-preview-thumb,
.grid-file-thumb {
  display: inline-grid;
  place-items: center;
  text-decoration: none;
  color: var(--text);
}

.file-preview-thumb img,
.grid-file-thumb img {
  width: 54px;
  height: 54px;
  object-fit: cover;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
}

.file-preview-thumb span {
  max-width: 130px;
  margin-top: 4px;
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.file-preview-chip,
.grid-file-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  max-width: 220px;
  padding: 6px 9px;
  border: 1px solid #bfdbfe;
  border-radius: 8px;
  background: #eff6ff;
  color: #1d4ed8;
  text-decoration: none;
  font-weight: 850;
}

.file-preview-chip span,
.grid-file-chip span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.workspace-global-search input[type="search"],
.workspace-global-search input[name="search"] {
  min-width: min(100%, 420px);
}

@keyframes smartSelectIn {
  from {
    opacity: 0;
    transform: translateY(8px) scale(.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 1100px) {
  .app-sidebar { width: 270px; }
  .app-main { margin-inline-start: 270px; }
  .dashboard-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ops-grid,
  .action-grid,
  .module-icon-grid,
  .professional-grid,
  .section-stat-grid,
  .alerts-grid,
  .matrix-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .executive-hero { grid-template-columns: 1fr; }
  .workflow-shell { grid-template-columns: 1fr; }
  .workspace-layout { grid-template-columns: 1fr; }
  .workspace-summary,
  .payment-strip,
  .workspace-control-strip,
  .workspace-stage-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .workspace-command-bar,
  .workspace-global-context,
  .workspace-focus-summary,
  .workspace-guide { grid-template-columns: 1fr; }
  .guided-grid,
  .collection-board { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .unified-workspace,
  .workspace-module-grid { grid-template-columns: 1fr; }
  .workspace-tab-rail { position: static; max-height: none; }
  .workspace-module-head,
  .workspace-search { display: grid; min-width: 0; }
  .workflow-card { position: static; }
  .permission-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-panel { grid-column: span 2; }
  .dashboard-panel { grid-column: span 2; }
  .crud-form { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .app-sidebar { position: static; width: auto; max-height: 360px; }
  .app-main { margin-inline-start: 0; padding: 12px; }
  .topbar,
  .module-toolbar,
  .hero-panel,
  .module-header,
  .grid-header,
  .grid-footer,
  .report-actions { display: block; height: auto; }
  .top-actions,
  .toolbar-actions,
  .pager-actions { margin-top: 10px; flex-wrap: wrap; }
  .dashboard-grid { grid-template-columns: 1fr; }
  .ops-grid,
  .action-grid,
  .module-icon-grid,
  .professional-grid,
  .section-stat-grid,
  .alerts-grid,
  .matrix-grid { grid-template-columns: 1fr; }
  .executive-hero { padding: 16px; }
  .permission-summary { grid-template-columns: 1fr; }
  .workflow-shell,
  .workspace-layout,
  .form-grid,
  .line-head,
  .line-row,
  .inventory-lines,
  .mini-line,
  .kpi-strip { grid-template-columns: 1fr; }
  .workspace-summary,
  .payment-strip,
  .workspace-control-strip,
  .workspace-stage-strip,
  .workspace-guide,
  .guided-grid,
  .collection-board { grid-template-columns: 1fr; }
  .workspace-command-bar { grid-template-columns: 1fr; }
  .workspace-global-search,
  .workspace-module-tools { display: grid; justify-content: stretch; }
  .workspace-context-input,
  .context-chip { width: 100%; max-width: 100%; min-width: 0; }
  .focus-title h3 { white-space: normal; }
  .workspace-crud-form { grid-template-columns: 1fr; }
  .tab-labels label { flex: 1 1 100%; }
  .span-2 { grid-column: span 1; }
  .hero-panel,
  .dashboard-panel,
  .wide-panel { grid-column: span 1; }
  .panel-title-row { display: block; }
  .live-badge { margin-top: 10px; white-space: normal; }
  .search-form { margin-top: 10px; flex-wrap: wrap; }
  .input-icon, .endpoint-chip { width: 100%; max-width: 100%; }
  .crud-form { grid-template-columns: 1fr; }
  .crud-title { display: block; }
  .crud-title .btn { margin-top: 10px; }
}

/* Final workspace layout: sidebar stays global, every section works through compact wrapped tabs. */
.unified-workspace {
  display: block;
}

.workspace-tab-rail {
  position: static;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 10px;
  max-height: none;
  overflow: visible;
  margin-bottom: 14px;
  padding: 10px;
  border-radius: 8px;
  background: #fff;
}

.workspace-tab-rail label {
  flex: 1 1 168px;
  max-width: 240px;
  min-width: 152px;
  min-height: 48px;
  display: inline-grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  padding: 8px 10px;
  border-radius: 8px;
  line-height: 1.35;
}

.workspace-tab-rail label span {
  white-space: normal;
  overflow-wrap: anywhere;
}

.workspace-tab-rail i {
  width: 34px;
  height: 34px;
  border-radius: 8px;
}

.workspace-module-head {
  flex-wrap: wrap;
}

.workspace-module-grid {
  grid-template-columns: 1fr;
}

.workspace-crud-form {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.workspace-data-card .table-responsive {
  width: 100%;
  overflow-x: visible;
}

.workspace-table {
  width: 100%;
  table-layout: fixed;
}

.workspace-table th,
.workspace-table td {
  white-space: normal;
  overflow-wrap: anywhere;
  vertical-align: middle;
}

.workspace-table .actions-col,
.workspace-table .row-actions {
  width: clamp(150px, 16vw, 220px);
}

.workspace-table .row-actions {
  justify-content: flex-start;
}

.workspace-table .row-actions .btn {
  min-width: 42px;
  justify-content: center;
  border-radius: 8px;
  font-weight: 900;
}

.workspace-table .row-actions .btn i {
  margin: 0;
  font-size: 15px;
}

.workspace-table .row-actions .btn span {
  margin-inline-start: 4px;
}

.workspace-table .row-actions .btn-outline-secondary {
  border-color: #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
}

.workspace-table .row-actions .btn-outline-danger {
  border-color: #fecaca;
  background: #fff5f5;
  color: #b42318;
}

/* Premium visual pass */
:root {
  --bg: #eef4f8;
  --surface: #ffffff;
  --surface-soft: #f7fafc;
  --border: #d8e4ee;
  --text: #0b1728;
  --muted: #617187;
  --primary: #0b72b9;
  --primary-dark: #07558e;
  --accent: #078a73;
  --accent-soft: #e8f7f3;
  --danger: #c5221f;
  --sidebar: #102036;
  --sidebar-2: #16304a;
  --sidebar-hover: #1d3b58;
  --shadow: 0 16px 40px rgba(15, 23, 42, .08);
  --shadow-soft: 0 8px 24px rgba(15, 23, 42, .06);
}

body {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .68), rgba(255, 255, 255, 0) 220px),
    var(--bg);
  font-feature-settings: "kern";
}

.app-sidebar {
  background:
    linear-gradient(180deg, rgba(12, 63, 96, .45), rgba(16, 32, 54, 0) 220px),
    var(--sidebar);
  box-shadow: 18px 0 42px rgba(15, 23, 42, .12);
}

.brand {
  padding: 8px 8px 18px;
}

.brand-mark {
  border-radius: 10px;
  background: linear-gradient(135deg, #0b72b9, #09a37d);
  box-shadow: 0 12px 26px rgba(11, 114, 185, .28);
}

.side-nav .nav-link {
  border-radius: 10px;
  transition: background .16s ease, border-color .16s ease, transform .16s ease;
}

.side-nav .nav-link:hover {
  transform: translateX(-2px);
}

.side-nav .nav-link.active {
  background: #eef8ff;
  color: #07558e;
  box-shadow: inset 4px 0 0 #0b72b9;
}

.nav-item-icon,
.module-icon {
  border-radius: 10px;
}

.topbar,
.module-toolbar,
.crud-panel,
.data-panel,
.report-actions,
.hero-panel,
.metric-card,
.dashboard-panel,
.workspace-panel,
.workspace-form-card,
.workspace-data-card,
.workspace-guide-step {
  border-radius: 12px;
  box-shadow: var(--shadow-soft);
}

.topbar {
  background: rgba(255, 255, 255, .94);
  backdrop-filter: blur(10px);
  border-color: rgba(216, 228, 238, .9);
}

.btn {
  border-radius: 10px;
  font-weight: 850;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
}

.btn-primary {
  background: linear-gradient(135deg, #0b72b9, #087e68);
  border-color: transparent;
  box-shadow: 0 10px 22px rgba(11, 114, 185, .22);
}

.btn-primary:hover {
  background: linear-gradient(135deg, #07558e, #066854);
  border-color: transparent;
}

.btn-outline-primary {
  background: #f7fbff;
}

.design-hero,
.executive-hero {
  border: 1px solid #dce9f3;
  background:
    linear-gradient(135deg, rgba(232, 247, 243, .95), rgba(255, 255, 255, .96) 45%, rgba(239, 247, 255, .94)),
    #fff;
  position: relative;
  overflow: hidden;
}

.design-hero::after,
.executive-hero::after {
  content: "";
  position: absolute;
  inset-inline-start: 20px;
  inset-block-start: 20px;
  width: 150px;
  height: 150px;
  border: 1px solid rgba(11, 114, 185, .12);
  border-radius: 24px;
  transform: rotate(10deg);
  pointer-events: none;
}

.executive-hero h2 {
  color: #071527;
  line-height: 1.35;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.dashboard-date {
  min-width: 190px;
  padding: 18px;
  border: 1px solid #d9e8f2;
  border-radius: 14px;
  background: rgba(255, 255, 255, .72);
  box-shadow: var(--shadow-soft);
}

.dashboard-date i {
  color: var(--primary);
  font-size: 28px;
}

.dashboard-date span,
.dashboard-date strong {
  display: block;
}

.dashboard-date span {
  color: var(--muted);
  margin-top: 10px;
  font-weight: 800;
}

.dashboard-date strong {
  font-size: 22px;
  margin-top: 4px;
}

.section-stat-card,
.action-tile,
.module-icon-card,
.professional-card {
  border-radius: 12px;
  border: 1px solid #dce7f0;
  background: linear-gradient(180deg, #fff, #f8fbfd);
  box-shadow: var(--shadow-soft);
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.section-stat-card:hover,
.action-tile:hover,
.module-icon-card:hover,
.professional-card:hover {
  transform: translateY(-3px);
  border-color: rgba(11, 114, 185, .35);
  box-shadow: 0 18px 40px rgba(15, 23, 42, .10);
}

.section-stat-card i,
.module-icon-card i,
.professional-card i,
.action-tile i {
  border-radius: 12px;
}

.dashboard-panel h3,
.workspace-module-head h3,
.crud-title h4,
.grid-header h4 {
  color: #071527;
  font-weight: 950;
}

.mini-stat-list {
  gap: 10px;
}

.mini-stat-list div {
  border-radius: 10px;
  background: #f8fbfd;
  border: 1px solid #e0eaf2;
}

.workspace-tab-rail {
  background: rgba(255, 255, 255, .88);
  border: 1px solid #dce7f0;
  box-shadow: var(--shadow-soft);
}

.workspace-tab-rail label {
  border: 1px solid #dbe7f0;
  background: linear-gradient(180deg, #fff, #f7fbff);
  font-weight: 900;
}

.workspace-tab-rail label:hover {
  border-color: rgba(11, 114, 185, .35);
  background: #eef7ff;
}

.workspace-tab-rail label.is-active {
  color: #055f50;
  border-color: rgba(7, 138, 115, .45);
  background: #e8f7f3;
  box-shadow: inset 0 -3px 0 #078a73;
}

.workspace-module-head {
  background: linear-gradient(90deg, #fff, #f8fbfd);
}

.workspace-crud-form .field {
  border-radius: 10px;
}

.form-control,
.form-select,
.smart-select-trigger {
  border-radius: 10px;
  border-color: #cfdce8;
}

.form-control:focus,
.form-select:focus,
.smart-select-trigger:focus {
  border-color: #0b72b9;
  box-shadow: 0 0 0 .22rem rgba(11, 114, 185, .14);
}

.data-table thead th {
  background: #17283d;
}

.workspace-table th,
.workspace-table td {
  font-size: 14px;
}

.row-actions .btn {
  min-height: 34px;
}

.app-alert,
.alert {
  border-radius: 12px;
}

/* Final shared grid polish: Excel-like filtering, Arabic wrapping, and compact actions. */
.table-responsive {
  max-width: 100%;
  overflow-x: auto;
}

.data-table {
  width: 100%;
  table-layout: fixed;
}

.data-table thead th,
.data-table tbody td {
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.55;
}

.data-table tbody td {
  max-width: 260px;
}

.data-table .barcode-cell,
.data-table td:has(.grid-file-list) {
  max-width: 180px;
}

.column-filter-row th {
  background: #eef5fb !important;
  color: #17283d;
  padding: 8px;
  vertical-align: top;
}

.table-filter {
  position: relative;
}

.table-filter i {
  position: absolute;
  inset-inline-start: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: #0b72b9;
  font-size: 13px;
  pointer-events: none;
}

.table-filter input {
  width: 100%;
  min-width: 120px;
  height: 34px;
  border: 1px solid #cfdce8;
  border-radius: 8px;
  padding: 6px 30px 6px 10px;
  background: #fff;
  color: #102033;
  font-size: 12px;
  font-weight: 800;
}

.table-filter input:focus {
  outline: 0;
  border-color: #0b72b9;
  box-shadow: 0 0 0 .18rem rgba(11, 114, 185, .14);
}

.student-360-card {
  margin: 0 0 16px;
  padding: 18px;
  border: 1px solid #cfe0ef;
  border-radius: 16px;
  background: linear-gradient(135deg, #ffffff 0%, #f3f9fd 100%);
  box-shadow: 0 14px 32px rgba(15, 39, 65, .08);
}

.student-360-head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
}

.student-avatar {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  color: #0b72b9;
  background: #e7f4ff;
  font-size: 28px;
}

.student-360-head h2 {
  margin: 2px 0 4px;
  font-size: 26px;
}

.student-360-head p {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0;
  color: #5a6f86;
}

.student-360-head p span:not(:empty) {
  padding: 5px 10px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid #d6e4ef;
  font-weight: 800;
}

.student-360-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.student-360-stats article,
.student-360-tabs article {
  border: 1px solid #d6e4ef;
  border-radius: 14px;
  background: #fff;
}

.student-360-stats article {
  padding: 12px;
  display: grid;
  gap: 4px;
}

.student-360-stats i {
  color: #0b72b9;
  font-size: 20px;
}

.student-360-stats span {
  color: #5a6f86;
  font-weight: 800;
  font-size: 12px;
}

.student-360-stats strong {
  color: #071326;
  font-size: 22px;
}

.student-360-tabs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.student-360-tabs article {
  padding: 12px;
  min-height: 140px;
}

.student-360-tabs h3 {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 10px;
  font-size: 15px;
  color: #0b2f52;
}

.student-360-tabs p {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin: 0;
  padding: 8px 0;
  border-top: 1px solid #eef3f7;
  color: #33485f;
  font-size: 13px;
}

.student-360-tabs p:first-of-type {
  border-top: 0;
}

.bulk-grade-row {
  grid-template-columns: minmax(230px, 1.4fr) minmax(150px, .5fr) minmax(180px, .7fr);
}

.bulk-grade-input-wrap {
  display: grid;
  gap: 5px;
  margin: 0;
  font-weight: 900;
  color: #33485f;
}

.bulk-grade-input-wrap input {
  max-width: 180px;
  text-align: center;
  font-weight: 900;
}

.bulk-grade-note {
  color: #63758a;
  font-weight: 700;
}

.filter-actions-note {
  font-size: 12px;
  color: #52657a !important;
  background: #eef5fb !important;
}

.row-actions {
  flex-wrap: wrap;
  white-space: normal;
}

.row-actions .btn,
.row-actions form {
  flex: 0 0 auto;
}

.workspace-tab-rail {
  display: flex;
  flex-wrap: wrap;
  overflow: visible;
  gap: 10px;
}

.workspace-tab-rail label {
  flex: 1 1 168px;
  min-width: 150px;
  max-width: 230px;
  justify-content: center;
}

.workspace-tab-rail label span {
  white-space: normal;
  line-height: 1.35;
}

.workspace-command-bar,
.module-toolbar,
.grid-header,
.compact-grid-header {
  flex-wrap: wrap;
}

@media (max-width: 900px) {
  .data-table {
    min-width: 760px;
  }

  .workspace-tab-rail label {
    flex-basis: calc(50% - 10px);
    max-width: none;
  }
}

@media (max-width: 760px) {
  .hero-actions {
    display: grid;
  }

  .dashboard-date {
    min-width: 0;
    width: 100%;
  }
}

/* RTL grid/print safety pass. */
.data-table,
.workspace-table {
  direction: rtl;
  text-align: start;
}

.actions-col,
.row-actions {
  min-width: 150px;
}

.row-actions .btn span {
  white-space: normal;
  overflow-wrap: anywhere;
}

.table-filter input {
  direction: rtl;
  text-align: start;
}

/* Unified workspace UX fixes. Keep these late so they win over earlier workspace passes. */
.unified-workspace > input[type="radio"] {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  opacity: 0;
  pointer-events: none;
}

.workspace-tab-rail {
  overflow: visible !important;
}

.workspace-tab-rail label {
  user-select: none;
}

.workspace-tab-rail label:focus-visible {
  outline: 3px solid rgba(11, 114, 185, .22);
  outline-offset: 2px;
}

.workspace-panel,
.workspace-data-card {
  overflow: hidden;
}

.workspace-data-card .table-responsive {
  max-width: 100%;
  overflow-x: hidden !important;
}

.workspace-data-card .workspace-table {
  min-width: 0 !important;
  width: 100% !important;
  table-layout: fixed;
}

.workspace-table th,
.workspace-table td {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.workspace-table .actions-col {
  width: 112px !important;
  min-width: 112px !important;
}

.workspace-table .row-actions {
  width: 112px !important;
  min-width: 112px !important;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  white-space: normal;
}

.row-actions form {
  display: inline-flex;
  margin: 0;
}

.grid-action-btn {
  inline-size: 34px;
  block-size: 34px;
  min-width: 34px !important;
  padding: 0 !important;
  border-radius: 8px !important;
}

.grid-action-btn i {
  margin: 0 !important;
  font-size: 16px !important;
}

.action-label {
  position: absolute !important;
  inline-size: 1px !important;
  block-size: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.selectable-row {
  transition: background .14s ease, box-shadow .14s ease;
}

.selectable-row.is-selected {
  background: #e8f7f3 !important;
  box-shadow: inset -4px 0 0 #078a73;
}

.selectable-row.is-selected td:first-child::before,
.selectable-row:focus-visible td:first-child::before,
.selectable-row:hover td:first-child::before {
  opacity: 1;
}

.student-360-empty {
  background: linear-gradient(135deg, #fff 0%, #f8fbfd 100%);
}

.student-360-empty .student-avatar {
  color: #52657a;
  background: #eef3f8;
}

.student-360-tabs p {
  min-width: 0;
}

.student-360-tabs p strong,
.student-360-tabs p span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.bulk-grade-list {
  overflow-x: hidden;
}

.bulk-grade-row {
  grid-template-columns: minmax(220px, 1fr) minmax(130px, 160px) minmax(140px, .65fr) !important;
}

.bulk-grade-input-wrap input.is-invalid {
  border-color: #dc2626;
  box-shadow: 0 0 0 .18rem rgba(220, 38, 38, .14);
}

.bulk-attendance-counts.has-invalid {
  color: #b91c1c;
}

@media (max-width: 900px) {
  .workspace-data-card .data-table,
  .workspace-data-card .workspace-table {
    min-width: 0 !important;
  }

  .workspace-table th,
  .workspace-table td {
    padding: 8px 7px;
    font-size: 12px;
  }

  .workspace-table .actions-col,
  .workspace-table .row-actions {
    width: 82px !important;
    min-width: 82px !important;
  }

  .grid-action-btn {
    inline-size: 32px;
    block-size: 32px;
    min-width: 32px !important;
  }

  .bulk-grade-row {
    grid-template-columns: 1fr minmax(110px, 150px) !important;
  }

  .bulk-grade-note {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .student-360-head {
    align-items: flex-start;
  }

  .student-360-tabs p {
    display: grid;
  }
}

@media print {
  @page {
    size: A4 landscape;
    margin: 10mm;
  }

  body {
    background: #fff !important;
    color: #000 !important;
  }

  .app-sidebar,
  .topbar,
  .module-toolbar,
  .crud-panel,
  .report-actions,
  .workspace-tab-rail,
  .workspace-command-bar,
  .toolbar-actions,
  .grid-footer,
  .column-filter-row,
  .row-actions,
  .actions-col,
  .btn {
    display: none !important;
  }

  .app-main {
    margin: 0 !important;
    padding: 0 !important;
  }

  .content-shell,
  .data-panel,
  .workspace-data-card,
  .table-responsive {
    margin: 0 !important;
    overflow: visible !important;
    box-shadow: none !important;
    border: 0 !important;
  }

  .data-table,
  .workspace-table {
    min-width: 0 !important;
    width: 100% !important;
    table-layout: auto !important;
    border-collapse: collapse !important;
    font-size: 10px;
  }

  .data-table thead th,
  .data-table tbody td {
    background: #fff !important;
    color: #000 !important;
    border: 1px solid #999 !important;
    padding: 5px 6px !important;
    overflow-wrap: anywhere;
  }
}

/* Senior UX pass: denser admin workspaces with clearer states and keyboard focus. */
:where(.btn, .nav-link, .workspace-tab-rail label, .workspace-stage-chip, .grid-action-btn, .form-control, .form-select):focus-visible {
  outline: 3px solid rgba(11, 114, 185, .24);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(11, 114, 185, .10);
}

.app-main {
  max-width: 1920px;
}

.workspace-command-bar {
  border-color: #cbddea;
  background: linear-gradient(180deg, #fff, #f8fbfd);
}

.workspace-command-title > i,
.module-title-block .module-icon,
.workspace-module-head .module-icon {
  box-shadow: inset 0 0 0 1px rgba(11, 114, 185, .10);
}

.workspace-tab-rail {
  gap: 8px;
  scrollbar-color: #9fb6ca transparent;
  scrollbar-width: thin;
}

.workspace-tab-rail label {
  min-height: 54px;
  border-color: #d6e3ee;
  background: #fbfdff;
  color: #17324d;
}

.workspace-tab-rail label:hover {
  transform: translateY(-1px);
}

.workspace-tab-rail label.is-active {
  border-color: rgba(7, 138, 115, .55);
  background: #e9f8f4;
  box-shadow: inset 0 -3px 0 #078a73, 0 10px 22px rgba(15, 23, 42, .06);
}

.workspace-module-head {
  align-items: center;
  border-bottom-color: #dce7f0;
}

.workspace-form-card,
.workspace-data-card,
.data-panel {
  border-color: #d6e3ee;
}

.workspace-form-card {
  background: linear-gradient(180deg, #fbfdff, #f4f9fd);
}

.field span:first-child,
.form-grid label > span:first-child,
.line-row label > span:first-child {
  color: #425a72;
}

.data-table thead th,
.workspace-table thead th {
  border-bottom: 0;
}

.data-table tbody tr:nth-child(even),
.workspace-table tbody tr:nth-child(even) {
  background: #fbfdff;
}

.data-table tbody tr:hover,
.workspace-table tbody tr:hover {
  background: #eef7ff;
}

.column-filter-row th {
  border-bottom: 1px solid #d6e3ee;
}

.status-pill {
  gap: 6px;
  border: 1px solid rgba(11, 114, 185, .18);
  background: #edf7ff;
  color: #07558e;
  line-height: 1.25;
}

.status-pill::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: currentColor;
  opacity: .8;
}

.status-pill.status-success {
  border-color: rgba(7, 138, 115, .26);
  background: #e8f7f3;
  color: #056753;
}

.status-pill.status-warning {
  border-color: rgba(181, 71, 8, .26);
  background: #fff7ed;
  color: #9a3412;
}

.status-pill.status-danger {
  border-color: rgba(197, 34, 31, .24);
  background: #fff1f0;
  color: #b42318;
}

.grid-action-btn {
  border-color: #ccdbe7;
  background: #fff;
}

.grid-action-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(15, 23, 42, .10);
}

.empty-row {
  background: #fbfdff;
}

@media (max-width: 760px) {
  .workspace-command-title h2 {
    white-space: normal;
  }

  .workspace-tab-rail label {
    flex-basis: 100%;
    max-width: none;
  }
}
