:root {
	--cakra-primary: #0e2015;
	--cakra-primary-dark: #07140c;
	--cakra-accent: #385018;
	--cakra-accent-hover: #284010;
	--cakra-bg: #f3f5f4;
	--cakra-text: #152016;
	--cakra-muted: #4f5a53;
	--bs-primary: var(--cakra-primary);
	--bs-primary-rgb: 14 32 21;
	--bs-link-color: var(--cakra-primary);
	--bs-link-hover-color: var(--cakra-accent);
	--bs-dropdown-link-hover-color: var(--cakra-primary);
	--bs-dropdown-link-active-color: var(--cakra-primary);
}

.logo-img {
	object-fit: contain;
}

.logo-lg {
	max-height: 5rem !important;
	width: auto;
}

.nk-sidebar-logo .logo-img {
	max-height: 48px;
	width: auto;
}

.nk-sidebar.is-compact:not(:hover) .nk-sidebar-head {
	width: 76px;
	min-width: 76px;
	padding-right: 0;
	padding-left: 0;
	justify-content: center;
}

.nk-sidebar.is-compact:not(:hover) .nk-sidebar-brand {
	display: flex;
	width: 76px;
	height: 48px;
	align-items: center;
	justify-content: center;
}

.nk-sidebar.is-compact:not(:hover) .nk-sidebar-head .nk-menu-trigger {
	display: none;
}

.nk-sidebar.is-compact:not(:hover) .nk-sidebar-logo {
	position: relative;
	display: block;
	width: 76px;
	height: 48px;
	overflow: hidden;
}

.nk-sidebar-logo .logo-img-small,
.nk-sidebar.is-compact:not(:hover) .logo-img-small {
	width: auto;
	height: auto;
	max-width: 64px;
	max-height: 34px;
	object-fit: contain;
}

