/* =========================================================
   ppolom. Desk Theme — Clean Corporate
   Stripe/Linear-inspired. Blue for actions only.
   ========================================================= */

/* --- DM Sans font --- */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800&display=swap');

/* =========================================================
   CSS VARIABLES
   ========================================================= */
:root,
[data-theme="light"] {
	/* --- Brand --- */
	--btn-primary: #0067A5;
	--border-primary: #0067A5;
	--primary-color: #0067A5;
	--primary: #0067A5;
	--brand-color: #0067A5;

	/* --- Grayscale system --- */
	--gray-50: #F8FAFC;
	--gray-100: #F1F5F9;
	--gray-200: #E2E8F0;
	--gray-300: #CBD5E1;
	--gray-400: #94A3B8;
	--gray-500: #64748B;
	--gray-600: #475569;
	--gray-700: #334155;
	--gray-800: #1E293B;
	--gray-900: #0F172A;

	/* --- Blue scale (used sparingly) --- */
	--blue-50: #F0F7FF;
	--blue-100: #DBEAFE;
	--blue-200: #BFDBFE;
	--blue-300: #93C5FD;
	--blue-400: #60A5FA;
	--blue-500: #0080CC;
	--blue-600: #0067A5;
	--blue-700: #005A91;
	--blue-800: #004D7D;
	--blue-900: #002A4A;

	/* --- Frappe overrides --- */
	--navbar-bg: #FFFFFF;
	--sidebar-select-color: #F0F7FF;
	--checkbox-gradient: linear-gradient(180deg, #0067A5 -124.51%, #0067A5 100%);
	--checkbox-focus-shadow: 0 0 0 3px rgba(0, 103, 165, 0.25);
	--focus-default: 0 0 0 3px rgba(0, 103, 165, 0.2);
	--focus-blue: 0 0 0 3px rgba(0, 103, 165, 0.25);
	--highlight-shadow: 1px 1px 10px var(--gray-100), 0px 0px 4px rgba(0, 103, 165, 0.15);

	/* --- Text --- */
	--text-color: #1E293B;
	--text-muted: #64748B;
	--text-light: #94A3B8;

	/* --- Font --- */
	--font-stack: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* --- Dark mode variables --- */
[data-theme="dark"] {
	--btn-primary: #60A5FA;
	--border-primary: #60A5FA;
	--primary-color: #60A5FA;
	--primary: #60A5FA;
	--brand-color: #60A5FA;
	--checkbox-gradient: linear-gradient(180deg, #60A5FA -124.51%, #0080CC 100%);
	--checkbox-focus-shadow: 0 0 0 3px rgba(96, 165, 250, 0.3);
	--focus-default: 0 0 0 3px rgba(96, 165, 250, 0.25);
	--focus-blue: 0 0 0 3px rgba(96, 165, 250, 0.3);

	/* --- Dark grayscale --- */
	--gray-50: #1a1f2e;
	--gray-100: #1e2538;
	--gray-200: #2a3348;
	--gray-300: #3a4560;
	--gray-400: #6b7a96;
	--gray-500: #8b9ab4;
	--gray-600: #a0b0c8;
	--gray-700: #c0cede;
	--gray-800: #dde5f0;
	--gray-900: #eef2f8;

	/* --- Dark blue scale --- */
	--blue-50: #0d1b2e;
	--blue-100: #122640;
	--blue-200: #1a3358;
	--blue-300: #2a4a78;
	--blue-400: #60A5FA;
	--blue-500: #60A5FA;
	--blue-600: #60A5FA;

	/* --- Frappe overrides --- */
	--navbar-bg: #0f1420;
	--sidebar-select-color: #1a2540;
	--highlight-shadow: 0px 1px 10px rgba(0, 0, 0, 0.4), 0px 0px 4px rgba(96, 165, 250, 0.15);

	/* --- Text --- */
	--text-color: #e2e8f0;
	--text-muted: #8b9ab4;
	--text-light: #6b7a96;
}

/* =========================================================
   GLOBAL TYPOGRAPHY — DM Sans everywhere
   ========================================================= */
body,
.frappe-control,
.frappe-list,
.page-container,
.modal,
.dropdown-menu,
.popover,
.tooltip {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
	color: #1E293B;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.text-muted,
.text-secondary {
	color: #64748B !important;
}

/* =========================================================
   NAVBAR — Clean white
   ========================================================= */
header .navbar {
	background-color: #FFFFFF !important;
	border-bottom: 1px solid #E2E8F0 !important;
	box-shadow: none !important;
}

/* Navbar logo — SVG wordmark */
header .navbar .navbar-brand .app-logo {
	max-height: 28px !important;
	width: auto !important;
}

header .navbar .navbar-brand .app-logo,
header .navbar .navbar-brand img {
	filter: none !important;
}

/* Navbar text & icons: gray, not black */
header .navbar .navbar-nav .nav-link,
header .navbar .notifications-icon,
header .navbar .navbar-icon-text {
	color: #64748B !important;
	font-weight: 500;
}

header .navbar .navbar-nav .nav-link:hover {
	color: #1E293B !important;
}

header .navbar .navbar-right .nav-link svg,
header .navbar .navbar-right .dropdown-toggle svg {
	stroke: #64748B;
}

header .navbar .navbar-right .nav-link:hover svg {
	stroke: #1E293B;
}

/* Search bar */
header .navbar .search-bar {
	background: #F8FAFC !important;
	border: 1px solid #E2E8F0 !important;
	border-radius: 8px !important;
	transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

header .navbar .search-bar:hover {
	border-color: #CBD5E1 !important;
}

header .navbar .search-bar input {
	color: #1E293B !important;
	font-family: 'DM Sans', -apple-system, sans-serif !important;
}

header .navbar .search-bar .search-icon {
	color: #94A3B8 !important;
}

header .navbar .search-bar input::placeholder {
	color: #94A3B8 !important;
}

header .navbar .search-bar:focus-within {
	background: #FFFFFF !important;
	border-color: #0067A5 !important;
	box-shadow: 0 0 0 3px rgba(0, 103, 165, 0.12) !important;
}

header .navbar .search-bar:focus-within .search-icon {
	color: #0067A5 !important;
}

/* Hamburger */
header .navbar .burger-menu svg {
	stroke: #64748B;
}

/* Avatar — blue gradient like mockup */
header .navbar .avatar-frame,
header .navbar .avatar {
	background: linear-gradient(135deg, #0067A5, #60A5FA) !important;
	color: #FFFFFF !important;
	border: none !important;
	font-weight: 700;
	font-size: 11px;
}

/* Override any Frappe-generated background color on the avatar */
header .navbar .avatar-frame .standard-image,
header .navbar .standard-image {
	background: linear-gradient(135deg, #0067A5, #60A5FA) !important;
	color: #FFFFFF !important;
	font-weight: 700;
}

/* "Help" text in navbar */
header .navbar .navbar-nav .nav-link .navbar-icon-text {
	font-size: 13px;
	font-weight: 500;
}

/* =========================================================
   SIDEBAR — Light gray, compact, refined
   ========================================================= */
.desk-sidebar {
	background-color: #F8FAFC !important;
	border-right: 1px solid #E2E8F0 !important;
	padding-top: 12px !important;
}

.layout-side-section {
	background-color: #F8FAFC !important;
}

/* Section labels — small uppercase */
.desk-sidebar .sidebar-label,
.desk-sidebar .sidebar-menu .sidebar-label,
.desk-sidebar .sidebar-menu > li > .sidebar-label {
	font-size: 10px !important;
	font-weight: 600 !important;
	color: #94A3B8 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.8px !important;
	padding: 4px 12px !important;
	margin-bottom: 2px !important;
}

/* All sidebar items — compact */
.desk-sidebar .sidebar-menu .sidebar-menu-item a {
	position: relative;
	color: #64748B !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	padding: 6px 12px !important;
	margin: 1px 8px !important;
	border-radius: 6px !important;
	transition: color 150ms, background 150ms;
	line-height: 1.4 !important;
}

/* Sidebar icons — smaller, thinner, lighter */
.desk-sidebar .sidebar-menu .sidebar-menu-item a svg,
.desk-sidebar .sidebar-menu .sidebar-menu-item a .icon {
	width: 16px !important;
	height: 16px !important;
	min-width: 16px !important;
	stroke-width: 1.5px;
	color: #94A3B8 !important;
	stroke: #94A3B8;
}

/* Hover: gray only */
.desk-sidebar .sidebar-menu .sidebar-menu-item a:hover {
	color: #1E293B !important;
	background: #F1F5F9 !important;
}

.desk-sidebar .sidebar-menu .sidebar-menu-item a:hover svg,
.desk-sidebar .sidebar-menu .sidebar-menu-item a:hover .icon {
	color: #64748B !important;
	stroke: #64748B;
}

/* Selected: blue left border + subtle blue bg */
.desk-sidebar .sidebar-menu .sidebar-menu-item a.selected,
.desk-sidebar .sidebar-menu .sidebar-menu-item a.selected:hover {
	background: #F0F7FF !important;
	color: #0067A5 !important;
	font-weight: 600 !important;
}

.desk-sidebar .sidebar-menu .sidebar-menu-item a.selected::before {
	content: '';
	position: absolute;
	left: 0;
	top: 4px;
	bottom: 4px;
	width: 3px;
	background: #0067A5;
	border-radius: 0 3px 3px 0;
}

.desk-sidebar .sidebar-menu .sidebar-menu-item a.selected svg,
.desk-sidebar .sidebar-menu .sidebar-menu-item a.selected .icon {
	stroke: #0067A5 !important;
	color: #0067A5 !important;
}

/* Sidebar expand/collapse chevrons — smaller */
.desk-sidebar .sidebar-menu .sidebar-menu-item .drop-icon {
	width: 14px !important;
	height: 14px !important;
	color: #94A3B8;
}

/* =========================================================
   PAGE HEAD
   ========================================================= */

/* Default page-head — single-row compact bar */
.page-head {
	border-bottom: 1px solid #E2E8F0;
	padding-top: 2px !important;
	padding-bottom: 2px !important;
	min-height: unset !important;
	height: auto !important;
}

.page-head .container {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}

/* Collapse page-head into single row: title left, actions right */
.page-head .page-head-content {
	display: flex !important;
	align-items: center !important;
	flex-wrap: nowrap !important;
	min-height: unset !important;
	padding: 4px 0 !important;
}

/* Hide the separate title row on list views — breadcrumb in navbar is enough */
.page-head .page-title .title-area {
	margin-bottom: 0 !important;
}

.page-head .page-title .title-text {
	color: #1E293B;
	font-size: 16px !important;
	font-weight: 700;
	letter-spacing: -0.3px;
}

/* Actions row — no extra margin */
.page-head .page-actions {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

/* Shrink action buttons in page-head */
.page-head .page-actions .btn {
	padding: 4px 10px !important;
	font-size: 12px !important;
}

.page-head .page-actions .btn-primary {
	padding: 5px 12px !important;
	font-size: 12px !important;
}

/* Injected workspace title — inside content area */
.ppolom-page-title {
	font-size: 18px;
	font-weight: 700;
	color: #1E293B;
	letter-spacing: -0.4px;
	padding: 20px 0 14px;
	margin: 0 0 4px;
	border-bottom: 1px solid #E2E8F0;
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* Burger moved to navbar via JS — hide original in page-head */
.page-head .sidebar-toggle-btn {
	display: none !important;
}

/* Burger in navbar — clean simple hamburger */
header.navbar .sidebar-toggle-btn {
	background: none;
	border: none;
	padding: 4px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 6px;
	transition: background 150ms;
}

header.navbar .sidebar-toggle-btn:hover {
	background: #F1F5F9;
}

/* Hide Frappe's default icons (hamburger + collapse arrows) */
header.navbar .sidebar-toggle-btn .sidebar-toggle-placeholder,
header.navbar .sidebar-toggle-btn .sidebar-toggle-icon {
	display: none !important;
}

/* Replace with a clean CSS hamburger */
header.navbar .sidebar-toggle-btn::before {
	content: '';
	display: block;
	width: 16px;
	height: 2px;
	background: #64748B;
	box-shadow: 0 5px 0 #64748B, 0 10px 0 #64748B;
	border-radius: 1px;
	transition: background 150ms, box-shadow 150ms;
	/* Offset upward to center all 3 lines (total height ~12px) within the button */
	transform: translateY(-5px);
}

header.navbar .sidebar-toggle-btn:hover::before {
	background: #1E293B;
	box-shadow: 0 5px 0 #1E293B, 0 10px 0 #1E293B;
}

/* Also hide the original burger icons in page-head (fallback) */
.page-head .sidebar-toggle-btn .sidebar-toggle-placeholder,
.page-head .sidebar-toggle-btn .sidebar-toggle-icon {
	display: none !important;
}

/* =========================================================
   BUTTONS
   ========================================================= */

/* Primary */
.btn-primary,
.btn-primary-dark {
	background-color: #0067A5 !important;
	border-color: #0067A5 !important;
	color: #FFFFFF !important;
	font-weight: 600;
	border-radius: 8px;
	transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary-dark:hover {
	background-color: #005A91 !important;
	border-color: #005A91 !important;
	box-shadow: 0 4px 12px rgba(0, 103, 165, 0.2);
}

.btn-primary:active {
	background-color: #004D7D !important;
	border-color: #004D7D !important;
}

/* Secondary / Default — white with gray border */
.btn-default,
.btn-secondary {
	background-color: #FFFFFF !important;
	border: 1px solid #CBD5E1 !important;
	color: #1E293B !important;
	font-weight: 500;
	border-radius: 8px;
	transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.btn-default:hover,
.btn-secondary:hover {
	background-color: #F8FAFC !important;
	border-color: #94A3B8 !important;
}

/* All buttons get rounded corners */
.btn {
	border-radius: 8px;
}

/* =========================================================
   LINKS
   ========================================================= */
a {
	color: #1A6FA8;
	transition: color 150ms;
}

a:hover {
	color: #0B5D94;
}

/* =========================================================
   FORM INPUTS — Refined borders, blue focus
   ========================================================= */
.frappe-control input,
.frappe-control select,
.frappe-control textarea,
.form-control {
	border-color: #CBD5E1;
	color: #1E293B;
	border-radius: 8px;
	font-family: 'DM Sans', -apple-system, sans-serif !important;
	transition: border-color 150ms, box-shadow 150ms;
}

.frappe-control input:focus,
.frappe-control select:focus,
.frappe-control textarea:focus,
.form-control:focus {
	border-color: #0067A5 !important;
	box-shadow: 0 0 0 3px rgba(0, 103, 165, 0.12) !important;
}

/* Checkbox / switch */
.frappe-control[data-fieldtype="Check"] input:checked + .label-area::before,
input[type="checkbox"]:checked + .label-area::before {
	background-color: #0067A5;
	border-color: #0067A5;
}

.toggle-switch input:checked + .slider {
	background-color: #0067A5;
}

/* =========================================================
   TABLES & LISTS — Gray headers, clean rows
   ========================================================= */
.frappe-list .list-row-head,
.report-wrapper .dt-header .dt-row-header,
.frappe-list .list-header {
	background-color: #F8FAFC;
	color: #64748B;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.3px;
}

.frappe-list .list-row:hover,
.report-wrapper .dt-row:hover {
	background-color: #F1F5F9;
}

.frappe-list .list-row {
	border-bottom-color: #E2E8F0;
	transition: background 150ms;
}

/* =========================================================
   TABS
   ========================================================= */
.nav-tabs .nav-link.active,
.nav-tabs .nav-link.active:hover {
	border-bottom-color: #0067A5 !important;
	color: #0067A5 !important;
	font-weight: 600;
}

.nav-tabs .nav-link {
	color: #64748B;
	font-weight: 500;
	transition: color 150ms;
}

.nav-tabs .nav-link:hover {
	color: #1E293B;
}

/* =========================================================
   STATUS BADGES — Semantic colors, no blue
   ========================================================= */

/* Draft / Not Saved — Gray */
.indicator-pill.gray,
.indicator-pill[data-indicator="gray"],
.indicator-pill.darkgrey,
.indicator-pill[data-indicator="darkgrey"] {
	background-color: #F1F5F9;
	color: #475569;
}

/* Submitted / Active — Amber */
.indicator-pill.blue,
.indicator-pill[data-indicator="blue"] {
	background-color: #FEF3C7;
	color: #92400E;
}

/* Paid / Completed / Success — Green */
.indicator-pill.green,
.indicator-pill[data-indicator="green"] {
	background-color: #DCFCE7;
	color: #166534;
}

/* Cancelled / Error — Red */
.indicator-pill.red,
.indicator-pill[data-indicator="red"] {
	background-color: #FEE2E2;
	color: #991B1B;
}

/* Overdue / Urgent — Orange */
.indicator-pill.orange,
.indicator-pill[data-indicator="orange"] {
	background-color: #FFEDD5;
	color: #9A3412;
}

/* Return / Credit — Purple */
.indicator-pill.purple,
.indicator-pill[data-indicator="purple"] {
	background-color: #F3E8FF;
	color: #6B21A8;
}

/* Yellow */
.indicator-pill.yellow,
.indicator-pill[data-indicator="yellow"] {
	background-color: #FEF9C3;
	color: #854D0E;
}

/* Cyan / Light Blue */
.indicator-pill.cyan,
.indicator-pill.light-blue,
.indicator-pill[data-indicator="cyan"],
.indicator-pill[data-indicator="light-blue"] {
	background-color: #ECFEFF;
	color: #155E75;
}

/* All indicator pills — rounded, clean */
.indicator-pill {
	border-radius: 99px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.01em;
	padding: 2px 10px;
}

/* =========================================================
   BADGES
   ========================================================= */
.badge-primary {
	background-color: #0067A5 !important;
}

/* =========================================================
   PROGRESS BARS
   ========================================================= */
.progress-bar {
	background-color: #0067A5;
}

.progress {
	border-radius: 99px;
	background-color: #E2E8F0;
}

/* =========================================================
   AWESOMEBAR
   ========================================================= */
.awesomebar:focus-within {
	border-color: #0067A5;
	box-shadow: 0 0 0 3px rgba(0, 103, 165, 0.12);
}

/* =========================================================
   LIKE BUTTON
   ========================================================= */
.like-active-item .like-action,
.liked-by .like-action {
	color: #0067A5;
}

/* =========================================================
   TIMELINE / ACTIVITY
   ========================================================= */
.timeline-dot {
	background-color: #0067A5;
}

/* =========================================================
   WORKSPACE — Cards, shortcuts, widgets
   ========================================================= */

/* Shortcut widgets */
.widget.shortcut-widget-box {
	border-color: #E2E8F0;
	border-radius: 8px;
	transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.widget.shortcut-widget-box:hover {
	border-color: #0067A5;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

/* Card widgets */
.widget.widget-shadow {
	border: 1px solid #E2E8F0;
	border-radius: 12px;
	box-shadow: none;
	transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.widget.widget-shadow:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}

/* Widget titles */
.widget .widget-head .widget-title {
	font-weight: 700 !important;
	color: #1E293B !important;
	letter-spacing: -0.2px;
}

/* Workspace section headers */
.workspace-section .section-title {
	font-size: 14px;
	font-weight: 700;
	color: #1E293B;
	letter-spacing: -0.2px;
}

/* =========================================================
   NOTIFICATION DOT — Red (not blue)
   ========================================================= */
.notifications-indicator {
	background-color: #DC2626 !important;
}

/* =========================================================
   SECTION HEADS IN FORMS
   ========================================================= */
.section-head {
	color: #1E293B;
	font-weight: 700;
	letter-spacing: -0.2px;
}

/* =========================================================
   DROPDOWNS — Clean, elevated
   ========================================================= */
.dropdown-menu {
	border: 1px solid #E2E8F0;
	border-radius: 8px;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08), 0 1px 3px rgba(0, 0, 0, 0.04);
	padding: 4px;
}

.dropdown-item {
	border-radius: 6px;
	font-size: 13px;
	font-weight: 500;
	color: #1E293B;
	transition: background 150ms;
}

.dropdown-item:hover,
.dropdown-item:focus {
	background-color: #F1F5F9;
	color: #1E293B;
}

.dropdown-item.active,
.dropdown-item:active {
	background-color: #F0F7FF;
	color: #0067A5;
}

/* =========================================================
   MODALS — Clean borders
   ========================================================= */
.modal-content {
	border-radius: 12px;
	border: 1px solid #E2E8F0;
}

.modal-header {
	border-bottom-color: #E2E8F0;
}

.modal-footer {
	border-top-color: #E2E8F0;
}

/* =========================================================
   ONBOARDING — Use green for complete, not blue
   ========================================================= */
.onboarding-steps .step-text a {
	color: #1A6FA8 !important;
}

.onboarding-steps .step.complete .step-icon {
	color: #166534;
}

.onboarding-steps .step.complete .step-icon svg {
	stroke: #166534;
}

/* =========================================================
   LOGIN PAGE
   ========================================================= */
.page-card .page-card-head {
	border-top: 3px solid #0067A5;
}

/* Hide the logo image — the h4 text IS the brand */
.page-card-head .app-logo {
	display: none !important;
}

/* Style "Login to ppolom." so "ppolom." looks like the logo */
.page-card-head h4 {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
	font-size: 28px;
	font-weight: 800;
	color: #0067A5;
	letter-spacing: -0.3px;
	margin-top: 8px;
}

.page-card .btn-primary {
	background-color: #0067A5 !important;
	border-color: #0067A5 !important;
}

.page-card .btn-primary:hover {
	background-color: #005A91 !important;
	border-color: #005A91 !important;
}

/* =========================================================
   FRAPPE CONTROL LABELS — Clean typography
   ========================================================= */
.frappe-control .control-label,
.frappe-control .label-area {
	font-size: 12px;
	font-weight: 600;
	color: #64748B;
	letter-spacing: 0.01em;
}

/* =========================================================
   COMMENT BOX / TIMELINE
   ========================================================= */
.comment-box .ql-editor {
	font-family: 'DM Sans', -apple-system, sans-serif !important;
}

/* =========================================================
   PRINT VIEW — Don't affect print
   ========================================================= */
@media print {
	body,
	.frappe-control,
	.frappe-list {
		font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
	}
}

/* =========================================================
   DARK MODE — Override all hardcoded light colors
   ========================================================= */

/* --- Typography --- */
[data-theme="dark"] body,
[data-theme="dark"] .frappe-control,
[data-theme="dark"] .frappe-list,
[data-theme="dark"] .page-container,
[data-theme="dark"] .modal,
[data-theme="dark"] .dropdown-menu,
[data-theme="dark"] .popover,
[data-theme="dark"] .tooltip {
	color: #e2e8f0;
}

[data-theme="dark"] .text-muted,
[data-theme="dark"] .text-secondary {
	color: #8b9ab4 !important;
}

/* --- Navbar --- */
[data-theme="dark"] header .navbar {
	background-color: #0f1420 !important;
	border-bottom: 1px solid #1e2538 !important;
}

[data-theme="dark"] header .navbar .navbar-nav .nav-link,
[data-theme="dark"] header .navbar .notifications-icon,
[data-theme="dark"] header .navbar .navbar-icon-text {
	color: #8b9ab4 !important;
}

[data-theme="dark"] header .navbar .navbar-nav .nav-link:hover {
	color: #e2e8f0 !important;
}

[data-theme="dark"] header .navbar .navbar-right .nav-link svg,
[data-theme="dark"] header .navbar .navbar-right .dropdown-toggle svg {
	stroke: #8b9ab4;
}

[data-theme="dark"] header .navbar .navbar-right .nav-link:hover svg {
	stroke: #e2e8f0;
}

/* Search bar */
[data-theme="dark"] header .navbar .search-bar {
	background: #1a1f2e !important;
	border: 1px solid #2a3348 !important;
}

[data-theme="dark"] header .navbar .search-bar:hover {
	border-color: #3a4560 !important;
}

[data-theme="dark"] header .navbar .search-bar input {
	color: #e2e8f0 !important;
}

[data-theme="dark"] header .navbar .search-bar .search-icon {
	color: #6b7a96 !important;
}

[data-theme="dark"] header .navbar .search-bar input::placeholder {
	color: #6b7a96 !important;
}

[data-theme="dark"] header .navbar .search-bar:focus-within {
	background: #1e2538 !important;
	border-color: #60A5FA !important;
	box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.15) !important;
}

[data-theme="dark"] header .navbar .search-bar:focus-within .search-icon {
	color: #60A5FA !important;
}

/* Hamburger */
[data-theme="dark"] header .navbar .burger-menu svg {
	stroke: #8b9ab4;
}

[data-theme="dark"] header.navbar .sidebar-toggle-btn:hover {
	background: #1e2538;
}

[data-theme="dark"] header.navbar .sidebar-toggle-btn::before {
	background: #8b9ab4;
	box-shadow: 0 5px 0 #8b9ab4, 0 10px 0 #8b9ab4;
	transform: translateY(-5px);
}

[data-theme="dark"] header.navbar .sidebar-toggle-btn:hover::before {
	background: #e2e8f0;
	box-shadow: 0 5px 0 #e2e8f0, 0 10px 0 #e2e8f0;
}

/* --- Sidebar --- */
[data-theme="dark"] .desk-sidebar {
	background-color: #0f1420 !important;
	border-right: 1px solid #1e2538 !important;
}

/* Fill sidebar parent so the color extends full height */
[data-theme="dark"] .layout-side-section {
	background-color: #0f1420 !important;
}

[data-theme="dark"] .desk-sidebar .sidebar-label,
[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-label,
[data-theme="dark"] .desk-sidebar .sidebar-menu > li > .sidebar-label {
	color: #6b7a96 !important;
}

[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item a {
	color: #8b9ab4 !important;
}

[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item a svg,
[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item a .icon {
	color: #6b7a96 !important;
	stroke: #6b7a96;
}

[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item a:hover {
	color: #e2e8f0 !important;
	background: #1a1f2e !important;
}

[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item a:hover svg,
[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item a:hover .icon {
	color: #a0b0c8 !important;
	stroke: #a0b0c8;
}

[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item a.selected,
[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item a.selected:hover {
	background: #1a2540 !important;
	color: #60A5FA !important;
}

[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item a.selected::before {
	background: #60A5FA;
}

[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item a.selected svg,
[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item a.selected .icon {
	stroke: #60A5FA !important;
	color: #60A5FA !important;
}

[data-theme="dark"] .desk-sidebar .sidebar-menu .sidebar-menu-item .drop-icon {
	color: #6b7a96;
}

/* --- Page Head --- */
[data-theme="dark"] .page-head {
	border-bottom: 1px solid #1e2538;
}

[data-theme="dark"] .page-head .page-title .title-text {
	color: #e2e8f0;
}

[data-theme="dark"] .ppolom-page-title {
	color: #e2e8f0;
	border-bottom: 1px solid #1e2538;
}

/* --- Buttons --- */
[data-theme="dark"] .btn-primary,
[data-theme="dark"] .btn-primary-dark {
	background-color: #2563EB !important;
	border-color: #2563EB !important;
	color: #FFFFFF !important;
}

[data-theme="dark"] .btn-primary:hover,
[data-theme="dark"] .btn-primary:focus,
[data-theme="dark"] .btn-primary-dark:hover {
	background-color: #1d4ed8 !important;
	border-color: #1d4ed8 !important;
	box-shadow: 0 4px 12px rgba(37, 99, 235, 0.3);
}

[data-theme="dark"] .btn-primary:active {
	background-color: #1e40af !important;
	border-color: #1e40af !important;
}

[data-theme="dark"] .btn-default,
[data-theme="dark"] .btn-secondary {
	background-color: #1a1f2e !important;
	border: 1px solid #2a3348 !important;
	color: #e2e8f0 !important;
}

[data-theme="dark"] .btn-default:hover,
[data-theme="dark"] .btn-secondary:hover {
	background-color: #1e2538 !important;
	border-color: #3a4560 !important;
}

/* --- Links --- */
[data-theme="dark"] a {
	color: #60A5FA;
}

[data-theme="dark"] a:hover {
	color: #93bbfd;
}

/* --- Form Inputs --- */
[data-theme="dark"] .frappe-control input,
[data-theme="dark"] .frappe-control select,
[data-theme="dark"] .frappe-control textarea,
[data-theme="dark"] .form-control {
	border-color: #2a3348;
	color: #e2e8f0;
	background-color: #1a1f2e;
}

[data-theme="dark"] .frappe-control input:focus,
[data-theme="dark"] .frappe-control select:focus,
[data-theme="dark"] .frappe-control textarea:focus,
[data-theme="dark"] .form-control:focus {
	border-color: #60A5FA !important;
	box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.15) !important;
	background-color: #1e2538;
}

[data-theme="dark"] .frappe-control[data-fieldtype="Check"] input:checked + .label-area::before,
[data-theme="dark"] input[type="checkbox"]:checked + .label-area::before {
	background-color: #60A5FA;
	border-color: #60A5FA;
}

[data-theme="dark"] .toggle-switch input:checked + .slider {
	background-color: #60A5FA;
}

/* --- Control Labels --- */
[data-theme="dark"] .frappe-control .control-label,
[data-theme="dark"] .frappe-control .label-area {
	color: #8b9ab4;
}

/* --- Tables & Lists --- */
[data-theme="dark"] .frappe-list .list-row-head,
[data-theme="dark"] .report-wrapper .dt-header .dt-row-header,
[data-theme="dark"] .frappe-list .list-header {
	background-color: #1a1f2e;
	color: #8b9ab4;
}

[data-theme="dark"] .frappe-list .list-row:hover,
[data-theme="dark"] .report-wrapper .dt-row:hover {
	background-color: #1e2538;
}

[data-theme="dark"] .frappe-list .list-row {
	border-bottom-color: #1e2538;
}

/* --- Tabs --- */
[data-theme="dark"] .nav-tabs .nav-link.active,
[data-theme="dark"] .nav-tabs .nav-link.active:hover {
	border-bottom-color: #60A5FA !important;
	color: #60A5FA !important;
}

[data-theme="dark"] .nav-tabs .nav-link {
	color: #8b9ab4;
}

[data-theme="dark"] .nav-tabs .nav-link:hover {
	color: #e2e8f0;
}

/* --- Status Badges (dark mode) --- */
[data-theme="dark"] .indicator-pill.gray,
[data-theme="dark"] .indicator-pill[data-indicator="gray"],
[data-theme="dark"] .indicator-pill.darkgrey,
[data-theme="dark"] .indicator-pill[data-indicator="darkgrey"] {
	background-color: #1e2538;
	color: #a0b0c8;
}

[data-theme="dark"] .indicator-pill.blue,
[data-theme="dark"] .indicator-pill[data-indicator="blue"] {
	background-color: #422006;
	color: #fbbf24;
}

[data-theme="dark"] .indicator-pill.green,
[data-theme="dark"] .indicator-pill[data-indicator="green"] {
	background-color: #052e16;
	color: #4ade80;
}

[data-theme="dark"] .indicator-pill.red,
[data-theme="dark"] .indicator-pill[data-indicator="red"] {
	background-color: #450a0a;
	color: #f87171;
}

[data-theme="dark"] .indicator-pill.orange,
[data-theme="dark"] .indicator-pill[data-indicator="orange"] {
	background-color: #431407;
	color: #fb923c;
}

[data-theme="dark"] .indicator-pill.purple,
[data-theme="dark"] .indicator-pill[data-indicator="purple"] {
	background-color: #2e1065;
	color: #c084fc;
}

[data-theme="dark"] .indicator-pill.yellow,
[data-theme="dark"] .indicator-pill[data-indicator="yellow"] {
	background-color: #422006;
	color: #facc15;
}

[data-theme="dark"] .indicator-pill.cyan,
[data-theme="dark"] .indicator-pill.light-blue,
[data-theme="dark"] .indicator-pill[data-indicator="cyan"],
[data-theme="dark"] .indicator-pill[data-indicator="light-blue"] {
	background-color: #083344;
	color: #22d3ee;
}

/* --- Workspace Widgets --- */
[data-theme="dark"] .widget.shortcut-widget-box {
	border-color: #1e2538;
}

[data-theme="dark"] .widget.shortcut-widget-box:hover {
	border-color: #60A5FA;
}

[data-theme="dark"] .widget.widget-shadow {
	border: 1px solid #1e2538;
}

[data-theme="dark"] .widget.widget-shadow:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .widget .widget-head .widget-title {
	color: #e2e8f0 !important;
}

[data-theme="dark"] .workspace-section .section-title {
	color: #e2e8f0;
}

/* --- Section Heads --- */
[data-theme="dark"] .section-head {
	color: #e2e8f0;
}

/* --- Dropdowns --- */
[data-theme="dark"] .dropdown-menu {
	border: 1px solid #2a3348;
	background-color: #161b28;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4), 0 1px 3px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .dropdown-item {
	color: #e2e8f0;
}

[data-theme="dark"] .dropdown-item:hover,
[data-theme="dark"] .dropdown-item:focus {
	background-color: #1e2538;
	color: #e2e8f0;
}

[data-theme="dark"] .dropdown-item.active,
[data-theme="dark"] .dropdown-item:active {
	background-color: #1a2540;
	color: #60A5FA;
}

/* --- Modals --- */
[data-theme="dark"] .modal-content {
	background-color: #161b28;
	border: 1px solid #2a3348;
}

[data-theme="dark"] .modal-header {
	border-bottom-color: #1e2538;
}

[data-theme="dark"] .modal-footer {
	border-top-color: #1e2538;
}

/* --- Progress --- */
[data-theme="dark"] .progress {
	background-color: #1e2538;
}

[data-theme="dark"] .progress-bar {
	background-color: #60A5FA;
}

/* --- Awesomebar --- */
[data-theme="dark"] .awesomebar:focus-within {
	border-color: #60A5FA;
	box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.15);
}

/* --- Like button --- */
[data-theme="dark"] .like-active-item .like-action,
[data-theme="dark"] .liked-by .like-action {
	color: #60A5FA;
}

/* --- Timeline --- */
[data-theme="dark"] .timeline-dot {
	background-color: #60A5FA;
}

/* --- Onboarding --- */
[data-theme="dark"] .onboarding-steps .step-text a {
	color: #60A5FA !important;
}

[data-theme="dark"] .onboarding-steps .step.complete .step-icon {
	color: #4ade80;
}

[data-theme="dark"] .onboarding-steps .step.complete .step-icon svg {
	stroke: #4ade80;
}

/* --- Login Page --- */
[data-theme="dark"] .page-card .page-card-head {
	border-top: 3px solid #60A5FA;
}

[data-theme="dark"] .page-card-head h4 {
	color: #60A5FA;
}

[data-theme="dark"] .page-card .btn-primary {
	background-color: #2563EB !important;
	border-color: #2563EB !important;
}

[data-theme="dark"] .page-card .btn-primary:hover {
	background-color: #1d4ed8 !important;
	border-color: #1d4ed8 !important;
}

/* --- Frappe Card --- */
[data-theme="dark"] .frappe-card {
	background-color: #161b28;
	border: 1px solid #1e2538;
}

/* --- Comment box --- */
[data-theme="dark"] .comment-box .ql-editor {
	color: #e2e8f0;
}

/* --- Workspace shortcut count badges --- */
[data-theme="dark"] .shortcut-widget-box .indicator-pill,
[data-theme="dark"] .shortcut-widget-box .count {
	background-color: #2563EB;
	color: #fff;
}

/* --- General body/page background --- */
[data-theme="dark"] .layout-main {
	background-color: var(--bg-color, #111827);
}

/* --- Breadcrumb --- */
[data-theme="dark"] .breadcrumb-container a,
[data-theme="dark"] .breadcrumb a {
	color: #8b9ab4;
}

[data-theme="dark"] .breadcrumb-container a:hover,
[data-theme="dark"] .breadcrumb a:hover {
	color: #60A5FA;
}

/* --- Toolbar / page actions buttons text --- */
[data-theme="dark"] .page-actions .btn-default {
	color: #e2e8f0 !important;
}

/* --- Comment/activity/timeline text --- */
[data-theme="dark"] .timeline-item .timeline-content {
	color: #c0cede;
}

/* --- Notification dot stays red --- */
[data-theme="dark"] .notifications-indicator {
	background-color: #DC2626 !important;
}

/* --- Avatar keeps gradient --- */
[data-theme="dark"] header .navbar .avatar-frame,
[data-theme="dark"] header .navbar .avatar {
	background: linear-gradient(135deg, #2563EB, #60A5FA) !important;
}

[data-theme="dark"] header .navbar .avatar-frame .standard-image,
[data-theme="dark"] header .navbar .standard-image {
	background: linear-gradient(135deg, #2563EB, #60A5FA) !important;
}
