/* ===========================================================================
   /erp_dashboard — Internal dashboard shell
   Loads on top of apjakal_internal_theme.css. Uses .erp-shell as scope.
   =========================================================================== */

.erp-shell {
	/* Force-dark base for consistency (light mode toggled via [data-theme]) */
	--bg-base:        #0A0A0F;
	--bg-surface:     #13131A;
	--bg-elevated:    #1C1C26;
	--bg-input:       #1F1F2A;
	--text-hi:        #F4F4F5;
	--text-md:        #A1A1AA;
	--text-lo:        #71717A;
	--border:         #27272A;
	--border-strong:  #3F3F46;

	display: grid;
	grid-template-areas:
		"header header"
		"sidebar main";
	grid-template-columns: 244px 1fr;
	grid-template-rows: 64px 1fr;
	min-height: 100vh;
	background: var(--bg-base);
	color: var(--text-hi);
	font-family: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

.erp-shell[data-theme="light"] {
	--bg-base:        #FAFAFA;
	--bg-surface:     #FFFFFF;
	--bg-elevated:    #F4F4F5;
	--bg-input:       #FFFFFF;
	--text-hi:        #18181B;
	--text-md:        #52525B;
	--text-lo:        #A1A1AA;
	--border:         #E4E4E7;
	--border-strong:  #D4D4D8;
}

.erp-shell.collapsed {
	grid-template-columns: 64px 1fr;
}

.erp-shell *,
.erp-shell *::before,
.erp-shell *::after {
	box-sizing: border-box;
}

/* Hide stray Frappe website chrome on this surface */
body:has(.erp-shell) > .navbar,
body:has(.erp-shell) > footer,
body:has(.erp-shell) > .web-footer {
	display: none !important;
}

/* =========================================================================
   HEADER
   ========================================================================= */
.erp-shell-header {
	grid-area: header;
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 0 20px;
	background: var(--bg-surface);
	border-bottom: 1px solid var(--border);
	position: sticky;
	top: 0;
	z-index: 50;
}
.erp-sidebar-toggle {
	display: none;
}
.erp-shell-brand {
	display: flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
	flex-shrink: 0;
}
.erp-shell-brand img {
	display: block;
	height: 32px;
	width: auto;
}
.erp-shell-brand-tag {
	display: inline-block;
	padding: 3px 8px;
	border-radius: 6px;
	background: var(--primary-soft);
	color: #FBA9A2;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 1px;
	text-transform: uppercase;
	border: 1px solid rgba(244, 48, 36, 0.25);
}
.erp-shell-search {
	display: flex;
	align-items: center;
	gap: 8px;
	background: var(--bg-elevated);
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 0 12px;
	width: 320px;
	max-width: 40vw;
	height: 38px;
	margin-left: 12px;
}
.erp-shell-search i {
	width: 16px; height: 16px;
	color: var(--text-lo);
}
.erp-shell-search input {
	background: transparent;
	border: 0;
	outline: none;
	color: var(--text-hi);
	font-size: 14px;
	flex: 1;
	font-family: inherit;
}
.erp-shell-search input::placeholder {
	color: var(--text-lo);
}
.erp-shell-search kbd {
	background: var(--bg-base);
	border: 1px solid var(--border);
	border-radius: 4px;
	padding: 2px 6px;
	font-size: 11px;
	color: var(--text-lo);
	font-family: inherit;
}
.erp-shell-tools {
	margin-left: auto;
	display: flex;
	align-items: center;
	gap: 6px;
}
.erp-icon-btn {
	width: 38px;
	height: 38px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 10px;
	background: transparent;
	border: 1px solid transparent;
	color: var(--text-md);
	cursor: pointer;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
	text-decoration: none;
}
.erp-icon-btn:hover {
	background: var(--bg-elevated);
	border-color: var(--border);
	color: var(--text-hi);
}
.erp-icon-btn i { width: 18px; height: 18px; }

/* =========================================================================
   PROFILE DROPDOWN
   ========================================================================= */
.erp-profile { position: relative; }
.erp-profile-trigger {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 6px 12px 6px 6px;
	background: transparent;
	border: 1px solid transparent;
	border-radius: 999px;
	cursor: pointer;
	color: var(--text-hi);
	transition: background 0.15s ease, border-color 0.15s ease;
	font-family: inherit;
	font-size: 14px;
}
.erp-profile-trigger:hover {
	background: var(--bg-elevated);
	border-color: var(--border);
}
.erp-profile-trigger img,
.erp-avatar {
	width: 30px; height: 30px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--primary), #C0241B);
	color: white;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 600;
	font-size: 12px;
	letter-spacing: 0.4px;
	flex-shrink: 0;
	object-fit: cover;
}
.erp-profile-name {
	max-width: 140px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	font-weight: 500;
}
.erp-profile-trigger i {
	width: 14px; height: 14px;
	color: var(--text-lo);
}
.erp-profile-menu {
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	min-width: 240px;
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	box-shadow: 0 18px 48px rgba(0,0,0,0.45);
	padding: 6px;
	z-index: 60;
	overflow: hidden;
}
.erp-profile-head {
	padding: 12px;
	border-bottom: 1px solid var(--border);
	margin-bottom: 6px;
}
.erp-profile-name-lg {
	font-weight: 600;
	color: var(--text-hi);
	font-size: 14px;
}
.erp-profile-email {
	font-size: 12px;
	color: var(--text-md);
	margin-top: 2px;
}
.erp-menu-item {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
	padding: 9px 12px;
	background: transparent;
	border: 0;
	border-radius: 8px;
	color: var(--text-hi);
	font-size: 14px;
	cursor: pointer;
	text-align: left;
	text-decoration: none;
	font-family: inherit;
}
.erp-menu-item:hover {
	background: var(--bg-elevated);
	color: var(--primary);
}
.erp-menu-item i {
	width: 16px; height: 16px;
	color: var(--text-md);
}
.erp-menu-item:hover i {
	color: var(--primary);
}
.erp-menu-item-danger:hover {
	background: rgba(239, 68, 68, 0.10);
	color: #FCA5A5;
}
.erp-menu-item-danger:hover i {
	color: #FCA5A5;
}
.erp-menu-divider {
	height: 1px;
	background: var(--border);
	margin: 6px 4px;
}

/* =========================================================================
   SIDEBAR
   ========================================================================= */