.nk-sidebar.is-compact:not(:hover) .nk-sidebar-logo .logo-img-small {
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

.btn-primary,
.btn-dim.btn-primary:not(:disabled):not(.disabled):hover {
	background-color: var(--cakra-primary) !important;
	border-color: var(--cakra-primary) !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
	background-color: var(--cakra-accent-hover) !important;
	border-color: var(--cakra-accent-hover) !important;
}

.progressbar-custom,
.progress .progressbar-custom {
	background-color: var(--cakra-primary) !important;
}

.btn-outline-primary {
	color: var(--cakra-primary) !important;
	border-color: var(--cakra-primary) !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
	color: #ffffff !important;
	background-color: var(--cakra-primary) !important;
	border-color: var(--cakra-primary) !important;
}

.text-primary,
.link-primary,
a {
	color: var(--cakra-primary);
}

.link-primary:hover,
a:hover {
	color: var(--cakra-accent);
}

.link-list a:hover,
.link-list a:hover .icon,
.link-list-menu a:hover,
.link-list-menu a:hover .icon,
.dropdown-menu .dropdown-item:hover,
.dropdown-menu .dropdown-item:focus {
	color: var(--cakra-primary) !important;
}

.pagination {
	--bs-pagination-hover-color: var(--cakra-primary);
	--bs-pagination-focus-color: var(--cakra-primary);
	--bs-pagination-active-bg: var(--cakra-primary);
	--bs-pagination-active-border-color: var(--cakra-primary);
}

.page-link:hover,
.page-link:focus {
	color: var(--cakra-primary) !important;
}

.page-link.active,
.active > .page-link,
.page-item.active .page-link {
	color: #ffffff !important;
	background-color: var(--cakra-primary) !important;
	border-color: var(--cakra-primary) !important;
}

.nav-tabs .nav-link:hover,
.nav-tabs .nav-link:focus,
.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link,
.nav-link.active {
	color: var(--cakra-primary) !important;
}

.nav-tabs .nav-link:after,
.nav-tabs .nav-link.active:after,
.nav-tabs .nav-item.show .nav-link:after {
	background-color: var(--cakra-primary) !important;
	border-color: var(--cakra-primary) !important;
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
	background-color: var(--cakra-primary) !important;
}

.bg-primary,
.badge-dot.bg-primary,
.badge-dim.bg-primary {
	background-color: var(--cakra-primary) !important;
}

.nk-body.bg-lighter,
.bg-lighter {
	background-color: var(--cakra-bg) !important;
}

.nk-menu-link:hover,
.active > .nk-menu-link,
.is-light .nk-menu-link:hover,
.is-light .active > .nk-menu-link {
	color: var(--cakra-primary) !important;
}

.nk-menu-link:hover .nk-menu-icon,
.active > .nk-menu-link .nk-menu-icon {
	color: var(--cakra-accent) !important;
}

.nk-menu-link:before,
.active > .nk-menu-link:before {
	background: var(--cakra-accent) !important;
}

.user-avatar,
.user-avatar[class*="bg-"] {
	background: var(--cakra-primary) !important;
	color: #ffffff !important;
}

.form-control:focus,
.form-select:focus {
	border-color: var(--cakra-accent) !important;
	box-shadow: 0 0 0 3px rgba(56, 80, 24, 0.12) !important;
}

.nk-footer-copyright,
.sub-text,
.text-soft {
	color: var(--cakra-muted);
}

.cash-btn-primary {
	color: var(--cakra-primary);
}

.form-control-wrap.error-field input {
	border: 1px solid #f9515c;
}

.form-control-wrap.error-field textarea {
	border: 1px solid #f9515c;
}

.form-control-wrap.error-field label {
	color: #f9515c;
}

.mfp-wrap {
	z-index: 9999999999 !important;
}
.mfp-image-holder .mfp-content {
	max-width: 90vw;
	max-height: 90vh;
}
img.mfp-img {
	max-height: 86vh !important;
	width: auto;
	height: auto;
	object-fit: contain;
}

.loader-wrapper,
.loader-wrapper-crud {
	position: absolute;
	height: 100%;
	width: 100%;
	top: 0;
	background: rgba(255, 255, 255, 0.6);
	border-radius: 12px;
	z-index: 5;
	display: none;
}

.loader-bars,
.loader-bars-crud {
	position: relative;
	top: 50%;
}

/* loader block */

.loader-bars,
.loader-bars-crud {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	height: 40px;
}

.loader-bars .loader-bar,
.loader-bars-crud .loader-bar-crud {
	width: 4px;
	height: 100%;
	margin-right: 4px;
	border-radius: 200px;
	-webkit-transform: scaleY(0.2);
	transform: scaleY(0.2);
	-webkit-animation: loader-bars 0.5s ease-in infinite alternate;
	animation: loader-bars 0.5s ease-in infinite alternate;
}

.loader-bars .loader-bar:last-child,
.loader-bars-crud .loader-bar-crud:last-child {
	margin-right: 0;
}

.loader-bars .loader-bar:first-child,
.loader-bars-crud .loader-bar-crud:first-child,
.loader-bars .loader-bar:nth-child(2),
.loader-bars-crud .loader-bar-crud:nth-child(2) {
	background-color: var(--cakra-primary-dark);
	-webkit-animation-delay: 0.1s;
	animation-delay: 0.1s;
}

.loader-bars .loader-bar:nth-child(3),
.loader-bars-crud .loader-bar-crud:nth-child(3) {
	background-color: var(--cakra-primary);
	-webkit-animation-delay: 0.2s;
	animation-delay: 0.2s;
}

.loader-bars .loader-bar:nth-child(4),
.loader-bars-crud .loader-bar-crud:nth-child(4) {
	background-color: var(--cakra-accent-hover);
	-webkit-animation-delay: 0.3s;
	animation-delay: 0.3s;
}

.loader-bars .loader-bar:nth-child(5),
.loader-bars-crud .loader-bar-crud:nth-child(5) {
	background-color: var(--cakra-accent);
	-webkit-animation-delay: 0.4s;
	animation-delay: 0.4s;
}

.loader-bars .loader-bar:nth-child(6),
.loader-bars-crud .loader-bar-crud:nth-child(6) {
	background-color: #689038;
	-webkit-animation-delay: 0.5s;
	animation-delay: 0.5s;
}

.loader-bars .loader-bar:nth-child(7),
.loader-bars-crud .loader-bar-crud:nth-child(7) {
	background-color: #9bbf6a;
	-webkit-animation-delay: 0.6s;
	animation-delay: 0.6s;
}

.loader-bars .loader-bar:nth-child(8),
.loader-bars-crud .loader-bar-crud:nth-child(8) {
	background-color: #c8e0a8;
	-webkit-animation-delay: 0.7s;
	animation-delay: 0.7s;
}

@-webkit-keyframes loader-bars {
	0% {
		-webkit-transform: scaleY(0.2);
		transform: scaleY(0.2);
	}
	to {
		-webkit-transform: scaleY(1);
		transform: scaleY(1);
	}
}

@keyframes loader-bars {
	0% {
		-webkit-transform: scaleY(0.2);
		transform: scaleY(0.2);
	}
	to {
		-webkit-transform: scaleY(1);
		transform: scaleY(1);
	}
}

/* End loader block */

/* Override TINYMCE */
.tox-editor-container .tox-statusbar__branding,
.tox-editor-container .tox-promotion {
	display: none !important;
}

button.tox-lock.tox-button.tox-button--naked.tox-button--icon {
	width: 3rem !important;
}
/* End Override TINYMCE */

/* Override Select2 */
input.select2-search__field {
	width: auto !important;
}
/* End Override Select2 */

/* News Comment */
.count-news-comment-wrapper,
.count-contact-message-wrapper {
	position: absolute;
	top: -7px;
	right: 10px;
	background: var(--bs-primary);
	color: #fff;
	padding: 8px;
	border-radius: 5px;
	font-size: 14px;
	line-height: 1;
}
/* End News Comment */

/* Payroll Slip (Gaji) */
.salary-card-scroll {
	overflow-x: auto;
}

.salary-card-scroll .salary-card {
	min-width: 900px;
}

.salary-card {
	max-width: 980px;
	margin: 0 auto;
	border-radius: 12px;
	box-shadow: 0 12px 30px rgba(20, 20, 20, 0.08);
}

.salary-card-inner {
	padding: 28px;
}

.salary-header {
	display: flex;
	gap: 20px;
	align-items: center;
	position: relative;
}

.salary-logo-btn {
	width: 90px;
	height: 90px;
	border: 2px dashed #d7dbe7;
	border-radius: 12px;
	background: #f9fafc;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #7c7f8a;
	font-weight: 600;
	cursor: pointer;
	padding: 0;
	position: relative;
	z-index: 3;
}

.salary-logo-btn img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	border-radius: 10px;
}

