@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css');

/* Helpdesk incident status badges */
.incident-status-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 2px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.1px;
	border: 1px solid transparent;
}

.incident-status-badge--new {
	background: #e8f0ff;
	color: #1d4ed8;
	border-color: #bfdbfe;
}

.incident-status-badge--progress {
	background: #fff4db;
	color: #9a6700;
	border-color: #fde68a;
}

.incident-status-badge--resolved {
	background: #dcfce7;
	color: #166534;
	border-color: #86efac;
}

.incident-status-badge--closed {
	background: #f1f5f9;
	color: #334155;
	border-color: #cbd5e1;
}

[data-theme='dark'] .incident-status-badge--new {
	background: rgba(59, 130, 246, 0.2);
	color: #93c5fd;
	border-color: rgba(147, 197, 253, 0.35);
}

[data-theme='dark'] .incident-status-badge--progress {
	background: rgba(250, 204, 21, 0.2);
	color: #fde68a;
	border-color: rgba(253, 230, 138, 0.35);
}

[data-theme='dark'] .incident-status-badge--resolved {
	background: rgba(34, 197, 94, 0.2);
	color: #86efac;
	border-color: rgba(134, 239, 172, 0.35);
}

[data-theme='dark'] .incident-status-badge--closed {
	background: rgba(148, 163, 184, 0.2);
	color: #e2e8f0;
	border-color: rgba(203, 213, 225, 0.35);
}

/* Invoice payment status badges */
.invoice-status-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 3px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.1px;
	border: 1px solid transparent;
	white-space: nowrap;
	line-height: 1.3;
}

.invoice-status-badge--pending {
	background: #fff4e6;
	color: #c2410c;
	border-color: #fdba74;
}

.invoice-status-badge--paid {
	background: #dcfce7;
	color: #166534;
	border-color: #86efac;
}

.invoice-status-badge--received {
	background: #e0f2fe;
	color: #0369a1;
	border-color: #7dd3fc;
}

.invoice-status-badge--credited {
	background: #f3e8ff;
	color: #6b21a8;
	border-color: #d8b4fe;
}

.invoice-status-badge--other {
	background: #fee2e2;
	color: #b91c1c;
	border-color: #fca5a5;
}

.invoice-status-badge--empty {
	background: #f1f5f9;
	color: #64748b;
	border-color: #e2e8f0;
}

.invoice-status-badge--neutral {
	background: #f1f5f9;
	color: #64748b;
	border-color: #e2e8f0;
}

[data-theme='dark'] .invoice-status-badge--pending {
	background: rgba(251, 146, 60, 0.2);
	color: #fdba74;
	border-color: rgba(253, 186, 116, 0.35);
}

[data-theme='dark'] .invoice-status-badge--paid {
	background: rgba(34, 197, 94, 0.2);
	color: #86efac;
	border-color: rgba(134, 239, 172, 0.35);
}

[data-theme='dark'] .invoice-status-badge--received {
	background: rgba(56, 189, 248, 0.2);
	color: #7dd3fc;
	border-color: rgba(125, 211, 252, 0.35);
}

[data-theme='dark'] .invoice-status-badge--credited {
	background: rgba(168, 85, 247, 0.2);
	color: #d8b4fe;
	border-color: rgba(216, 180, 254, 0.35);
}

[data-theme='dark'] .invoice-status-badge--other {
	background: rgba(239, 68, 68, 0.2);
	color: #fca5a5;
	border-color: rgba(252, 165, 165, 0.35);
}

[data-theme='dark'] .invoice-status-badge--empty {
	background: rgba(148, 163, 184, 0.15);
	color: #94a3b8;
	border-color: rgba(203, 213, 225, 0.25);
}

[data-theme='dark'] .invoice-status-badge--neutral {
	background: rgba(148, 163, 184, 0.15);
	color: #94a3b8;
	border-color: rgba(203, 213, 225, 0.25);
}