.erp-shell-sidebar {
	grid-area: sidebar;
	background: var(--bg-base);
	border-right: 1px solid var(--border);
	overflow-y: auto;
	overflow-x: hidden;
	padding: 18px 12px;
	transition: width 0.2s ease;
}
.erp-sidenav-label {
	font-size: 11px;
	color: var(--text-lo);
	letter-spacing: 1.2px;
	text-transform: uppercase;
	padding: 12px 10px 6px;
	font-weight: 600;
	white-space: nowrap;
}
.erp-sidenav ul {
	list-style: none;
	padding: 0;
	margin: 0 0 10px;
}
.erp-sidenav-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 9px 10px;
	border-radius: 9px;
	color: var(--text-md);
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	margin-bottom: 2px;
	transition: background 0.15s ease, color 0.15s ease;
	white-space: nowrap;
}
.erp-sidenav-item i {
	width: 18px; height: 18px;
	flex-shrink: 0;
}
.erp-sidenav-item:hover {
	background: var(--bg-elevated);
	color: var(--text-hi);
}
.erp-sidenav-item.active {
	background: var(--primary-soft);
	color: var(--primary);
	box-shadow: inset 3px 0 0 var(--primary);
}

/* Collapsed sidebar — show icons only */
.erp-shell.collapsed .erp-sidenav-label,
.erp-shell.collapsed .erp-sidenav-item span {
	display: none;
}
.erp-shell.collapsed .erp-sidenav-item {
	justify-content: center;
	padding: 11px 0;
}
.erp-shell.collapsed .erp-shell-sidebar {
	padding: 18px 6px;
}

/* =========================================================================
   MAIN
   ========================================================================= */
.erp-shell-main {
	grid-area: main;
	padding: 32px 32px 64px;
	overflow-y: auto;
	background: var(--bg-base);
}
.erp-main-header {
	display: flex;
	justify-content: space-between;
	align-items: end;
	gap: 24px;
	margin-bottom: 28px;
	flex-wrap: wrap;
}
.erp-main-header h1 {
	margin: 0 0 4px;
	font-size: 26px;
	font-weight: 700;
	letter-spacing: -0.5px;
	color: var(--text-hi);
}
.erp-main-header p {
	margin: 0;
	color: var(--text-md);
	font-size: 15px;
}
.erp-main-meta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--text-md);
	font-size: 13px;
}
.erp-status-dot {
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--success);
	box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.18);
	animation: erp-status-pulse 2.4s ease-in-out infinite;
}
@keyframes erp-status-pulse {
	0%, 100% { box-shadow: 0 0 0 0    rgba(16, 185, 129, 0.30); }
	50%      { box-shadow: 0 0 0 6px  rgba(16, 185, 129, 0.00); }
}

/* =========================================================================
   GRID + CARDS
   ========================================================================= */
.erp-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
	gap: 20px;
}
.erp-card {
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 16px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: border-color 0.18s ease, transform 0.18s ease;
}
.erp-card:hover {
	border-color: var(--border-strong);
	transform: translateY(-2px);
}
.erp-card-glass {
	background: linear-gradient(180deg, rgba(28, 28, 38, 0.65), rgba(19, 19, 26, 0.85));
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: var(--shadow-md);
}
.erp-shell[data-theme="light"] .erp-card-glass {
	background: var(--bg-surface);
	backdrop-filter: none;
}
.erp-card-head {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding: 18px 20px 12px;
}
.erp-card-icon {
	flex-shrink: 0;
	width: 38px; height: 38px;
	border-radius: 10px;
	background: var(--primary-soft);
	color: var(--primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.erp-card-icon i { width: 18px; height: 18px; }
.erp-card-title-wrap { flex: 1; min-width: 0; }
.erp-card-title {
	margin: 0 0 2px;
	font-size: 16px;
	font-weight: 600;
	color: var(--text-hi);
}
.erp-card-blurb {
	margin: 0;
	font-size: 12px;
	color: var(--text-md);
	line-height: 1.45;
}
.erp-card-actions {
	display: flex;
	gap: 4px;
	flex-shrink: 0;
}
.erp-card-refresh {
	width: 32px; height: 32px;
	border-radius: 8px;
}
.erp-card-refresh i { width: 14px; height: 14px; }
.erp-card-refresh.spinning i {
	animation: erp-spin 0.8s linear infinite;
}
@keyframes erp-spin {
	to { transform: rotate(360deg); }
}
.erp-card-body {
	padding: 4px 20px 16px;
	flex: 1;
	min-height: 120px;
}
.erp-card-foot {
	padding: 12px 20px;
	border-top: 1px solid var(--border);
	display: flex;
	justify-content: flex-end;
}
.erp-link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	color: var(--primary);
	font-weight: 600;
	font-size: 13px;
	text-decoration: none;
	transition: gap 0.15s ease;
}
.erp-link:hover { gap: 8px; color: var(--primary-hover); }
.erp-link i { width: 14px; height: 14px; }

/* Skeleton loaders */
.erp-skeleton-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding-top: 8px;
}
.erp-skeleton {
	height: 14px;
	border-radius: 6px;
	background: linear-gradient(90deg, var(--bg-elevated), var(--bg-input), var(--bg-elevated));
	background-size: 200% 100%;
	animation: erp-shimmer 1.4s ease-in-out infinite;
}
@keyframes erp-shimmer {
	0%   { background-position: 200% 0; }
	100% { background-position: -200% 0; }
}

/* Phase-3 placeholder body */
.erp-card-placeholder {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 14px 0;
	color: var(--text-md);
	font-size: 13px;
}
.erp-card-placeholder i {
	width: 16px; height: 16px;
	color: var(--warning);
}
.erp-card-kpis {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
	padding: 8px 0 0;
}
.erp-kpi {
	background: var(--bg-base);
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 10px 12px;
}
.erp-kpi-label {
	display: block;
	font-size: 11px;
	color: var(--text-lo);
	letter-spacing: 0.4px;
	text-transform: uppercase;
	margin-bottom: 4px;
}
.erp-kpi-value {
	font-size: 16px;
	font-weight: 600;
	color: var(--text-hi);
}

/* Card error state */
.erp-card-error {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 14px 0;
	color: var(--danger);
	font-size: 13px;
}

/* Chart container — fixed height so cards don't jump */
.erp-chart-wrap {
	position: relative;
	width: 100%;
	height: 180px;
	margin: 12px 0 4px;
}