.salary-title {
	position: absolute;
	left: 0;
	right: 0;
	text-align: center;
	font-weight: 600;
	color: #3d3f4c;
	z-index: 1;
}

.salary-company {
	font-size: 18px;
	letter-spacing: 0.3px;
}

.salary-address {
	font-size: 12px;
	color: #8a8f98;
	margin-top: 2px;
}

.salary-doc-title {
	font-size: 16px;
	margin-top: 6px;
	color: #5b5f69;
}

.salary-editable {
	outline: none;
	cursor: text;
}

.salary-divider {
	height: 2px;
	background: #1d1e27;
	margin: 18px 0 16px;
}

.salary-meta {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
	font-size: 13px;
	margin-bottom: 16px;
}

.salary-meta-left,
.salary-meta-right {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.salary-field {
	display: flex;
	align-items: center;
	gap: 10px;
}

.salary-label {
	font-weight: 600;
	color: #2f3342;
	min-width: 86px;
}

.salary-value {
	font-weight: 600;
	color: var(--cakra-primary);
}

.salary-plain {
	border: none;
	background-color: transparent;
	box-shadow: none;
	padding-left: 0;
	height: auto;
	line-height: 1.3;
}

select.salary-plain {
	padding-right: 1.4rem;
	background-position: right 0.2rem center;
	background-size: 12px 12px;
}

.salary-plain:focus {
	box-shadow: none;
}

.salary-period {
	display: flex;
	gap: 8px;
}

#salary-month {
	min-width: 120px;
}

.salary-table {
	font-size: 12.5px;
	table-layout: fixed;
}

.salary-table th:nth-child(2),
.salary-table td:nth-child(2) {
	width: 160px;
}

.salary-table th:nth-child(3),
.salary-table td:nth-child(3) {
	width: 70px;
}

.salary-table th:nth-child(4),
.salary-table td:nth-child(4) {
	width: 160px;
}

.salary-total-cell {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: 8px;
}

.salary-name-cell {
	position: relative;
	padding-left: 20px;
}

.row-delete {
	border: none;
	background: transparent;
	color: #9aa0a6;
	padding: 0;
	cursor: pointer;
	display: none;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}

.salary-table tbody tr:hover .row-delete,
.salary-table tbody tr.row-active .row-delete {
	display: inline-flex;
}