:root {
	--sidebar-bg: var(--tenant-primary, #582156);
	--submenu-bg: var(--tenant-secondary, #71306f);
	--text-color: #333;
	--bg-color: #f4f6f9;
	--header-bg: #fff;
	--card-bg: #fff;
}

/* Prevent FOUC (Flash of Unstyled Content) - Better approach */
/* Hide content until tenant colors are applied */
body:not(.tenant-zoriva):not(.tenant-flex) {
	opacity: 0;
	transition: opacity 0.1s ease;
}

/* Show content once tenant class is applied */
body.tenant-zoriva,
body.tenant-flex {
	opacity: 1;
	transition: opacity 0.1s ease;
}

/* Keep vertical scrollbar space reserved to prevent header shift on initial load. */
html {
	scrollbar-gutter: stable;
}

[data-theme='dark'] {
	--sidebar-bg: var(--tenant-primary, #582156);
	--submenu-bg: var(--tenant-secondary, #71306f);
	--text-color: #eee;
	--bg-color: #121212;
	--header-bg: #1e1e1e;
	--card-bg: #2a2a2a;
}

body {
	margin: 0;
	font-family: 'Roboto', sans-serif;
	background-color: var(--bg-color);
	color: var(--text-color);
	overflow: hidden;
}

/* App-wide tenant-themed scrollbars */
html,
body,
.sidebar,
.main-content,
.modal-dialog-scrollable .modal-body,
.modal-body,
.table-responsive,
.dataTables_wrapper .dataTables_scrollBody,
.csf-panel-body,
.notification-panel {
	scrollbar-width: thin;
	scrollbar-color: var(--tenant-secondary, #71306f) transparent;
}

html::-webkit-scrollbar,
body::-webkit-scrollbar,
.sidebar::-webkit-scrollbar,
.main-content::-webkit-scrollbar,
.modal-dialog-scrollable .modal-body::-webkit-scrollbar,
.modal-body::-webkit-scrollbar,
.table-responsive::-webkit-scrollbar,
.dataTables_wrapper .dataTables_scrollBody::-webkit-scrollbar,
.csf-panel-body::-webkit-scrollbar,
.notification-panel::-webkit-scrollbar {
	width: 4px;
	height: 4px;
}

html::-webkit-scrollbar-track,
body::-webkit-scrollbar-track,
.sidebar::-webkit-scrollbar-track,
.main-content::-webkit-scrollbar-track,
.modal-dialog-scrollable .modal-body::-webkit-scrollbar-track,
.modal-body::-webkit-scrollbar-track,
.table-responsive::-webkit-scrollbar-track,
.dataTables_wrapper .dataTables_scrollBody::-webkit-scrollbar-track,
.csf-panel-body::-webkit-scrollbar-track,
.notification-panel::-webkit-scrollbar-track {
	background: transparent;
}

.sidebar::-webkit-scrollbar-track {
	margin: 10px 0;
}

html::-webkit-scrollbar-thumb,
body::-webkit-scrollbar-thumb,
.sidebar::-webkit-scrollbar-thumb,
.main-content::-webkit-scrollbar-thumb,
.modal-dialog-scrollable .modal-body::-webkit-scrollbar-thumb,
.modal-body::-webkit-scrollbar-thumb,
.table-responsive::-webkit-scrollbar-thumb,
.dataTables_wrapper .dataTables_scrollBody::-webkit-scrollbar-thumb,
.csf-panel-body::-webkit-scrollbar-thumb,
.notification-panel::-webkit-scrollbar-thumb {
	background: var(--tenant-secondary, #71306f);
	border-radius: 999px;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

html::-webkit-scrollbar-thumb:hover,
body::-webkit-scrollbar-thumb:hover,
.sidebar::-webkit-scrollbar-thumb:hover,
.main-content::-webkit-scrollbar-thumb:hover,
.modal-dialog-scrollable .modal-body::-webkit-scrollbar-thumb:hover,
.modal-body::-webkit-scrollbar-thumb:hover,
.table-responsive::-webkit-scrollbar-thumb:hover,
.dataTables_wrapper .dataTables_scrollBody::-webkit-scrollbar-thumb:hover,
.csf-panel-body::-webkit-scrollbar-thumb:hover,
.notification-panel::-webkit-scrollbar-thumb:hover {
	background: color-mix(in srgb, var(--tenant-secondary, #71306f) 72%, #ffffff);
}

.main-container {
	display: flex;
	height: 100vh;
	flex-direction: column;
}

.sidebar,
.main-content {
	transition: all 0.3s ease;
}

.sidebar {
	width: 250px;
	background-color: var(--sidebar-bg);
	color: white;
	position: fixed;
	height: 100vh;
	top: 0;
	left: 0;
	padding-top: 60px;
	box-sizing: border-box;
	box-shadow: 2px 0px 8px rgba(0, 0, 0, 0.1);
	display: flex;
	flex-direction: column;
	z-index: 100;
	transition: width 0.3s ease;
	overflow-x: hidden;
	overflow-y: auto;
}

/* Keep menu rows from collapsing in shorter viewports */
.sidebar > * {
	flex-shrink: 0;
}

.sidebar-collapsed .sidebar {
	width: 70px;
}

.sidebar-collapsed .sidebar .menu-text {
	display: none;
}

.menu-item {
	padding: 15px;
	display: flex;
	align-items: center;
	cursor: pointer;
	transition: background-color 0.3s ease;
	min-height: 48px;
	line-height: 1.2;
	flex-shrink: 0;
}

.menu-item:hover {
	background-color: var(--submenu-bg);
}

.menu-item .material-icons,
.menu-item .menu-icon-fa {
	margin-right: 10px;
	font-size: 24px;
	line-height: 1;
	vertical-align: middle;
}

.menu-item .menu-icon-fa {
	width: 24px;
	text-align: center;
}

.submenu {
	display: none;
	flex-direction: column;
	background-color: var(--tenant-submenu, #662764);
	/* padding-left: 15px; */
	overflow: visible;
	max-height: none;
	opacity: 1;
	padding-top: 0;
	padding-bottom: 0;
	flex-shrink: 0;
}

.submenu.open {
	display: block;
	overflow: visible;
}

.submenu .menu-item {
	padding-left: 50px;
	min-height: 46px;
}

.menu-divider {
	height: 1px;
	background-color: rgba(255, 255, 255, 0.2);
	margin: 10px 15px;
}

.header {
	width: 100%;
	background-color: var(--header-bg);
	padding: 6px 20px;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 101;
}

.hamburger-btn {
	display: block;
	cursor: pointer;
	font-size: 30px;
	color: var(--tenant-primary, #582156);
	z-index: 102;
}

.header-right {
	display: flex;
	align-items: center;
	gap: 15px;
	margin-right: 20px;
}

.logo-title {
	font-family: 'Calibri Light', 'Segoe UI', 'Roboto', sans-serif;
	font-weight: 300;
	font-size: 22px;
	line-height: 1;
	letter-spacing: 0.5px;
	margin: 0;
	padding: 0;
	color: var(--tenant-primary, #582156);
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 220px;
}

.unread-container {
	position: relative;
	margin-right: 15px;
	cursor: pointer;
}

.unread-containerold::after {
	content: 'Berichten openen';
	position: absolute;
	top: 120%;
	left: 50%;
	transform: translateX(-50%);
	background: #333;
	color: #fff;
	font-size: 12px;
	padding: 6px 10px;
	border-radius: 4px;
	white-space: nowrap;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.2s ease;
	z-index: 999;
}

.unread-container:hover::after {
	opacity: 1;
}

.unread-message {
	font-size: 30px;
	color: #f44336;
}

/* Notification count on bell only — not global .badge (breaks Bootstrap badges in tables, etc.) */
.unread-container .badge {
	position: absolute;
	top: -5px;
	right: -5px;
	background: var(--tenant-primary, #582156);
	color: white;
	font-size: 12px;
	border-radius: 50%;
	padding: 2px 6px;
	animation: pulse 1.5s infinite;
}

.notification-item .notif-count {
	background-color: var(--tenant-primary, #582156) !important;
}

@keyframes pulse {
	0% {
		transform: scale(1);
	}

	50% {
		transform: scale(1.2);
	}

	100% {
		transform: scale(1);
	}
}

.user-img {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	object-fit: cover;
}

.account-btn {
	display: flex;
	align-items: center;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 250px;
	cursor: pointer;
}

.account-btn span {
	margin-left: 10px;
	min-width: 125px;
}

.login-as-btn {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	background-color: var(--tenant-primary, #582156);
	color: white;
	border-radius: 6px;
	cursor: pointer;
	transition: background-color 0.2s ease;
	font-size: 14px;
	font-weight: 500;
}

.login-as-btn:hover {
	background-color: var(--tenant-secondary, #71306f);
}

.login-as-btn .material-icons {
	font-size: 18px;
}

.login-as-text {
	font-size: 14px;
}

.main-content {
	flex-grow: 1;
	padding: 80px 60px 40px 310px !important; /* Top Right Bottom Left */
	background-color: var(--card-bg);
	box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.1);
	border-radius: 10px;
	transition: all 0.3s ease;
	/* Avoid temporary viewport scrollbar flicker during page fade/translate animations. */
	contain: paint;
	overflow-x: hidden;
	overflow-y: auto;
}

/* When sidebar is collapsed */
.sidebar-collapsed .main-content {
	padding-left: 110px !important;
}

.account-dropdown {
	position: fixed;
	right: 20px;
	top: 60px;
	background-color: var(--header-bg);
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
	border-radius: 5px;
	width: 180px;
	z-index: 105;
	display: none;
}

.account-dropdown .menu-item {
	padding: 10px;
	cursor: pointer;
	transition: background-color 0.3s ease;
	display: flex;
	align-items: center;
}

.account-dropdown .material-icons {
	margin-right: 10px;
}

.account-dropdown .menu-text {
	display: inline;
}

.account-dropdown .menu-item:hover {
	background-color: #f0f0f0;
}

[data-theme='dark'] .account-dropdown .menu-item:hover {
	color: black;
}

[data-theme='dark'] .account-dropdown .menu-item:hover .material-icons {
	color: black;
}

.notification-panel {
	position: absolute;
	right: 100px;
	top: 60px;
	width: 240px;
	background: var(--header-bg);
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
	border-radius: 5px;
	display: none;
	flex-direction: column;
	z-index: 106;
	font-size: 14px;
	padding: 8px 0;
}

.panel-title {
	font-weight: bold;
	padding: 10px 15px;
	border-bottom: 1px solid #eee;
}

.notification-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding: 10px 15px;
	cursor: pointer;
	transition: background 0.2s;
}

.notification-item .red-icon {
	color: #f44336;
	font-size: 20px;
	margin-right: 5px;
}

.notification-item .notif-label {
	flex: 1;
}

.notification-item .notif-count {
	background-color: #f44336;
	color: white;
	font-size: 12px;
	padding: 2px 6px;
	border-radius: 12px;
	min-width: 20px;
	text-align: center;
}

.notification-item:hover {
	background-color: #f6f6f6;
}

[data-theme='dark'] .notification-item:hover {
	background-color: #444;
}

.logo-title {
	font-family: 'Orbitron', sans-serif;
	font-weight: 700;
	letter-spacing: 1px;
	font-size: 26px;
	color: #582156;
}

.header {
	padding: 6px 20px; /* even smaller */
	height: 60px; /* optionally force a fixed height */
}

.logo-title {
	font-size: 20px;
	line-height: 1;
	padding: 0;
	margin: 0;
}

.notification-item .notif-count {
	background-color: #582156;
	color: white;
	font-size: 12px;
	padding: 2px 6px;
	border-radius: 12px;
	min-width: 20px;
	text-align: center;
}

[data-theme='dark'] table.dataTable {
	background-color: #121212;
	color: #eee;
	border-collapse: collapse;
}

[data-theme='dark'] table.dataTable thead {
	background-color: #292929;
	color: #fff;
	border-bottom: 2px solid #444;
}

[data-theme='dark'] table.dataTable tbody tr:nth-child(odd) {
	background-color: #2f2f2f; /* Much lighter gray */
}

[data-theme='dark'] table.dataTable tbody tr:nth-child(even) {
	background-color: #181818; /* Much darker */
}

[data-theme='dark'] table.dataTable tbody tr:hover {
	background-color: #3c3c3c;
}

[data-theme='dark'] table.dataTable td,
[data-theme='dark'] table.dataTable th {
	border: 1px solid #333;
	padding: 8px 10px;
}

[data-theme='dark'] .dataTables_wrapper select {
	background-color: #1e1e1e;
	color: #eee;
	border: 1px solid #444;
}

[data-theme='dark'] .dataTables_wrapper .dataTables_length,
[data-theme='dark'] .dataTables_wrapper .dataTables_filter,
[data-theme='dark'] .dataTables_wrapper .dataTables_info,
[data-theme='dark'] .dataTables_wrapper .dataTables_paginate {
	color: #ccc;
}

[data-theme='dark'] .dataTables_wrapper .dataTables_paginate .paginate_button {
	color: #ccc !important;
	background-color: #1e1e1e !important;
	border: 1px solid #444 !important;
}

[data-theme='dark'] .dataTables_wrapper .dataTables_paginate .paginate_button.current {
	background-color: var(--tenant-primary, #582156) !important;
	color: #fff !important;
}

.loading-container {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	margin-top: 0;
	padding: 12px 0;
	font-size: 18px;
}

.loading-icon {
	color: var(--tenant-primary, #582156);
	font-size: 32px;
	animation: spin 1s linear infinite;
}

.loading-text {
	color: var(--text-color);
}

/* Spinner animation */
@keyframes spin {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(360deg);
	}
}

.dashboard-title {
	color: var(--tenant-primary, #582156);
	margin-bottom: 10px;
}

.contracts-search-filter-banner {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-wrap: nowrap;
	gap: 0.75rem;
	padding: 0.625rem 1rem !important;
	margin: 0 0 0.75rem;
	min-height: 2.5rem;
	border-radius: 10px;
	border: 1px solid color-mix(in srgb, #f59e0b 42%, #fde68a);
	border-left: 3px solid #f59e0b;
	background: linear-gradient(
		135deg,
		color-mix(in srgb, #fef3c7 88%, #fff) 0%,
		color-mix(in srgb, #fffbeb 92%, #fff) 100%
	);
	box-shadow: 0 2px 8px rgba(245, 158, 11, 0.12);
	box-sizing: border-box;
}

/* Match table horizontal inset; equal vertical padding (no pt-4/pb-0 on markup). */
.tab-pane > .contracts-search-filter-banner {
	margin: 1rem 1rem 0.5rem;
	padding: 0.625rem 1rem !important;
}

.settings-content-shell > .contracts-search-filter-banner {
	margin: 0 0 0.75rem;
	padding: 0.625rem 1rem !important;
}

.contracts-search-filter-banner__text {
	margin: 0;
	padding: 0;
	flex: 1 1 auto;
	min-width: 0;
	font-size: 0.9rem;
	line-height: 1.5;
	color: #713f12;
}

.contracts-search-filter-banner .btn {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	line-height: 1.25;
	white-space: nowrap;
}

[data-theme='dark'] .contracts-search-filter-banner {
	border-color: rgba(251, 191, 36, 0.32);
	border-left-color: #fbbf24;
	background: linear-gradient(
		135deg,
		rgba(251, 191, 36, 0.18) 0%,
		rgba(245, 158, 11, 0.1) 100%
	);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.22);
}

[data-theme='dark'] .contracts-search-filter-banner__text {
	color: #fde68a;
}

/* Admin table note icon (GetNote / SetNote) */
.admin-note-col,
table.dataTable thead th.admin-note-col,
table.dataTable tbody td.admin-note-col {
	padding-left: 0.35rem !important;
	padding-right: 0.35rem !important;
	min-width: 3rem;
	width: 3rem;
	max-width: 3.5rem;
	text-align: center !important;
	vertical-align: middle !important;
}

table.dataTable thead th.admin-note-col {
	white-space: nowrap;
	font-size: 0.85rem;
}

.admin-note-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: transparent;
	padding: 0;
	margin: 0;
	color: var(--tenant-primary, #582156);
	cursor: pointer;
	line-height: 1;
	vertical-align: middle;
}

.admin-note-btn:hover,
.admin-note-btn:focus {
	color: var(--tenant-gradient-end, #8e3a78);
}

.admin-note-btn .material-icons {
	font-size: 22px;
}

.admin-note-btn--empty {
	color: #9ca3af !important;
	opacity: 0.9;
}

.admin-note-btn--empty:hover,
.admin-note-btn--empty:focus {
	color: #6b7280 !important;
}

[data-theme='dark'] .admin-note-btn--empty {
	color: rgba(255, 255, 255, 0.42) !important;
}

[data-theme='dark'] .admin-note-btn--empty:hover,
[data-theme='dark'] .admin-note-btn--empty:focus {
	color: rgba(255, 255, 255, 0.62) !important;
}

[data-theme='dark'] .admin-note-btn {
	color: var(--tenant-gradient-end, #b57da9);
}

[data-theme='dark'] .admin-note-btn:hover,
[data-theme='dark'] .admin-note-btn:focus {
	color: #e9c4e0;
}

#adminNoteModal .modal-body textarea {
	min-height: 10rem;
	resize: vertical;
}

*,
::after,
::before {
	box-sizing: border-box;
}
.dashboard-title {
	color: var(--tenant-primary, #582156);
	margin-bottom: 10px;
	font-size: 24px !important;
	font-weight: bold !important;
}
[data-theme='dark'] .dashboard-title {
	color: #fff;
	margin-bottom: 10px;
	font-size: 24px !important;
	font-weight: bold !important;
}

.btn-primary {
	--bs-btn-color: #fff;
	--bs-btn-bg: var(--tenant-primary, #582156);
	--bs-btn-border-color: var(--tenant-primary, #582156);
	--bs-btn-hover-color: #fff;
	--bs-btn-hover-bg: var(--tenant-hover, #441b43);
	--bs-btn-hover-border-color: var(--tenant-hover, #441b43);
	--bs-btn-focus-shadow-rgb: 88, 33, 86;
	--bs-btn-active-color: #fff;
	--bs-btn-active-bg: var(--tenant-primary, #582156);
	--bs-btn-active-border-color: var(--tenant-primary, #582156);
	--bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
	--bs-btn-disabled-color: #fff;
	--bs-btn-disabled-bg: var(--tenant-primary, #582156);
	--bs-btn-disabled-border-color: var(--tenant-primary, #582156);
}

/* Outline buttons — tenant primary (Bootstrap default is blue) */
.btn-outline-primary {
	--bs-btn-color: var(--tenant-primary, #582156);
	--bs-btn-border-color: var(--tenant-primary, #582156);
	--bs-btn-hover-color: #fff;
	--bs-btn-hover-bg: var(--tenant-primary, #582156);
	--bs-btn-hover-border-color: var(--tenant-primary, #582156);
	--bs-btn-active-color: #fff;
	--bs-btn-active-bg: var(--tenant-hover, #441b43);
	--bs-btn-active-border-color: var(--tenant-hover, #441b43);
	--bs-btn-disabled-color: var(--tenant-primary, #582156);
	--bs-btn-disabled-border-color: var(--tenant-primary, #582156);
	--bs-btn-focus-shadow-rgb: 88, 33, 86;
}

[data-theme='dark'] .btn-outline-primary {
	--bs-btn-color: rgba(255, 255, 255, 0.92);
	--bs-btn-border-color: color-mix(in srgb, var(--tenant-primary, #582156) 50%, rgba(255, 255, 255, 0.35));
	--bs-btn-hover-color: #fff;
	--bs-btn-hover-bg: var(--tenant-primary, #582156);
	--bs-btn-hover-border-color: var(--tenant-primary, #582156);
	--bs-btn-active-color: #fff;
	--bs-btn-active-bg: var(--tenant-hover, #441b43);
	--bs-btn-active-border-color: var(--tenant-hover, #441b43);
}

.btn-outline-secondary {
	--bs-btn-color: var(--text-color, #495057);
	--bs-btn-border-color: color-mix(in srgb, var(--tenant-primary, #582156) 22%, rgba(0, 0, 0, 0.18));
	--bs-btn-hover-color: var(--tenant-primary, #582156);
	--bs-btn-hover-bg: color-mix(in srgb, var(--tenant-primary, #582156) 10%, transparent);
	--bs-btn-hover-border-color: var(--tenant-primary, #582156);
	--bs-btn-active-color: #fff;
	--bs-btn-active-bg: var(--tenant-primary, #582156);
	--bs-btn-active-border-color: var(--tenant-primary, #582156);
	--bs-btn-focus-shadow-rgb: 88, 33, 86;
}

[data-theme='dark'] .btn-outline-secondary {
	--bs-btn-color: rgba(255, 255, 255, 0.88);
	--bs-btn-border-color: rgba(255, 255, 255, 0.28);
	--bs-btn-hover-color: #fff;
	--bs-btn-hover-bg: rgba(255, 255, 255, 0.1);
	--bs-btn-hover-border-color: rgba(255, 255, 255, 0.4);
	--bs-btn-active-color: #fff;
	--bs-btn-active-bg: var(--tenant-primary, #582156);
	--bs-btn-active-border-color: var(--tenant-primary, #582156);
}

[data-theme='dark'] input,
[data-theme='dark'] select,
[data-theme='dark'] textarea {
	background-color: #2a2a2a !important;
	color: #fff !important;
}

/* Native select dropdown options in dark mode (dropdown list background) */
[data-theme='dark'] select option {
	background-color: #2a2a2a !important;
	color: #fff !important;
}
a {
	color: var(--tenant-primary, #582156) !important;
}

/* Anchor buttons: do not let global link color override Bootstrap btn states */
a.btn {
	color: var(--bs-btn-color) !important;
}

a.btn:hover,
a.btn:focus {
	color: var(--bs-btn-hover-color, var(--bs-btn-color)) !important;
}

a.btn:active,
a.btn.active,
a.btn.show,
a.btn:first-child:active:not(.btn-check),
:not(.btn-check) + a.btn:active {
	color: var(--bs-btn-active-color, var(--bs-btn-hover-color, var(--bs-btn-color))) !important;
}

.menu-item.active {
	background-color: var(--submenu-bg);
}
[data-theme='dark'] div:where(.swal2-container) div:where(.swal2-popup) {
	background-color: #2b2a2a;
	color: #fff;
}

#subscriptionMessage .subscription-message-intro {
	display: block;
	margin-top: 0.65rem;
	font-size: 0.95rem;
	font-weight: 400;
	line-height: 1.5;
}

#subscriptionMessage .subscription-message-note {
	display: block;
	margin-top: 0.65rem;
	padding: 0.45rem 0.65rem;
	font-size: 0.875rem;
	font-weight: 600;
	line-height: 1.4;
	color: #ffeb3b;
	background: rgba(0, 0, 0, 0.25);
	border-left: 3px solid #ffc107;
	border-radius: 0 6px 6px 0;
}

.subscription-card.pending-activation #subscriptionMessage .subscription-message-note {
	color: rgba(255, 255, 255, 0.92);
	font-weight: 500;
	background: rgba(255, 255, 255, 0.12);
	border-left-color: rgba(255, 255, 255, 0.55);
}

.subscription-card.expiring-soon #subscriptionMessage .subscription-message-note {
	color: #fff;
	background: rgba(0, 0, 0, 0.4);
	border-left-color: #fff;
}

button.swal2-confirm {
	background-color: var(--tenant-primary, #582156) !important;
}
button.swal2-cancel {
	background-color: #504e50 !important;
}

[data-theme='dark'] .form-control::placeholder {
	color: #fff;
}

.dataTable td,
.dataTable th {
	white-space: normal !important; /* Allow text wrapping */
	word-wrap: break-word; /* Ensure long words break */
	overflow: hidden; /* Prevent text from overflowing */
}
div:where(.swal2-icon).swal2-warning {
	border-color: var(--tenant-primary, #582156) !important;
	color: var(--tenant-primary, #582156) !important;
}

/* Info (and related) icons — match tenant primary instead of default blue */
div:where(.swal2-icon).swal2-info {
	border-color: var(--tenant-primary, #582156) !important;
	color: var(--tenant-primary, #582156) !important;
}

div:where(.swal2-icon).swal2-question {
	border-color: var(--tenant-primary, #582156) !important;
	color: var(--tenant-primary, #582156) !important;
}

.loader {
	display: none;
	width: 1rem;
	height: 1rem;
	border: 2px solid white;
	border-top: 2px solid transparent;
	border-radius: 50%;
	animation: spin 0.8s linear infinite;
}

@keyframes spin {
	from {
		transform: rotate(0deg);
	}

	to {
		transform: rotate(360deg);
	}
}
.bg-main {
	background-color: var(--tenant-accent, #3c1b3f);
}
.bg-main-white {
	background-color: #fff !important;
}
[data-theme='dark'] .bg-main-white {
	background-color: #1e1e1e !important;
}
[data-theme='dark'] .form-control,
[data-theme='dark'] .form-select {
	border-color: #fff !important;
}
[data-theme='dark'] #nav-tab .nav-link {
	color: #fff !important;
}
[data-theme='dark'] #notification-panel a {
	text-decoration: none;
	color: #fff !important;
}
#notification-panel a {
	text-decoration: none;
}
.authLogo {
	padding: 40px 0;
	width: 250px !important;
}
table thead th {
	background: var(--tenant-primary, #582156);
	color: #fff;
	border-color: var(--tenant-primary, #582156) !important;
}
.dataTables_filter {
	margin-bottom: 10px;
}

.modal-header {
	background: var(--tenant-primary, #582156);
	color: #fff;
}

/* Global modal layering fix:
   .main-content uses paint containment for page transitions, which can trap modal stacking.
   Disable containment/scroll clipping while any Bootstrap modal is open. */
body.modal-open .main-content {
	contain: none;
	overflow: visible;
}

.modal-backdrop {
	z-index: 1090 !important;
}

.modal {
	z-index: 1100 !important;
}

/* Restore Bootstrap fade/slide when tenant-theme colour transitions are active. */
.modal.fade {
	transition: opacity 0.15s linear !important;
}

.modal.fade .modal-dialog {
	transition: transform 0.3s ease-out !important;
}

.modal-backdrop.fade {
	transition: opacity 0.15s linear !important;
}

.offcanvas {
	transition: transform 0.3s ease-in-out !important;
}

.offcanvas-backdrop.fade {
	transition: opacity 0.15s linear !important;
}

[data-theme='dark'] .modal-body {
	background: #2a2a2a;
	color: #fff;
}
[data-theme='dark'] .modal-header {
	border: none !important;
	border-top-left-radius: none !important;
	border-top-right-radius: none !important;
}

[data-theme='dark'] .ui-datepicker {
	background: #2c2c2c;
	color: #fff;
	border: 1px solid #555;
}

[data-theme='dark'] .ui-datepicker-header {
	background: #3a3a3a;
	border-bottom: 1px solid #555;
}

[data-theme='dark'] .ui-datepicker-title {
	color: #fff;
}

[data-theme='dark'] .ui-datepicker-calendar td a {
	color: #000 !important;
}

[data-theme='dark'] .ui-state-hover,
[data-theme='dark'] .ui-widget-content .ui-state-hover,
[data-theme='dark'] .ui-widget-header .ui-state-hover {
	background: #555;
	border: 1px solid #666;
	color: #fff;
}

[data-theme='dark'] .ui-state-active,
[data-theme='dark'] .ui-widget-content .ui-state-active {
	background: #666;
	color: #fff;
}
.ui-state-highlight,
.ui-widget-content .ui-state-highlight,
.ui-widget-header .ui-state-highlight {
	border: 1px solid var(--tenant-primary, #582156) !important;
	background: #a8a8a8 !important;
	color: #fff !important;
}
.ui-state-active,
.ui-widget-content .ui-state-active,
.ui-widget-header .ui-state-active,
a.ui-button:active,
.ui-button:active,
.ui-button.ui-state-active:hover {
	border: 1px solid var(--tenant-primary, #582156) !important;
	background: var(--tenant-primary, #582156) !important;
	font-weight: normal;
	color: #ffffff !important;
}
.sidebar-collapsed .submenu .menu-item {
	padding-left: 22px;
}

/* Dark mode adjustments for Select2 */
[data-theme='dark'] .select2-container--bootstrap4 .select2-selection {
	background-color: #333 !important; /* Dark background */
	border-color: #444 !important; /* Dark border */
	color: #fff !important; /* White text */
}

[data-theme='dark'] .select2-container--bootstrap4 .select2-selection__rendered {
	color: #fff !important; /* Ensure the selected text is white */
}

[data-theme='dark'] .select2-container--bootstrap4 .select2-dropdown {
	background-color: #333 !important; /* Dark dropdown background */
	border-color: #444 !important; /* Dark border for the dropdown */
	color: #fff !important; /* White text */
}

[data-theme='dark'] .select2-container--bootstrap4 .select2-results__option {
	background-color: #333 !important; /* Dark option background */
	color: #fff !important; /* White text for options */
}

[data-theme='dark'] .select2-container--bootstrap4 .select2-results__option--highlighted {
	background-color: #444 !important; /* Darker highlighted option */
}
[data-theme='dark'] .select2-container--bootstrap4 .select2-selection--single .select2-selection__arrow b {
	border-color: #fff transparent transparent transparent !important;
}

/* Hover effect (when the user hovers over an option) */
.select2-container--bootstrap4 .select2-results__option:hover {
	background-color: var(--tenant-primary, #582156) !important; /* Light gray background on hover */
	color: #fff !important; /* Dark text on hover */
}
.select2-container--bootstrap4 .select2-results__option--highlighted,
.select2-container--bootstrap4 .select2-results__option--highlighted.select2-results__option[aria-selected='true'] {
	color: #fff;
	background-color: var(--tenant-primary, #582156) !important;
}
.loading-image {
	width: 100px;
}

[data-theme='dark'] .customCheckbox .form-group label:before,
[data-theme='dark'] tbody td .customCheckbox .form-group label:before {
	content: '';
	background-color: transparent;
	border: 2px solid #fff;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05), inset 0px -15px 10px -12px rgba(0, 0, 0, 0.05);
	padding: 10px;
	display: inline-block;
	position: relative;
	vertical-align: middle;
	cursor: pointer;
	margin-right: 5px;
}

[data-theme='dark'] .customCheckbox .form-group input:checked + label:after,
[data-theme='dark'] tbody td .customCheckbox .form-group input:checked + label:after {
	content: '';
	display: block;
	position: absolute;
	top: 5px;
	left: 10px;
	width: 6px;
	height: 14px;
	border: solid #fff;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

.view-more {
	color: #fff !important;
	display: inline-block;
}
[data-theme='dark'] .view-more {
	color: #fff !important;
	display: inline-block;
	margin: 15px 5px;
}
.formCheck {
	display: block;
	margin-bottom: 0;
	margin-left: 5px !important;
}

.formCheck input {
	padding: 0;
	height: initial;
	width: initial;
	margin-bottom: 0;
	display: none;
	cursor: pointer;
}

.formCheck label {
	position: relative;
	cursor: pointer;
}

.formCheck label:before {
	content: '';
	background-color: transparent;
	border: 2px solid var(--tenant-primary, #582156);
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05), inset 0px -15px 10px -12px rgba(0, 0, 0, 0.05);
	padding: 10px;
	display: inline-block;
	position: relative;
	vertical-align: middle;
	cursor: pointer;
	margin-right: 5px;
}
[data-theme='dark'] .formCheck label:before {
	content: '';
	background-color: transparent;
	border: 2px solid #fff;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05), inset 0px -15px 10px -12px rgba(0, 0, 0, 0.05);
	padding: 10px;
	display: inline-block;
	position: relative;
	vertical-align: middle;
	cursor: pointer;
	margin-right: 5px;
}

.formCheck input:checked + label:after {
	content: '';
	display: block;
	position: absolute;
	top: 5px;
	left: 10px;
	width: 6px;
	height: 14px;
	border: solid var(--tenant-primary, #582156);
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}
[data-theme='dark'] .formCheck input:checked + label:after {
	content: '';
	display: block;
	position: absolute;
	top: 5px;
	left: 10px;
	width: 6px;
	height: 14px;
	border: solid #fff;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}
[data-theme='dark'] form a {
	color: #fff !important;
}

[data-theme='dark'] table.dataTable.dtr-inline.collapsed > tbody > tr > td.dtr-control:before,
table.dataTable.dtr-inline.collapsed > tbody > tr > th.dtr-control:before {
	color: #fff !important;
}

table .material-icons {
	cursor: pointer;
}

table .material-icons:hover {
	color: var(--tenant-accent, #3c1b3f) !important;
}

.logo-img {
	width: 180px !important;
	object-fit: contain;
}

:root {
	--tenant-logo: url('../img/logo.png');
	--tenant-logo-white: url('../img/logo-white.png');
}

[data-theme='dark'] {
	--tenant-logo: var(--tenant-logo-white);
}

.logo-img {
	height: 30px !important;
	width: 180px !important;
}
[data-theme='dark'] a {
	color: #fff !important;
}

[data-theme='dark'] #nav-tab .nav-link.active {
	color: #000 !important;
}
[data-theme='dark'] .hamburger-btn {
	color: #ffffff;
}

div:where(.swal2-icon).swal2-success .swal2-success-ring {
	border: 0.25em solid var(--tenant-primary, #582156) !important;
}
div:where(.swal2-icon).swal2-success [class^='swal2-success-line'] {
	background-color: var(--tenant-primary, #582156) !important;
}
.dashboard-table li a {
	color: #fff !important;
	text-decoration: none;
	display: inline-block;
	padding: 3px 0;
}

[data-theme='dark'] div.dtr-modal div.dtr-modal-display {
	background-color: #2a2a2a;
	border: 1px solid #2a2a2a;
}
.hide {
	display: none !important;
}
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter {
	margin-right: 5px;
}

#adminBackBtn {
	font-weight: bold;
	border-bottom: 1px solid var(--tenant-primary, #582156);
	cursor: pointer;
	margin-right: 15px;
	color: var(--tenant-accent, #3c1b3f);
}
[data-theme='dark'] #adminBackBtn {
	border-bottom: 1px solid #fff;
	color: #fff;
}

.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
	background-color: var(--tenant-accent, #3c1b3f) !important;
	color: white;
}
[data-theme='dark'] .select2-dropdown {
	background-color: #2a2a2a !important;
	border: 1px solid #aaa;
}

[data-theme='dark'] .select2-container--default .select2-selection--multiple {
	background-color: #2a2a2a !important;
	border: 1px solid #aaa;
}

[data-theme='dark'] .select2-container--default .select2-selection--multiple .select2-selection__choice {
	background-color: #2a2a2a !important;
	border: 1px solid #aaa;
}

[data-theme='dark'] .select2-container--default .select2-results__option--selected {
	background-color: #464545;
}

.form-control:focus {
	background-color: transparent !important;
	border-color: #79118340;
	outline: 0;
	box-shadow: none;
}

/* Checkbox switch */
.switch input {
	display: none;
}

.switch {
	display: inline-block;
	width: 55px;
	height: 25px;
	margin: 4px;
	transform: translateY(50%);
	position: relative;
}

.slider {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	border-radius: 30px;
	box-shadow: 0 0 0 2px #777, 0 0 4px #777;
	cursor: pointer;
	border: 4px solid transparent;
	overflow: hidden;
	transition: 0.2s;
}

.slider:before {
	position: absolute;
	content: '';
	width: 100%;
	height: 100%;
	background-color: #777;
	border-radius: 30px;
	transform: translateX(-30px);
	transition: 0.2s;
}

input:checked + .slider:before {
	transform: translateX(30px);
	background-color: var(--tenant-dark-hover, #6a2768);
}

input:checked + .slider {
	box-shadow: 0 0 0 2px var(--tenant-dark-hover, #6a2768), 0 0 8px var(--tenant-dark-hover, #6a2768);
}

.matchSwitch {
	margin-top: -18px;
}

/* Bootstrap form-switch: tenant primary instead of default blue */
.form-switch .form-check-input {
	accent-color: var(--tenant-primary, #582156);
}

.form-switch .form-check-input:focus {
	border-color: color-mix(in srgb, var(--tenant-primary, #582156) 45%, #adb5bd);
	box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--tenant-primary, #582156) 22%, transparent);
}

.form-switch .form-check-input:checked {
	background-color: var(--tenant-primary, #582156);
	border-color: var(--tenant-primary, #582156);
}

.form-switch .form-check-input:checked:focus {
	background-color: var(--tenant-hover, #441b43);
	border-color: var(--tenant-hover, #441b43);
	box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--tenant-primary, #582156) 28%, transparent);
}

[data-theme='dark'] .form-switch .form-check-input:focus {
	border-color: color-mix(in srgb, var(--tenant-gradient-end, #8e3a78) 55%, #6c757d);
	box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--tenant-gradient-end, #8e3a78) 30%, transparent);
}

[data-theme='dark'] .form-switch .form-check-input:checked {
	background-color: var(--tenant-gradient-end, #8e3a78);
	border-color: var(--tenant-gradient-end, #8e3a78);
}

[data-theme='dark'] .form-switch .form-check-input:checked:focus {
	background-color: var(--tenant-primary, #582156);
	border-color: var(--tenant-primary, #582156);
}

/* App toasts (Toastify): centered below fixed header — see applyAppToastPosition in utility.js */
.toastify.toastify-app {
    max-width: min(520px, calc(100vw - 24px));
    border-radius: 8px;
    font-size: 0.95rem;
    line-height: 1.35;
    text-align: center;
}

.toastify.toastify-app.toastify-center {
    left: 50% !important;
    right: auto !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.menu-item.hidemenu {
    display: none;
}

.menu-item.menu-item-disabled,
.submenu .menu-item.menu-item-disabled {
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: auto;
}

.menu-item.menu-item-disabled:hover,
.submenu .menu-item.menu-item-disabled:hover {
    background-color: transparent;
}

.menu-item.menu-item-disabled .material-icons,
.menu-item.menu-item-disabled .menu-icon-fa,
.menu-item.menu-item-disabled .menu-text {
    color: inherit;
}

.menu-disabled-tooltip {
    position: fixed;
    z-index: 1100;
    max-width: min(300px, calc(100vw - 24px));
    padding: 10px 12px;
    font-size: 12px;
    font-weight: 500;
    line-height: 1.5;
    color: #f8fafc;
    background: #334155;
    border-radius: 10px;
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.28);
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.15s ease, visibility 0.15s ease;
}

.menu-disabled-tooltip.is-visible {
    opacity: 1;
    visibility: visible;
}

.menu-disabled-tooltip::before {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    border: 7px solid transparent;
}

.menu-disabled-tooltip.is-right::before {
    left: -13px;
    border-right-color: #334155;
}

.menu-disabled-tooltip.is-left::before {
    right: -13px;
    border-left-color: #334155;
}

[data-theme='dark'] .menu-disabled-tooltip {
    background: #1e293b;
    color: #e2e8f0;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
}

[data-theme='dark'] .menu-disabled-tooltip.is-right::before {
    border-right-color: #1e293b;
}

[data-theme='dark'] .menu-disabled-tooltip.is-left::before {
    border-left-color: #1e293b;
}

a.aanvragen-link-disabled {
    opacity: 0.55;
    cursor: not-allowed;
    pointer-events: auto;
}

/* Application request meta in detail modals (periode, dagen, reden) */
.request-detail-days {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}

.request-detail-day-pill {
	display: inline-block;
	padding: 0.35rem 0.65rem;
	border-radius: 6px;
	font-size: 0.85rem;
	font-weight: 500;
	background: color-mix(in srgb, var(--tenant-primary, #582156) 10%, #f8f9fa);
	border: 1px solid color-mix(in srgb, var(--tenant-primary, #582156) 28%, #e0e0e0);
	color: var(--tenant-primary, #582156);
}

[data-theme='dark'] .request-detail-day-pill {
	background: color-mix(in srgb, var(--tenant-primary, #582156) 32%, #2a2a2a);
	border-color: color-mix(in srgb, var(--tenant-gradient-end, #8e3a78) 45%, #444);
	color: #f0e6ef;
}

.request-detail-meta-empty {
	color: #6c757d;
	font-style: italic;
}

[data-theme='dark'] .request-detail-meta-empty {
	color: #aaa;
}

/* Reusable reveal/stagger animations for pages, tables, and cards */
.ui-reveal {
	opacity: 0;
	transform: translateY(8px);
	transition: opacity 240ms ease, transform 240ms ease;
}

.ui-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.ui-enter-item {
	opacity: 0;
	transform: translateY(6px);
	animation: uiItemIn 180ms ease forwards;
}

@keyframes uiItemIn {
	from {
		opacity: 0;
		transform: translateY(6px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (prefers-reduced-motion: reduce) {
	.ui-reveal {
		opacity: 1 !important;
		transform: none !important;
		transition: none !important;
	}
	.ui-enter-item {
		opacity: 1 !important;
		transform: none !important;
		animation: none !important;
	}
}