/* List items */
.erp-list {
	list-style: none;
	padding: 0;
	margin: 8px 0 0;
	display: flex;
	flex-direction: column;
}
.erp-list li + li { border-top: 1px solid var(--border); }
.erp-list a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding: 10px 0;
	text-decoration: none;
	color: var(--text-hi);
	transition: color 0.15s ease;
}
.erp-list a:hover { color: var(--primary); }
.erp-list-text   { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.erp-list-title  {
	font-size: 13px;
	font-weight: 500;
	color: var(--text-hi);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.erp-list-sub    {
	font-size: 11px;
	color: var(--text-md);
	margin-top: 1px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.erp-list-amount {
	font-size: 13px;
	font-weight: 600;
	color: var(--text-hi);
	white-space: nowrap;
	flex-shrink: 0;
}

/* =========================================================================
   MODULE SUB-PAGE  (/erp_dashboard/m/<id>)
   Reuses .erp-shell + .erp-card chrome from the main dashboard.
   ========================================================================= */
.erp-module-header {
	display: flex;
	align-items: center;
	gap: 18px;
	padding: 12px 0 24px;
	margin-bottom: 8px;
	border-bottom: 1px solid var(--border);
}
.erp-module-icon {
	flex-shrink: 0;
	width: 56px; height: 56px;
	border-radius: 14px;
	background: linear-gradient(135deg, var(--primary), #C0241B);
	color: white;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 24px rgba(244, 48, 36, 0.3);
}
.erp-module-icon i { width: 28px; height: 28px; }
.erp-module-meta h1 {
	margin: 0 0 4px;
	font-size: 26px;
	font-weight: 700;
	letter-spacing: -0.5px;
	color: var(--text-hi);
}
.erp-module-meta p {
	margin: 0;
	color: var(--text-md);
	font-size: 14px;
}

.erp-module-block {
	margin-bottom: 32px;
}
.erp-module-block-head {
	margin-bottom: 14px;
}
.erp-module-block-head h3 {
	margin: 0;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	color: var(--text-lo);
}

/* Shortcuts row */
.erp-shortcuts-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 12px;
}
.erp-shortcut {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	color: var(--text-hi);
	text-decoration: none;
	transition: border-color 0.15s ease, transform 0.15s ease, background 0.15s ease;
}
.erp-shortcut:hover {
	border-color: var(--primary);
	background: var(--bg-elevated);
	transform: translateY(-1px);
	color: var(--text-hi);
}
.erp-shortcut-icon {
	flex-shrink: 0;
	width: 36px; height: 36px;
	border-radius: 10px;
	background: var(--primary-soft);
	color: var(--primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.erp-shortcut-icon i { width: 18px; height: 18px; }
.erp-shortcut-label {
	font-size: 13px;
	font-weight: 500;
}

/* KPI tiles */
.erp-module-kpis {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 14px;
}
.erp-module-kpi {
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 16px 18px;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.erp-module-kpi-label {
	font-size: 11px;
	color: var(--text-lo);
	letter-spacing: 0.6px;
	text-transform: uppercase;
	font-weight: 600;
}
.erp-module-kpi-value {
	font-size: 26px;
	font-weight: 700;
	color: var(--text-hi);
	letter-spacing: -0.5px;
}

/* Charts */
.erp-module-charts {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
	gap: 18px;
}
.erp-module-chart {
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 16px;
}
.erp-module-chart-head { margin-bottom: 8px; }
.erp-module-chart-head h4 {
	margin: 0;
	font-size: 14px;
	font-weight: 600;
	color: var(--text-hi);
}
.erp-chart-empty {
	padding: 60px 0;
	text-align: center;
	color: var(--text-lo);
	font-size: 13px;
	font-style: italic;
}

/* Sub-section grid — reuses .erp-card from main dashboard */
.erp-module-subgrid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
	gap: 18px;
}

/* =========================================================================
   DOCUMENTS — DRMS hierarchical browser (/erp_dashboard/documents)
   ========================================================================= */
.erp-docs-head {
	display: flex;
	align-items: center;
	gap: 18px;
	padding: 12px 0 24px;
	margin-bottom: 8px;
	border-bottom: 1px solid var(--border);
}
.erp-docs-title { display: flex; align-items: center; gap: 18px; }
.erp-docs-icon {
	flex-shrink: 0;
	width: 56px; height: 56px;
	border-radius: 14px;
	background: linear-gradient(135deg, var(--primary), #C0241B);
	color: white;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 24px rgba(244, 48, 36, 0.3);
}
.erp-docs-icon i { width: 28px; height: 28px; }
.erp-docs-title h1 {
	margin: 0 0 4px;
	font-size: 26px;
	font-weight: 700;
	letter-spacing: -0.5px;
	color: var(--text-hi);
}
.erp-docs-title p { margin: 0; color: var(--text-md); font-size: 14px; }

.erp-docs-breadcrumb {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	margin: 0 0 20px;
	padding: 10px 14px;
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 10px;
	font-size: 13px;
}
.erp-docs-breadcrumb a {
	color: var(--text-md);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 6px;
	border-radius: 4px;
	transition: color 0.12s ease, background 0.12s ease;
}
.erp-docs-breadcrumb a:hover {
	color: var(--primary);
	background: var(--primary-soft);
}
.erp-docs-breadcrumb a i { width: 13px; height: 13px; }
.erp-bc-current {
	color: var(--text-hi);
	font-weight: 600;
	padding: 2px 6px;
}
.erp-bc-sep i {
	width: 13px; height: 13px;
	color: var(--text-lo);
}

.erp-docs-loading,
.erp-docs-error,
.erp-docs-empty {
	padding: 50px 20px;
	text-align: center;
	color: var(--text-md);
	font-size: 14px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
}
.erp-docs-loading i,
.erp-docs-error i,
.erp-docs-empty i {
	width: 32px; height: 32px;
	color: var(--text-lo);
}
.erp-docs-error i { color: var(--danger); }
.erp-docs-loading i { animation: erp-spin 1.2s linear infinite; }
.erp-docs-empty p { margin: 0; }

.erp-docs-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 12px;
}
.erp-docs-card {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 16px;
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	color: var(--text-hi);
	text-decoration: none;
	transition: border-color 0.15s ease, transform 0.15s ease, background 0.15s ease;
}
.erp-docs-card:hover {
	border-color: var(--primary);
	background: var(--bg-elevated);
	transform: translateY(-1px);
	color: var(--text-hi);
}
.erp-docs-card-icon {
	flex-shrink: 0;
	width: 36px; height: 36px;
	border-radius: 9px;
	background: var(--primary-soft);
	color: var(--primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.erp-docs-card-icon i { width: 18px; height: 18px; }
.erp-docs-card-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.erp-docs-card-title {
	font-size: 14px;
	font-weight: 600;
	color: var(--text-hi);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.erp-docs-card-sub {
	font-size: 11px;
	color: var(--text-md);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.erp-docs-card-arrow {
	flex-shrink: 0;
	width: 16px; height: 16px;
	color: var(--text-lo);
	transition: transform 0.15s ease, color 0.15s ease;
}
.erp-docs-card:hover .erp-docs-card-arrow {
	color: var(--primary);
	transform: translateX(2px);
}

/* File list (record level) */
.erp-docs-toolbar {
	margin-bottom: 14px;
	display: flex;
	gap: 10px;
}
.erp-docs-files {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.erp-docs-file {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 12px 16px;
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 10px;
	transition: border-color 0.15s ease;
}
.erp-docs-file:hover {
	border-color: var(--border-strong);
}
.erp-docs-file-icon {
	flex-shrink: 0;
	width: 44px; height: 44px;
	border-radius: 8px;
	background: var(--bg-elevated);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	color: var(--text-md);
}
.erp-docs-file-icon img {
	width: 100%; height: 100%;
	object-fit: cover;
}
.erp-docs-file-icon i { width: 22px; height: 22px; }
.erp-docs-file-icon-pdf  { background: rgba(239, 68, 68, 0.12); color: #FCA5A5; }
.erp-docs-file-icon-doc, .erp-docs-file-icon-docx { background: rgba(59, 130, 246, 0.12); color: #93C5FD; }
.erp-docs-file-icon-xls, .erp-docs-file-icon-xlsx, .erp-docs-file-icon-csv { background: rgba(16, 185, 129, 0.12); color: #6EE7B7; }
.erp-docs-file-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.erp-docs-file-name {
	font-size: 14px;
	font-weight: 500;
	color: var(--text-hi);
	text-decoration: none;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	transition: color 0.12s ease;
}
.erp-docs-file-name:hover { color: var(--primary); }
.erp-docs-file-sub {
	font-size: 11px;
	color: var(--text-md);
	display: flex;
	align-items: center;
	gap: 4px;
}
.erp-docs-file-action {
	flex-shrink: 0;
	width: 36px; height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 8px;
	color: var(--text-md);
	transition: background 0.12s ease, color 0.12s ease;
}
.erp-docs-file-action:hover {
	background: var(--primary-soft);
	color: var(--primary);
}
.erp-docs-file-action i { width: 16px; height: 16px; }

/* Active sidebar link */
.erp-sidenav-item.active {
	background: var(--primary-soft);
	color: var(--primary);
	box-shadow: inset 3px 0 0 var(--primary);
}

/* =========================================================================
   PERMISSIONS MANAGER  (/erp_dashboard/admin/permissions)
   ========================================================================= */
.erp-perms-head {
	display: flex;
	align-items: center;
	gap: 18px;
	padding: 12px 0 24px;
	margin-bottom: 8px;
	border-bottom: 1px solid var(--border);
}
.erp-perms-title { display: flex; align-items: center; gap: 18px; }
.erp-perms-icon {
	flex-shrink: 0;
	width: 56px; height: 56px;
	border-radius: 14px;
	background: linear-gradient(135deg, var(--primary), #C0241B);
	color: white;
	display: inline-flex; align-items: center; justify-content: center;
	box-shadow: 0 8px 24px rgba(244, 48, 36, 0.3);
}
.erp-perms-icon i { width: 28px; height: 28px; }
.erp-perms-title h1 {
	margin: 0 0 4px;
	font-size: 26px; font-weight: 700; letter-spacing: -0.5px;
	color: var(--text-hi);
}
.erp-perms-title p { margin: 0; color: var(--text-md); font-size: 14px; max-width: 720px; }

.erp-perms-tabs {
	display: flex;
	gap: 4px;
	padding: 4px;
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 10px;
	margin-bottom: 18px;
	width: fit-content;
}
.erp-perms-tab {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 16px;
	background: transparent;
	border: 0;
	border-radius: 7px;
	color: var(--text-md);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	font-family: inherit;
	transition: background 0.15s ease, color 0.15s ease;
}
.erp-perms-tab i { width: 16px; height: 16px; }
.erp-perms-tab:hover { color: var(--text-hi); }
.erp-perms-tab.active {
	background: var(--primary);
	color: var(--text-on-primary);
}

.erp-perms-pane {
	display: grid;
	grid-template-columns: 320px 1fr;
	gap: 18px;
	min-height: 600px;
}

/* Left list pane */
.erp-perms-list {
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	display: flex; flex-direction: column;
	max-height: calc(100vh - 280px);
	overflow: hidden;
}
.erp-perms-list-search {
	position: relative;
	padding: 12px;
	border-bottom: 1px solid var(--border);
}
.erp-perms-list-search i {
	position: absolute; left: 22px; top: 50%; transform: translateY(-50%);
	width: 16px; height: 16px; color: var(--text-lo); pointer-events: none;
}
.erp-perms-list-search input {
	width: 100%;
	padding: 8px 12px 8px 34px;
	background: var(--bg-elevated);
	border: 1px solid var(--border);
	border-radius: 8px;
	color: var(--text-hi);
	font-size: 13px;
	font-family: inherit;
}
.erp-perms-list-search input:focus {
	outline: none;
	border-color: var(--primary);
	box-shadow: 0 0 0 3px var(--primary-glow);
}
.erp-perms-list-items {
	overflow-y: auto;
	flex: 1;
	padding: 6px;
}
.erp-perms-list-item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 10px;
	border-radius: 8px;
	color: var(--text-hi);
	text-decoration: none;
	transition: background 0.12s ease;
	margin-bottom: 2px;
}
.erp-perms-list-item:hover { background: var(--bg-elevated); }
.erp-perms-list-item.active {
	background: var(--primary-soft);
	color: var(--primary);
}
.erp-perms-list-avatar {
	flex-shrink: 0;
	width: 32px; height: 32px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--primary), #C0241B);
	color: white;
	display: inline-flex; align-items: center; justify-content: center;
	font-size: 11px; font-weight: 700;
	overflow: hidden;
	object-fit: cover;
}
.erp-perms-list-avatar img { width: 100%; height: 100%; object-fit: cover; }
.erp-perms-list-avatar-text { background: linear-gradient(135deg, var(--primary), #C0241B); }
.erp-perms-list-avatar-role { background: var(--bg-elevated); color: var(--text-md); }
.erp-perms-list-avatar-role i { width: 14px; height: 14px; }
.erp-perms-list-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.erp-perms-list-title {
	font-size: 13px; font-weight: 500;
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.erp-perms-list-sub { font-size: 11px; color: var(--text-md); }

/* Detail pane */
.erp-perms-detail {
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	padding: 24px 28px;
	min-height: 400px;
	overflow-y: auto;
	max-height: calc(100vh - 280px);
}
.erp-perms-empty,
.erp-perms-loading,
.erp-perms-error {
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	gap: 12px;
	padding: 60px 20px;
	color: var(--text-md);
	text-align: center;
}
.erp-perms-empty i,
.erp-perms-loading i,
.erp-perms-error i { width: 32px; height: 32px; color: var(--text-lo); }
.erp-perms-loading i { animation: erp-spin 1.2s linear infinite; }
.erp-perms-error i { color: var(--danger); }
.erp-perms-empty p,
.erp-perms-loading p,
.erp-perms-error p { margin: 0; max-width: 360px; font-size: 14px; }
.erp-perms-empty-list {
	padding: 30px 16px;
	text-align: center;
	color: var(--text-md);
	font-size: 13px;
}

.erp-perms-detail-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 16px;
	margin-bottom: 24px;
	padding-bottom: 18px;
	border-bottom: 1px solid var(--border);
}
.erp-perms-detail-meta {
	display: flex; align-items: center; gap: 14px;
}
.erp-perms-detail-avatar {
	flex-shrink: 0;
	width: 56px; height: 56px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--primary), #C0241B);
	color: white;
	display: inline-flex; align-items: center; justify-content: center;
	font-size: 18px; font-weight: 700;
	overflow: hidden;
	box-shadow: 0 6px 16px rgba(244, 48, 36, 0.25);
}
.erp-perms-detail-avatar img { width: 100%; height: 100%; object-fit: cover; }
.erp-perms-detail-meta h2 { margin: 0; font-size: 20px; color: var(--text-hi); }
.erp-perms-detail-sub { margin: 4px 0 0; font-size: 12px; color: var(--text-md); }
.erp-perms-detail-actions { display: flex; gap: 8px; }

.erp-perms-block { margin-bottom: 24px; }
.erp-perms-block-head {
	display: flex; align-items: center;
	justify-content: space-between;
	margin-bottom: 12px;
}
.erp-perms-block-head h3 {
	margin: 0;
	font-size: 13px; font-weight: 700;
	letter-spacing: 1.2px; text-transform: uppercase;
	color: var(--text-lo);
}
.erp-perms-block-count {
	font-size: 12px; color: var(--text-md);
}
.erp-perms-block-empty {
	padding: 16px;
	color: var(--text-lo);
	font-size: 13px;
	font-style: italic;
}

.erp-perms-roles {
	display: flex; flex-wrap: wrap; gap: 8px;
	align-items: center;
}
.erp-perms-role-chip {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 6px 4px 6px 12px;
	background: var(--primary-soft);
	color: var(--primary);
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
}
.erp-perms-role-revoke {
	display: inline-flex; align-items: center; justify-content: center;
	width: 18px; height: 18px;
	background: transparent;
	border: 0; border-radius: 50%;
	color: var(--primary); cursor: pointer;
	opacity: 0.6;
	transition: opacity 0.12s ease, background 0.12s ease;
}
.erp-perms-role-revoke:hover { opacity: 1; background: rgba(244, 48, 36, 0.18); }
.erp-perms-role-revoke i { width: 12px; height: 12px; }
.erp-perms-role-add {
	display: flex; gap: 6px; align-items: center; width: 100%;
	margin-top: 8px;
}
.erp-perms-role-add input {
	flex: 1;
	padding: 7px 12px;
	background: var(--bg-elevated);
	border: 1px solid var(--border);
	border-radius: 8px;
	color: var(--text-hi);
	font-size: 13px;
	font-family: inherit;
}
.erp-perms-role-add input:focus {
	outline: none; border-color: var(--primary);
	box-shadow: 0 0 0 3px var(--primary-glow);
}

.erp-perms-sections {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 6px;
}
.erp-perms-toggle {
	display: flex; align-items: center; gap: 8px;
	padding: 8px 12px;
	background: var(--bg-elevated);
	border: 1px solid var(--border);
	border-radius: 8px;
	cursor: pointer;
	font-size: 13px;
	color: var(--text-hi);
	transition: border-color 0.12s ease;
}
.erp-perms-toggle:hover { border-color: var(--border-strong); }
.erp-perms-toggle input { accent-color: var(--primary); cursor: pointer; }

.erp-perms-details {
	background: var(--bg-elevated);
	border: 1px solid var(--border);
	border-radius: 8px;
	margin-bottom: 8px;
	overflow: hidden;
}
.erp-perms-details summary {
	padding: 10px 14px;
	cursor: pointer;
	font-size: 13px;
	font-weight: 500;
	color: var(--text-hi);
	display: inline-flex; align-items: center; gap: 8px;
	user-select: none;
}
.erp-perms-details summary i { width: 14px; height: 14px; color: var(--text-md); }
.erp-perms-details[open] summary { border-bottom: 1px solid var(--border); }
.erp-perms-ws-list {
	display: flex; flex-direction: column;
}
.erp-perms-ws-row {
	display: grid;
	grid-template-columns: 1fr 130px auto;
	gap: 10px;
	align-items: center;
	padding: 8px 14px;
	font-size: 12px;
	border-top: 1px solid var(--border);
}
.erp-perms-ws-row:first-child { border-top: 0; }
.erp-perms-ws-row-edit {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
}
.erp-perms-ws-row-edit .erp-perms-ws-info {
	display: flex; flex-direction: column; gap: 2px;
	min-width: 200px; flex: 0 0 200px;
}
.erp-perms-ws-row-edit .erp-perms-ws-gates {
	flex: 1;
	display: flex; flex-wrap: wrap;
	gap: 6px;
	align-items: center;
}
.erp-perms-block-hint {
	margin: 0 0 12px;
	font-size: 12px;
	color: var(--text-md);
	font-style: italic;
}

.erp-perms-gate-chip {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 3px 4px 3px 10px;
	background: rgba(59, 130, 246, 0.10);
	color: #93C5FD;
	border: 1px solid rgba(59, 130, 246, 0.25);
	border-radius: 999px;
	font-size: 11px;
	font-weight: 600;
}
.erp-perms-gate-x {
	display: inline-flex; align-items: center; justify-content: center;
	width: 16px; height: 16px;
	background: transparent; border: 0; border-radius: 50%;
	color: #93C5FD;
	cursor: pointer; opacity: 0.6;
	transition: opacity 0.12s ease, background 0.12s ease;
}
.erp-perms-gate-x:hover { opacity: 1; background: rgba(59, 130, 246, 0.2); }
.erp-perms-gate-x i { width: 11px; height: 11px; }
.erp-perms-gate-add-btn {
	display: inline-flex; align-items: center; justify-content: center;
	width: 22px; height: 22px;
	background: var(--bg-elevated);
	border: 1px dashed var(--border-strong);
	border-radius: 50%;
	color: var(--text-md);
	cursor: pointer;
	transition: border-color 0.12s ease, color 0.12s ease;
}
.erp-perms-gate-add-btn:hover {
	border-color: var(--primary);
	color: var(--primary);
	border-style: solid;
}
.erp-perms-gate-add-btn i { width: 12px; height: 12px; }

/* Workspace tick/untick grid */
.erp-perms-ws-checks {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 8px;
}
.erp-perms-ws-check {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	background: var(--bg-elevated);
	border: 1px solid var(--border);
	border-radius: 8px;
	cursor: pointer;
	transition: border-color 0.12s ease, background 0.12s ease;
}
.erp-perms-ws-check:hover { border-color: var(--border-strong); }
.erp-perms-ws-check.is-ticked {
	border-color: var(--primary);
	background: var(--primary-soft);
}
.erp-perms-ws-check.is-no-role {
	cursor: not-allowed;
	opacity: 0.55;
}
.erp-perms-ws-check.is-no-role:hover { border-color: var(--border); }
.erp-perms-ws-check.is-blocked {
	border-color: var(--danger);
	background: rgba(239, 68, 68, 0.08);
}
.erp-perms-ws-check input[type="checkbox"] {
	flex-shrink: 0;
	width: 16px; height: 16px;
	accent-color: var(--primary);
	cursor: pointer;
}
.erp-perms-ws-check.is-no-role input { cursor: not-allowed; }
.erp-perms-ws-check-meta {
	flex: 1; min-width: 0;
	display: flex; flex-direction: column; gap: 2px;
}
.erp-perms-ws-check-name {
	font-size: 13px;
	font-weight: 500;
	color: var(--text-hi);
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.erp-perms-ws-check-sub {
	font-size: 11px;
	color: var(--text-md);
	display: flex; align-items: center; gap: 6px;
}

.erp-perms-gate-picker {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 3px;
	background: var(--bg-elevated);
	border: 1px solid var(--primary);
	border-radius: 8px;
	box-shadow: 0 4px 14px rgba(0,0,0,0.4);
}
.erp-perms-gate-input {
	width: 200px;
	padding: 5px 10px;
	background: var(--bg-input);
	border: 1px solid var(--border);
	border-radius: 6px;
	color: var(--text-hi);
	font-size: 12px;
	font-family: inherit;
}
.erp-perms-gate-input:focus { outline: none; border-color: var(--primary); }
.erp-perms-gate-cancel {
	display: inline-flex; align-items: center; justify-content: center;
	width: 24px; height: 24px;
	background: transparent;
	border: 0; border-radius: 4px;
	color: var(--text-md);
	cursor: pointer;
}
.erp-perms-gate-cancel:hover { background: rgba(0,0,0,0.2); color: var(--text-hi); }
.erp-perms-gate-cancel i { width: 13px; height: 13px; }
.erp-perms-ws-name {
	font-weight: 500; color: var(--text-hi);
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.erp-perms-ws-module { color: var(--text-md); font-size: 11px; }
.erp-perms-tag {
	font-size: 10px;
	padding: 2px 8px;
	border-radius: 999px;
	background: var(--bg-base);
	color: var(--text-md);
	border: 1px solid var(--border);
}
.erp-perms-tag-muted { color: var(--text-lo); }
.erp-perms-tag-danger {
	background: rgba(239, 68, 68, 0.12);
	color: #FCA5A5;
	border-color: rgba(239, 68, 68, 0.25);
}

.erp-perms-users-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 6px;
}
.erp-perms-user-chip {
	display: flex; align-items: center; gap: 8px;
	padding: 6px 10px;
	background: var(--bg-elevated);
	border: 1px solid var(--border);
	border-radius: 999px;
	font-size: 12px;
	color: var(--text-hi);
}
.erp-perms-user-chip img,
.erp-perms-user-chip .erp-perms-list-avatar-text {
	width: 22px; height: 22px;
	border-radius: 50%;
	font-size: 9px;
	display: inline-flex; align-items: center; justify-content: center;
	overflow: hidden;
	flex-shrink: 0;
}
.erp-perms-user-disabled { opacity: 0.5; }

.erp-perms-docperm-table {
	overflow-x: auto;
	border: 1px solid var(--border);
	border-radius: 8px;
	background: var(--bg-elevated);
}
.erp-perms-docperm-table table {
	width: 100%;
	border-collapse: collapse;
	font-size: 12px;
	color: var(--text-hi);
}
.erp-perms-docperm-table th,
.erp-perms-docperm-table td {
	padding: 8px 12px;
	text-align: left;
	border-bottom: 1px solid var(--border);
}
.erp-perms-docperm-table th {
	background: var(--bg-surface);
	color: var(--text-md);
	font-weight: 600;
	font-size: 11px;
	letter-spacing: 0.5px;
	text-transform: uppercase;
}
.erp-perms-docperm-table td:not(:first-child) {
	text-align: center;
	color: var(--success);
	font-weight: 700;
}
.erp-perms-note {
	padding: 8px 12px;
	font-size: 11px;
	color: var(--text-md);
	font-style: italic;
}

@media (max-width: 980px) {
	.erp-perms-pane { grid-template-columns: 1fr; }
	.erp-perms-list { max-height: 320px; }
}

/* Child pages — each is its own deep-dive page, rendered as a navigable card */
.erp-child-pages {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 14px;
}
.erp-child-page {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 18px;
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	color: var(--text-hi);
	text-decoration: none;
	transition: border-color 0.15s ease, transform 0.15s ease, background 0.15s ease;
}
.erp-child-page:hover {
	border-color: var(--primary);
	background: var(--bg-elevated);
	transform: translateY(-1px);
	color: var(--text-hi);
}
.erp-child-page-icon {
	flex-shrink: 0;
	width: 40px; height: 40px;
	border-radius: 10px;
	background: linear-gradient(135deg, var(--primary), #C0241B);
	color: white;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 12px rgba(244, 48, 36, 0.25);
}
.erp-child-page-icon i { width: 20px; height: 20px; }
.erp-child-page-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.erp-child-page-title {
	font-size: 14px;
	font-weight: 600;
	color: var(--text-hi);
}
.erp-child-page-blurb {
	font-size: 12px;
	color: var(--text-md);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.erp-child-page-arrow {
	flex-shrink: 0;
	width: 16px; height: 16px;
	color: var(--text-lo);
	transition: transform 0.15s ease, color 0.15s ease;
}
.erp-child-page:hover .erp-child-page-arrow {
	color: var(--primary);
	transform: translateX(2px);
}

/* =========================================================================
   GLOBAL SEARCH DROPDOWN
   ========================================================================= */
.erp-shell-search { position: relative; }
.erp-search-dropdown {
	position: absolute;
	top: calc(100% + 6px);
	left: 0; right: 0;
	min-width: 380px;
	max-height: 480px;
	overflow-y: auto;
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	box-shadow: 0 18px 48px rgba(0,0,0,0.50);
	padding: 6px;
	z-index: 70;
}
.erp-search-status {
	padding: 10px 14px;
	font-size: 12px;
	color: var(--text-lo);
	letter-spacing: 0.4px;
	text-transform: uppercase;
}
.erp-search-group-label {
	padding: 10px 14px 4px;
	font-size: 11px;
	color: var(--text-lo);
	letter-spacing: 1.2px;
	text-transform: uppercase;
	font-weight: 600;
}
/* Top-level DocType navigation hits get a primary-tinted label */
.erp-search-group-label-primary {
	color: var(--primary);
	background: var(--primary-soft);
	border-radius: 6px;
	margin: 4px 6px 0;
	padding: 6px 12px;
}
.erp-search-item-doctype-nav {
	display: flex;
	align-items: center;
	gap: 8px;
}
.erp-search-item-doctype-nav::before {
	content: "→";
	color: var(--primary);
	font-weight: 700;
}
.erp-search-item {
	display: flex;
	flex-direction: column;
	gap: 2px;
	padding: 8px 14px;
	border-radius: 8px;
	color: var(--text-hi);
	text-decoration: none;
	transition: background 0.12s ease;
}
.erp-search-item:hover {
	background: var(--bg-elevated);
	color: var(--primary);
}
.erp-search-title  {
	font-size: 13px;
	font-weight: 500;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.erp-search-snippet {
	font-size: 11px;
	color: var(--text-md);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* =========================================================================
   NOTIFICATION BELL
   ========================================================================= */
.erp-bell-wrap { position: relative; }
.erp-bell { position: relative; }
.erp-bell-badge {
	position: absolute;
	top: 4px;
	right: 4px;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	border-radius: 9999px;
	background: var(--primary);
	color: var(--text-on-primary);
	font-size: 10px;
	font-weight: 700;
	line-height: 18px;
	text-align: center;
	box-shadow: 0 0 0 2px var(--bg-surface);
	pointer-events: none;
}
.erp-bell-dropdown {
	position: absolute;
	top: calc(100% + 6px);
	right: 0;
	min-width: 360px;
	max-width: 420px;
	max-height: 520px;
	display: flex;
	flex-direction: column;
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 12px;
	box-shadow: 0 18px 48px rgba(0,0,0,0.50);
	z-index: 70;
	overflow: hidden;
}
.erp-bell-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 14px;
	border-bottom: 1px solid var(--border);
}
.erp-bell-head h4 {
	margin: 0;
	font-size: 14px;
	color: var(--text-hi);
	font-weight: 600;
}
.erp-bell-clear {
	background: transparent;
	border: 0;
	color: var(--primary);
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	padding: 4px 8px;
	border-radius: 6px;
	font-family: inherit;
}
.erp-bell-clear:hover {
	background: var(--primary-soft);
}
.erp-bell-list {
	overflow-y: auto;
	flex: 1;
	padding: 4px;
}
.erp-bell-empty {
	padding: 28px 14px;
	text-align: center;
	color: var(--text-md);
	font-size: 13px;
}
.erp-bell-item {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 10px 12px;
	border-radius: 8px;
	color: var(--text-hi);
	text-decoration: none;
	transition: background 0.12s ease;
}
.erp-bell-item:hover { background: var(--bg-elevated); }
.erp-bell-item-text { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.erp-bell-item-subject {
	font-size: 13px;
	font-weight: 500;
	color: var(--text-hi);
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
.erp-bell-unread .erp-bell-item-subject { font-weight: 600; }
.erp-bell-item-meta {
	font-size: 11px;
	color: var(--text-lo);
}
.erp-bell-item-dot {
	flex-shrink: 0;
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--primary);
	margin-top: 6px;
}

/* =========================================================================
   DESK-VIEW MODAL (iframe)
   ========================================================================= */
.erp-frame-modal {
	position: fixed;
	inset: 0;
	z-index: 200;
	background: var(--bg-base);
	display: flex;
	flex-direction: column;
	animation: erp-frame-in 0.18s ease-out;
}
@keyframes erp-frame-in {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}
body.erp-frame-open { overflow: hidden; }

.erp-frame-modal-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 20px;
	background: var(--bg-surface);
	border-bottom: 1px solid var(--border);
}
.erp-frame-title {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-weight: 600;
	font-size: 15px;
	color: var(--text-hi);
}
.erp-frame-title i { width: 18px; height: 18px; color: var(--primary); }
.erp-frame-modal-tools { display: flex; gap: 4px; }
.erp-frame-modal iframe {
	flex: 1;
	width: 100%;
	border: 0;
	background: #fff;  /* Frappe Desk light surface */
}

/* External-scope placeholder */
.erp-external-placeholder {
	max-width: 480px;
	margin: 80px auto;
	text-align: center;
	padding: 48px 32px;
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
}
.erp-external-placeholder i {
	width: 48px; height: 48px;
	color: var(--primary);
	margin-bottom: 18px;
}
.erp-external-placeholder h2 {
	margin: 0 0 10px;
	color: var(--text-hi);
	font-size: 22px;
}
.erp-external-placeholder p {
	margin: 0 0 24px;
	color: var(--text-md);
}

/* Empty grid (user has no allowed sections) */
.erp-empty-grid {
	grid-column: 1 / -1;
	text-align: center;
	padding: 64px 32px;
	color: var(--text-md);
}
.erp-empty-grid i { width: 36px; height: 36px; color: var(--text-lo); margin-bottom: 12px; }
.erp-empty-grid h3 { margin: 0 0 6px; color: var(--text-hi); font-size: 18px; }
.erp-empty-grid p  { margin: 0; }

/* KPI trend arrow */
.erp-kpi-value {
	display: inline-flex;
	align-items: center;
	gap: 4px;
}
.erp-kpi-trend {
	display: inline-block;
	width: 0; height: 0;
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
}
.erp-kpi-trend-up   { border-bottom: 5px solid var(--success); }
.erp-kpi-trend-down { border-top:    5px solid var(--danger); }

/* =========================================================================
   TOUR
   ========================================================================= */
.erp-tour {
	position: fixed;
	inset: 0;
	z-index: 1000;
}
.erp-tour-overlay {
	position: absolute;
	inset: 0;
	background: rgba(10, 10, 15, 0.78);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}
.erp-tour-tooltip {
	position: absolute;
	min-width: 320px;
	max-width: 400px;
	padding: 22px;
	background: var(--bg-surface);
	border: 1px solid var(--border);
	border-radius: 14px;
	box-shadow: 0 20px 60px rgba(0,0,0,0.6);
	color: var(--text-hi);
}
.erp-tour-step {
	font-size: 11px;
	color: var(--primary);
	font-weight: 700;
	letter-spacing: 1px;
	text-transform: uppercase;
}
.erp-tour-tooltip h3 {
	margin: 6px 0 6px;
	font-size: 18px;
	color: var(--text-hi);
}
.erp-tour-tooltip p {
	margin: 0 0 18px;
	font-size: 14px;
	color: var(--text-md);
	line-height: 1.55;
}
.erp-tour-actions {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
}
.erp-tour-skip {
	font-size: 12px;
	color: var(--text-md);
	display: inline-flex;
	align-items: center;
	gap: 6px;
	cursor: pointer;
}
.erp-tour-skip input { accent-color: var(--primary); }
.erp-tour-buttons { display: flex; gap: 6px; }

.erp-btn-sm {
	padding: 6px 12px;
	border-radius: 7px;
	font-size: 13px;
	font-weight: 600;
	border: 1px solid var(--border);
	background: var(--bg-elevated);
	color: var(--text-hi);
	cursor: pointer;
	font-family: inherit;
}
.erp-btn-sm:hover {
	background: var(--bg-input);
}
.erp-btn-primary-sm {
	background: var(--primary);
	color: var(--text-on-primary);
	border-color: var(--primary);
}
.erp-btn-primary-sm:hover {
	background: var(--primary-hover);
	border-color: var(--primary-hover);
}
.erp-btn-ghost { background: transparent; }

/* Tour highlight */
.erp-tour-highlight {
	position: relative;
	z-index: 1001;
	box-shadow: 0 0 0 4px var(--primary), 0 0 0 8px rgba(244, 48, 36, 0.25);
	border-radius: 8px;
	transition: box-shadow 0.2s ease;
}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 980px) {
	.erp-shell {
		grid-template-columns: 0 1fr;
		grid-template-areas: "header header" "main main";
	}
	.erp-shell-sidebar {
		position: fixed;
		top: 64px; bottom: 0; left: 0;
		width: 244px;
		transform: translateX(-100%);
		transition: transform 0.2s ease;
		z-index: 40;
	}
	.erp-shell.sidebar-open .erp-shell-sidebar {
		transform: translateX(0);
	}
	.erp-sidebar-toggle { display: inline-flex; }
	.erp-shell-search { display: none; }
	.erp-profile-name { display: none; }
}
@media (max-width: 640px) {
	.erp-shell-main { padding: 24px 16px 48px; }
	.erp-shell-brand-tag { display: none; }
	.erp-grid { grid-template-columns: 1fr; }
	.erp-card-kpis { grid-template-columns: repeat(2, 1fr); }
}

@media (prefers-reduced-motion: reduce) {
	.erp-skeleton, .erp-status-dot, .erp-card-refresh.spinning i { animation: none; }
}

/* ── Change Password modal ────────────────────────────────── */
.erp-cp-modal {
	position: fixed;
	inset: 0;
	background: rgba(10, 10, 15, 0.55);
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
}
.erp-cp-modal[hidden] { display: none; }
.erp-cp-card {
	background: var(--erp-surface, #13131A);
	color: var(--erp-text, #E5E7EB);
	border: 1px solid var(--erp-border, #2A2A35);
	border-radius: 12px;
	width: 100%;
	max-width: 440px;
	padding: 22px 24px;
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.45);
}
.erp-cp-head {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 16px;
}
.erp-cp-head h3 {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 600;
	flex: 1;
}
.erp-cp-head i[data-lucide="key-round"] {
	color: var(--erp-primary, #F43024);
}
.erp-cp-head .erp-icon-btn { margin-left: 0; }
#erp-cp-form label {
	display: block;
	font-size: 0.78rem;
	color: var(--erp-text-muted, #9CA3AF);
	margin-bottom: 12px;
}
#erp-cp-form input {
	display: block;
	width: 100%;
	margin-top: 4px;
	padding: 8px 12px;
	background: var(--erp-bg, #0A0A0F);
	color: var(--erp-text, #E5E7EB);
	border: 1px solid var(--erp-border, #2A2A35);
	border-radius: 6px;
	font-size: 0.92rem;
}
#erp-cp-form input:focus {
	outline: none;
	border-color: var(--erp-primary, #F43024);
}
.erp-cp-msg {
	font-size: 0.78rem;
	color: #F43024;
	min-height: 18px;
	margin: 4px 0 10px;
}
.erp-cp-msg-ok { color: #3DAF6F; }
.erp-cp-actions {
	display: flex;
	justify-content: flex-end;
	gap: 8px;
}
.erp-shell[data-theme="light"] .erp-cp-card {
	background: #ffffff;
	color: #0A0A0F;
}
.erp-shell[data-theme="light"] #erp-cp-form input {
	background: #F8F8FA;
	color: #0A0A0F;
}

/* ─── My Helpdesk KPI strip (employee welcome) ───────────────────────── */
.erp-my-kpis {
	margin: 0 0 24px;
	padding: 18px 20px 16px;
	border: 1px solid var(--erp-border, #2A2A35);
	border-radius: 14px;
	background: linear-gradient(180deg,
		rgba(244, 48, 36, 0.06),
		rgba(19, 19, 26, 0.4));
	backdrop-filter: blur(6px);
}
.erp-my-kpis-head {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 14px;
}
.erp-my-kpis-head h2 {
	font-size: 0.95rem;
	font-weight: 600;
	margin: 0;
	color: var(--erp-text, #E5E7EB);
	letter-spacing: 0.2px;
}
.erp-my-kpis-head > i {
	width: 18px;
	height: 18px;
	color: var(--erp-primary, #F43024);
}
.erp-my-kpis-link {
	margin-left: auto;
	font-size: 0.82rem;
	display: inline-flex;
	align-items: center;
	gap: 4px;
}
.erp-my-kpis-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: 10px;
}
.erp-my-kpi {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	border: 1px solid var(--erp-border, #2A2A35);
	border-radius: 10px;
	background: var(--erp-surface, #13131A);
	transition: transform 0.15s ease, border-color 0.15s ease;
}
.erp-my-kpi:hover {
	transform: translateY(-1px);
	border-color: rgba(244, 48, 36, 0.5);
}
.erp-my-kpi-icon {
	width: 36px;
	height: 36px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(244, 48, 36, 0.12);
	color: var(--erp-primary, #F43024);
	flex-shrink: 0;
}
.erp-my-kpi-icon i { width: 18px; height: 18px; }
.erp-my-kpi-body { min-width: 0; }
.erp-my-kpi-value {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--erp-text, #E5E7EB);
	line-height: 1.1;
}
.erp-my-kpi-label {
	font-size: 0.78rem;
	color: var(--erp-text-dim, #9CA3AF);
	margin-top: 2px;
}
.erp-my-kpi-sub {
	font-size: 0.72rem;
	color: var(--erp-text-dim, #6B7280);
	margin-top: 1px;
}
.erp-kpi-good .erp-my-kpi-icon { background: rgba(61, 175, 111, 0.14); color: #3DAF6F; }
.erp-kpi-warn .erp-my-kpi-icon { background: rgba(245, 158, 11, 0.14); color: #F59E0B; }
.erp-kpi-bad  .erp-my-kpi-icon { background: rgba(244, 48, 36, 0.16); color: #F43024; }

.erp-shell[data-theme="light"] .erp-my-kpis {
	background: linear-gradient(180deg, rgba(244, 48, 36, 0.04), #ffffff);
}
.erp-shell[data-theme="light"] .erp-my-kpi { background: #F8F8FA; }