.salary-table tbody tr:hover .row-delete {
	color: #d11b1b;
}

.salary-table th,
.salary-table td {
	border-left: 0 !important;
	border-right: 0 !important;
}

.salary-table td {
	border-top: 1px solid #eef1f6 !important;
	border-bottom: 1px solid #eef1f6 !important;
}

.salary-table input.form-control-sm {
	border: none;
	background: transparent;
	box-shadow: none;
	padding-left: 0;
	padding-right: 0;
	height: auto;
	line-height: 1.3;
}

.salary-component-name,
.deduction-name {
	text-transform: uppercase;
	font-weight: 600;
	color: #2f3342;
}

.salary-table input.form-control-sm:focus {
	box-shadow: none;
}

.salary-table thead th {
	background: #1c2230;
	color: #fff;
	text-transform: uppercase;
	font-weight: 600;
	font-size: 11px;
	letter-spacing: 0.6px;
}

.salary-table input {
	height: 32px;
}

.salary-table .form-control-sm {
	font-size: 12px;
}

.salary-total-row td {
	background: #f0f3f9;
	font-weight: 700;
}

.salary-deduction-table tbody tr td {
	background: #fff;
	border-bottom: 1px solid #f5b5b5 !important;
}

.salary-deduction-table tbody tr td,
.salary-deduction-table .deduction-name,
.salary-deduction-table .deduction-amount {
	color: #d11b1b;
	font-weight: 600;
}

.salary-deduction-table .deduction-amount {
	text-align: right;
}

.salary-net-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: #0f1627;
	color: #fff;
	padding: 10px 16px;
	border-radius: 6px;
	margin-top: 12px;
	font-weight: 700;
	letter-spacing: 0.6px;
	font-size: 13px;
}

.salary-net-value {
	background: #254c9a;
	padding: 6px 12px;
	border-radius: 4px;
	min-width: 140px;
	text-align: right;
}

.salary-bonus-table {
	margin-top: 10px;
	border: 1px solid #e6e9f2;
	border-radius: 6px;
	overflow: hidden;
}

.salary-bonus-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 8px 12px;
	border-bottom: 1px solid #e6e9f2;
	font-size: 12.5px;
	font-weight: 600;
	gap: 12px;
}

.salary-money-right {
	text-align: right;
	min-width: 140px;
}

.salary-bonus-row:last-child {
	border-bottom: none;
}

.salary-bonus-label {
	color: #2f3342;
	white-space: nowrap;
	flex: 1;
}

.salary-bonus-value {
	color: var(--cakra-primary);
	font-weight: 700;
	min-width: 140px;
	text-align: right;
}

.salary-footer {
	display: flex;
	justify-content: space-between;
	gap: 20px;
	margin-top: 18px;
	flex-wrap: wrap;
}

.salary-notes {
	flex: 1;
	min-width: 260px;
}

.salary-sign {
	min-width: 220px;
	text-align: center;
	font-size: 12px;
	font-weight: 600;
	color: #2f3342;
}

.salary-stamp-btn {
	width: 120px;
	height: 120px;
	border: 2px dashed #d7dbe7;
	border-radius: 12px;
	background: #f9fafc;
	margin: 8px auto 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #7c7f8a;
	cursor: pointer;
}

.salary-stamp-btn img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	border-radius: 10px;
}

.salary-sign-name {
	margin-top: 4px;
	font-weight: 700;
}

.salary-sign-role {
	font-size: 11px;
	color: #8a8f98;
}

/* Payroll slip modal (detail) text alignment */
#salary-db-card .salary-label {
	min-width: 90px;
	padding-right: 8px;
}

#salary-db-card .salary-value {
	font-weight: 700;
	color: #1f2430;
}

#salary-db-days,
#salary-db-overtime,
#salary-db-period-label {
	color: var(--cakra-primary) !important;
	font-weight: 700;
}

#salary-db-card .salary-footer {
	align-items: stretch;
}

#salary-db-card .salary-notes {
	display: flex;
}

#salary-db-card .salary-note-box,
#salary-db-card .salary-sign {
	min-height: 190px;
}

#salary-db-card .salary-note-box {
	flex: 1;
	height: 100%;
}

.salary-db-reset-btn {
	margin-right: 6px;
	margin-top: 8px;
}

.salary-db-header {
	margin-bottom: 18px;
}

.salary-db-empty {
	margin-top: 24px;
	border: 2px dashed #d9e0ef;
	border-radius: 18px;
	padding: 48px 16px;
	text-align: center;
	color: #8e95a3;
	background: #fbfcfe;
}

.salary-db-empty-icon {
	width: 70px;
	height: 70px;
	border-radius: 50%;
	background: #eef2f8;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 30px;
	color: #c3c9d6;
	margin-bottom: 16px;
}

.salary-db-empty-title {
	font-weight: 700;
	letter-spacing: 1px;
	color: #8c94a5;
	margin-bottom: 6px;
}

.salary-db-empty-desc {
	font-size: 13px;
	color: #9aa2b1;
}

.salary-note-box {
	border: 1px solid #d7dbe7;
	border-radius: 10px;
	padding: 12px 14px;
	background: #fafbfe;
	font-size: 13px;
	color: #6d7483;
	min-height: 74px;
}

.salary-note-box::before {
	content: "CATATAN:";
	display: block;
	font-weight: 700;
	color: #8a94a6;
	letter-spacing: 0.5px;
	margin-bottom: 6px;
}

.salary-db-card {
	border-radius: 14px;
}

.salary-db-icon {
	width: 46px;
	height: 46px;
	border-radius: 12px;
	background: rgba(46, 91, 255, 0.12);
	color: #2e5bff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
}

.salary-db-code {
	font-size: 11px;
	color: #a1a6b1;
	font-weight: 600;
}

.salary-db-date {
	font-size: 12px;
	color: #7c808a;
	margin-top: 4px;
}

.salary-db-name {
	margin-top: 14px;
	font-weight: 700;
	font-size: 16px;
	color: #1f2430;
}

.salary-db-period {
	margin-top: 4px;
	font-size: 13px;
	font-weight: 600;
	color: #2e5bff;
}

.salary-db-total {
	margin-top: 14px;
	background: #f6f8ff;
	border-radius: 10px;
	padding: 10px 12px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: 12px;
	color: #6f7481;
}

.salary-db-total strong {
	color: #0f8a5f;
	font-size: 14px;
}

.salary-db-actions {
	margin-top: 14px;
	display: grid;
	grid-template-columns: 1fr 44px;
	gap: 10px;
	align-items: center;
}

.salary-db-delete {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
}

/* Select2 search full width */
.select2-container .select2-search--dropdown .select2-search__field {
	width: 100% !important;
	box-sizing: border-box;
}

.salary-logo-static,
.salary-stamp-static {
	border: none;
	background: transparent;
}

.salary-logo-static .salary-logo-placeholder,
.salary-stamp-static .salary-stamp-placeholder {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #9aa1ad;
	font-weight: 600;
}

.salary-card {
	position: relative;
}

.salary-ribbon {
	position: absolute;
	top: 14px;
	right: -46px;
	transform: rotate(45deg);
	background: #24a865;
	color: #fff;
	font-weight: 700;
	font-size: 11px;
	padding: 6px 50px;
	letter-spacing: 1px;
	box-shadow: 0 6px 12px rgba(0, 0, 0, 0.12);
	z-index: 5;
	overflow: hidden;
}

.salary-ribbon::before,
.salary-ribbon::after {
	content: "";
	position: absolute;
	bottom: -6px;
	border-width: 6px 6px 0 6px;
	border-style: solid;
	border-color: #1f8a54 transparent transparent transparent;
}

.salary-ribbon::before {
	left: 0;
}

.salary-ribbon::after {
	right: 0;
}

@media (max-width: 768px) {
	/* .salary-header {
		flex-direction: column;
	} */

	.salary-title {
		text-align: center;
	}

	/* .salary-meta {
		flex-direction: column;
		align-items: flex-start;
	} */

	.salary-net-row {
		flex-direction: column;
		gap: 8px;
	}

	.salary-net-value {
		width: 100%;
	}
}
/* End Payroll Slip (Gaji) */

/* Cash pages */
.cash-hero {
	background: var(--cakra-primary);
	color: #fff;
	border-radius: 24px;
	padding: 28px 32px;
	box-shadow: 0 18px 35px rgba(14, 32, 21, 0.22);
	/* margin-top: 32px; */
}
.cash-hero .cash-label {
	font-size: 12px;
	letter-spacing: 2px;
	text-transform: uppercase;
	opacity: 0.85;
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 12px;
}
.cash-hero .cash-label .icon {
	font-size: 18px;
}
.cash-hero .cash-amount {
	font-size: 48px;
	font-weight: 800;
	line-height: 1.1;
	margin-bottom: 24px;
}
.cash-hero .cash-actions {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
}
.cash-btn {
	border-radius: 999px;
	padding: 10px 22px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	font-size: 12px;
	border: 1px solid transparent;
}
.cash-btn-primary {
	background: #ffffff;
	color: var(--cakra-primary);
	border-color: #ffffff;
}
.cash-btn-secondary {
	background: transparent;
	color: #ffffff;
	border-color: rgba(255, 255, 255, 0.25);
}
.cash-btn-danger {
	background: #ff3b4a;
	color: #ffffff;
	border-color: #ff3b4a;
}
.cash-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
}
.cash-tools {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 12px;
	flex-wrap: wrap;
}
.cash-tool-select {
	min-width: 220px;
}
.cash-table-scroll {
	overflow-x: auto;
}
.cash-table-scroll table {
	min-width: 1400px;
}
.cash-category-box {
	background: #f6f8ff;
	border: 1px solid #e2e8f5;
	border-radius: 16px;
	padding: 20px;
	margin-bottom: 24px;
}
.cash-category-title {
	font-size: 12px;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: #6c72ff;
	font-weight: 700;
	margin-bottom: 14px;
}
.cash-category-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
}
.cash-category-item {
	background: #fff;
	border: 1px solid #e2e8f5;
	border-radius: 16px;
	padding: 16px 18px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	box-shadow: 0 10px 20px rgba(30, 48, 85, 0.06);
}
.cash-category-item .cash-category-text {
	font-weight: 600;
	color: #2b2f3a;
}
.cash-category-item .btn {
	flex-shrink: 0;
}
.form-control-select.no-arrow:after {
	content: none;
}
@media (max-width: 768px) {
	.cash-toolbar {
		align-items: flex-start;
	}
	.cash-tools {
		width: 100%;
		justify-content: flex-start;
	}
	.cash-tool-select {
		width: 100%;
		min-width: 0;
	}
	.cash-tools .btn,
	.cash-tools .dropdown {
		width: 100%;
	}
	.cash-tools .dropdown .btn {
		width: 100%;
	}
}
@media (max-width: 768px) {
	.cash-hero {
		padding: 22px;
	}
	.cash-hero .cash-amount {
		font-size: 36px;
	}
}
.report-hero {
	border-radius: 26px;
	box-shadow: 0 12px 32px rgba(15, 23, 42, 0.08);
	border: 1px solid #eef1f6;
	/* margin-top: 12px; */
}
.report-hero-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
}
.report-title {
	font-size: 22px;
	font-weight: 700;
	margin-bottom: 2px;
}
.report-subtitle {
	font-size: 12px;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: #8091a7;
	font-weight: 600;
}
.report-filter {
	display: flex;
	align-items: center;
	gap: 12px;
	background: #f5f7fb;
	border-radius: 999px;
	padding: 8px 12px;
	border: 1px solid #eef1f6;
}
.report-date-input {
	display: flex;
	align-items: center;
	gap: 8px;
	background: #fff;
	border-radius: 999px;
	padding: 6px 12px;
	border: 1px solid #e5e9f2;
}
.report-date-input .form-control {
	border: none;
	padding: 0;
	height: auto;
	min-width: 110px;
	background: transparent;
}
.report-date-input .form-control:focus {
	box-shadow: none;
}
.report-summary {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}
.report-summary-4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}
.summary-card {
	border-radius: 22px;
	color: #fff;
	padding: 18px 22px;
	min-height: 120px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}
.summary-card h6 {
	font-size: 12px;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: 8px;
}
.summary-card .summary-value {
	font-size: 26px;
	font-weight: 700;
}
.summary-green {
	background: linear-gradient(135deg, #00b87b 0%, #00a76b 100%);
}
.summary-red {
	background: linear-gradient(135deg, #f43f5e 0%, #ef4444 100%);
}
.summary-blue {
	background: linear-gradient(135deg, #4f46e5 0%, #4338ca 100%);
}
.summary-yellow {
	background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}
.report-table-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 18px;
}
.report-table-title {
	display: flex;
	align-items: center;
	gap: 12px;
}
.report-table-title .title {
	margin-bottom: 0;
}
.report-chart-total {
	font-size: 12px;
	color: #8091a7;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 12px;
}
.report-total {
	font-size: 12px;
	color: #8091a7;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
}
.report-filters {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}
.report-filters .form-control {
	width: 180px;
}
.report-filters .select2-container {
	width: 180px !important;
}
.report-chart-box {
	height: 280px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.report-chart-box-lg {
	height: 320px;
}
@media (max-width: 991px) {
	.report-summary {
		grid-template-columns: 1fr;
	}
}
.drive-header-actions {
	display: flex;
	gap: 12px;
	align-items: center;
}
.drive-search {
	min-width: 0;
}
.drive-filter-card {
	border: 1px solid #e5e9f2;
	border-radius: 16px;
	padding: 16px;
	background: #fff;
}
.drive-card {
	border: 1px solid #e5e9f2;
	border-radius: 16px;
	background: #fff;
	overflow: hidden;
	position: relative;
	height: 100%;
	display: flex;
	flex-direction: column;
}
.drive-card-thumb {
	height: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
}
.drive-photo-thumb {
	background-size: cover;
	background-position: center;
}
.drive-video-thumb {
	cursor: pointer;
}
.drive-card-thumb .icon {
	font-size: 56px;
	color: #fff;
	text-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
}
.drive-card--apps .drive-card-thumb {
	background: #ff7a59;
	background-image: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.35), transparent 55%),
		radial-gradient(circle at 80% 80%, rgba(0, 0, 0, 0.18), transparent 60%);
}
.drive-card--document .drive-card-thumb {
	background: #5b8ef8;
	background-image: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.35), transparent 55%),
		radial-gradient(circle at 80% 80%, rgba(0, 0, 0, 0.18), transparent 60%);
}
.drive-card--notes .drive-card-thumb {
	background: #34c38f;
	background-image: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.35), transparent 55%),
		radial-gradient(circle at 80% 80%, rgba(0, 0, 0, 0.18), transparent 60%);
}
.drive-card--photo .drive-card-thumb {
	background: #eef1f6;
}
.drive-card--portrait .drive-card-thumb {
	height: 200px;
	background-image: var(--thumb-url);
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	position: relative;
	overflow: hidden;
}
.drive-card--portrait .drive-card-thumb::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: var(--thumb-url);
	background-size: cover;
	background-position: center;
	filter: blur(14px);
	transform: scale(1.08);
	opacity: 0.45;
}
.drive-card--portrait .drive-card-thumb::after {
	content: "";
	position: absolute;
	inset: 0;
	background: transparent;
}
.drive-card--portrait .drive-thumb-media {
	position: relative;
	z-index: 1;
	width: 100%;
	height: 100%;
	object-fit: contain;
}
@media (max-width: 991.98px) {
	.drive-card--portrait .drive-card-thumb {
		height: 180px;
	}
	.drive-card-thumb {
		height: 180px;
	}
}
.drive-card--video .drive-card-thumb {
	background: #2f80ed;
	background-image: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.35), transparent 55%),
		radial-gradient(circle at 80% 80%, rgba(0, 0, 0, 0.18), transparent 60%);
}
.drive-card-body {
	padding: 16px;
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
}
.drive-card-title {
	font-weight: 600;
	font-size: 15px;
	margin-bottom: 6px;
	display: inline-flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
}
.drive-ext-chip {
	display: inline-flex;
	align-items: center;
	padding: 2px 8px;
	border-radius: 999px;
	background: #eef2ff;
	color: #3f51b5;
	font-size: 10px;
	font-weight: 700;
	line-height: 1.2;
	text-transform: lowercase;
}
.drive-card-meta {
	color: #7a879e;
	font-size: 12px;
	display: flex;
	gap: 10px;
	align-items: center;
}
.drive-card-notes {
	color: #526484;
	font-size: 13px;
	margin: 10px 0 14px;
}
.drive-card-actions {
	display: flex;
	gap: 8px;
	margin-top: auto;
}
.drive-card-actions .btn {
	flex: 0 0 auto;
}
.drive-card-actions .btn-download {
	flex: 1 1 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.drive-card-actions .btn-icon {
	width: 40px;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.drive-card-winner {
	margin-top: 12px;
}
.drive-card-winner .select2-container {
	width: 100% !important;
}
.drive-card-winner .select2-selection--single {
	height: 36px;
}
.drive-card-winner .select2-selection__rendered {
	line-height: 34px;
}
.drive-card-winner .select2-selection__arrow {
	height: 34px;
}
.drive-winner-option {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.drive-winner-option .icon {
	color: #f2b200;
	font-size: 14px;
}
.drive-winner-option .fa,
.drive-winner-option .fas {
	color: #f2b200;
	font-size: 14px;
}
.drive-filter-actions .btn {
	padding: 0.5rem 1.1rem;
}
.drive-video-popup {
	width: fit-content;
	max-width: calc(100vw - 32px);
	max-height: calc(100vh - 96px);
	margin: 0 auto;
	padding: 8px;
	background: #0b1020;
	border-radius: 12px;
	position: relative;
}
.drive-video-popup video {
	width: auto;
	height: auto;
	max-width: calc(100vw - 48px);
	max-height: calc(100vh - 120px);
	display: block;
	border-radius: 8px;
	margin: 0 auto;
}
.drive-video-popup .mfp-close {
	right: -6px;
	top: -10px;
}
.drive-loader {
	text-align: center;
	padding: 20px 0;
	color: #7a879e;
}
.drive-scroll-loader {
	display: none;
	text-align: center;
	padding: 12px 0 4px;
}
.drive-scroll-loader .loader-bars {
	height: 20px;
}
.drive-scroll-loader .loader-bar {
	height: 20px;
	width: 3px;
	margin-right: 3px;
}
.drive-badge {
	background: #f5f6fa;
	color: #526484;
	padding: 2px 8px;
	border-radius: 8px;
	font-size: 11px;
}
.drive-badge--type {
	color: #fff;
}
.drive-winner-ribbon {
	position: absolute;
	top: 16px;
	right: -44px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 50px;
	font-size: 11px;
	font-weight: 700;
	color: #fff;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	transform: rotate(45deg);
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
	z-index: 2;
}
.drive-winner-ribbon .icon {
	font-size: 12px;
}
.drive-winner-ribbon .fa,
.drive-winner-ribbon .fas {
	font-size: 12px;
}
.drive-winner-ribbon--youtube {
	background: #ff0033;
}
.drive-winner-ribbon--tiktok {
	background: #111827;
}
.drive-card--apps .drive-badge--type {
	background: #ff7a59;
}
.drive-card--document .drive-badge--type {
	background: #5b8ef8;
}
.drive-card--notes .drive-badge--type {
	background: #34c38f;
}
.drive-card--photo .drive-badge--type {
	background: #9b51e0;
}
.drive-card--video .drive-badge--type {
	background: #2f80ed;
}
.drive-report-table table {
	width: 100%;
}
.drive-report-name {
	display: flex;
	align-items: center;
	gap: 10px;
	font-weight: 600;
	color: #364a63;
}
.attendance-report-scroll {
	overflow-x: auto;
}
.attendance-report-scroll table {
	min-width: 1000px;
}
.drive-report-avatar {
	width: 34px;
	height: 34px;
	border-radius: 10px;
	background: #e9f0ff;
	color: #2f80ed;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
}
.drive-report-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 4px 10px;
	border-radius: 10px;
	background: #f1f3f7;
	color: #364a63;
	font-weight: 600;
	font-size: 12px;
}
.drive-report-rank-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.drive-report-rank-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 12px;
	border-radius: 12px;
	background: #f8faff;
}
.drive-report-rank-name {
	display: flex;
	align-items: center;
	gap: 10px;
	color: #364a63;
	font-weight: 600;
}
.drive-report-rank-index {
	width: 26px;
	height: 26px;
	border-radius: 8px;
	background: #e9f0ff;
	color: #2f80ed;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 12px;
}
.drive-report-rank-value {
	font-weight: 700;
	color: #364a63;
}
.drive-modal-label {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: #8094ae;
	margin-bottom: 6px;
}
.drive-header-wrap {
	flex-wrap: wrap;
}
.drive-header-actions {
	flex-wrap: wrap;
}

@media (max-width: 767.98px) {
	.drive-header-actions .form-control-wrap {
		flex: 0 0 100%;
		width: 100%;
	}
}
.drive-category-item {
	font-weight: 700;
}
.drive-category-delete {
	width: 36px;
	height: 36px;
	border-radius: 10px;
	background: #fdecec;
	border: 1px solid #fdecec;
	color: #e85347;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
