:root {
	--tw-primary: #206bc4;
	--tw-primary-rgb: 32, 107, 196;
	--tw-primary-dark: #1b5aa5;
	--tw-bg: #f4f6fb;
	--tw-bg-soft: #eef2f9;
	--tw-surface: #ffffff;
	--tw-border: #dce3f1;
	--tw-text: #182433;
	--tw-muted: #667382;
	--tw-sidebar: #0f172a;
	--tw-sidebar-soft: #16213a;
	--tw-success: #2fb344;
	--tw-warning: #f59f00;
	--tw-danger: #d63939;
	--tw-shadow: 0 12px 32px rgba(15, 23, 42, 0.08);
	--tw-radius: 16px;
}

body,
body.body,
body.hold-transition {
	font-family: 'Inter', 'Source Sans Pro', sans-serif;
	background: var(--tw-bg);
	color: var(--tw-text);
}

body.theme-tabler {
	background:
		radial-gradient(circle at top right, rgba(var(--tw-primary-rgb), 0.08), transparent 24%),
		linear-gradient(180deg, #f8faff 0%, #f4f6fb 100%);
}

.layout-fixed .main-sidebar,
.main-sidebar {
	box-shadow: none;
}

.main-header {
	border-bottom: 1px solid rgba(var(--tw-primary-rgb), 0.08);
	background: rgba(255, 255, 255, 0.92) !important;
	backdrop-filter: blur(12px);
}

.main-header.navbar {
	min-height: 72px;
	padding: 0.75rem 1.25rem;
}

.main-header .nav-link {
	color: var(--tw-text) !important;
	border-radius: 12px;
}

.main-header .nav-link:hover,
.main-header .nav-link:focus {
	background: rgba(var(--tw-primary-rgb), 0.08);
}

.tw-navbar-chip {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.55rem 0.9rem;
	background: rgba(var(--tw-primary-rgb), 0.1);
	border: 1px solid rgba(var(--tw-primary-rgb), 0.15);
	color: var(--tw-primary);
	border-radius: 999px;
	font-weight: 600;
	line-height: 1;
}

.tw-navbar-user {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.4rem 0.55rem 0.4rem 0.4rem;
	border: 1px solid var(--tw-border);
	background: #fff;
	border-radius: 999px;
}

.tw-avatar {
	width: 38px;
	height: 38px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--tw-primary) 0%, #6ea8fe 100%);
	color: #fff;
	font-weight: 700;
	font-size: 0.9rem;
	letter-spacing: 0.04em;
}

.tw-user-meta {
	display: flex;
	flex-direction: column;
	line-height: 1.1;
}

.tw-user-meta small {
	color: var(--tw-muted);
}

.main-sidebar {
	background: linear-gradient(180deg, var(--tw-sidebar) 0%, var(--tw-sidebar-soft) 100%) !important;
	border-right: 1px solid rgba(255, 255, 255, 0.05);
}

.brand-link {
	height: auto;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
	background: transparent !important;
	padding: 1rem 1rem 0.85rem;
}

.tw-brand-wrap {
	display: flex;
	align-items: center;
	gap: 0.85rem;
}

.tw-brand-badge {
	width: 44px;
	height: 44px;
	flex: 0 0 44px;
	border-radius: 14px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, rgba(255,255,255,0.22), rgba(255,255,255,0.08));
	color: #fff;
	font-size: 1.15rem;
}

.tw-brand-text {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.tw-brand-title {
	color: #fff;
	font-weight: 700;
	letter-spacing: 0.01em;
}

.tw-brand-subtitle {
	color: rgba(255, 255, 255, 0.65);
	font-size: 0.78rem;
}

.sidebar {
	padding: 1rem 0.85rem;
}

.user-panel {
	border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
	margin-top: 0 !important;
	padding: 0 0.5rem 1rem !important;
	align-items: center;
	gap: 0.8rem;
}

.user-panel .info {
	padding: 0 !important;
}

.user-panel .info a {
	color: #fff !important;
	font-weight: 600;
}

.tw-user-panel-avatar {
	width: 42px;
	height: 42px;
	border-radius: 14px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
	font-weight: 700;
	text-transform: uppercase;
}

.nav-sidebar > .nav-item > .nav-link.active {
	background: rgba(var(--tw-primary-rgb), 0.18) !important;
	color: #fff !important;
	box-shadow: inset 0 0 0 1px rgba(255,255,255,0.04);
}

.nav-sidebar .nav-link {
	margin-bottom: 0.3rem;
	border-radius: 12px;
	padding: 0.8rem 0.9rem;
	color: rgba(255, 255, 255, 0.82) !important;
}

.nav-sidebar .nav-link:hover,
.nav-sidebar .nav-link:focus {
	background: rgba(255, 255, 255, 0.06) !important;
	color: #fff !important;
}

.nav-sidebar .nav-treeview {
	margin-top: 0.3rem;
	padding-left: 0.55rem;
}

.nav-sidebar .nav-treeview > .nav-item > .nav-link {
	padding: 0.65rem 0.75rem;
	font-size: 0.94rem;
}

.content-wrapper {
	background: transparent;
	padding-bottom: 2rem;
}

.content-header {
	padding: 1.25rem 1.5rem 0.5rem;
}

.content-header h1,
.content-header .m-0 {
	font-weight: 700;
	color: var(--tw-text);
}

.breadcrumb {
	background: transparent;
	margin-bottom: 0;
}

.breadcrumb-item,
.breadcrumb-item a {
	color: var(--tw-muted);
}

.content .container,
.content .container-fluid {
	padding-top: 0.75rem;
}

.card,
.small-box,
.info-box,
.modal-content,
.dropdown-menu {
	border: 1px solid var(--tw-border);
	border-radius: var(--tw-radius);
	box-shadow: var(--tw-shadow);
}

.card-header,
.modal-header {
	border-bottom-color: var(--tw-border);
}

.btn-primary,
.bg-primary {
	background: var(--tw-primary) !important;
	border-color: var(--tw-primary) !important;
}

.btn-primary:hover,
.btn-primary:focus {
	background: var(--tw-primary-dark) !important;
	border-color: var(--tw-primary-dark) !important;
}

.btn-light,
.btn-default {
	background: #fff;
	border-color: var(--tw-border);
	color: var(--tw-text);
}

.form-control,
.custom-select,
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
	min-height: 44px;
	border-radius: 12px !important;
	border-color: var(--tw-border) !important;
	box-shadow: none !important;
}

.form-control:focus,
.custom-select:focus {
	border-color: rgba(var(--tw-primary-rgb), 0.7) !important;
	box-shadow: 0 0 0 0.2rem rgba(var(--tw-primary-rgb), 0.12) !important;
}

.table,
.table td,
.table th,
.dataTable td,
.dataTable th {
	border-color: #e9eef7 !important;
}

.table thead th {
	background: #f8faff;
	color: var(--tw-muted);
	font-weight: 700;
	text-transform: uppercase;
	font-size: 0.75rem;
	letter-spacing: 0.04em;
}

.page-link {
	color: var(--tw-primary);
	border-color: var(--tw-border);
}

.page-item.active .page-link {
	background: var(--tw-primary);
	border-color: var(--tw-primary);
}

#loading-screen {
	position: fixed;
	inset: 0;
	z-index: 2000;
	background: rgba(255, 255, 255, 0.85);
	display: flex;
	align-items: center;
	justify-content: center;
}

.tw-page-shell {
	background: linear-gradient(180deg, rgba(var(--tw-primary-rgb), 0.06) 0%, rgba(255, 255, 255, 0) 220px);
}

.tw-home-panel {
	background: rgba(255, 255, 255, 0.8);
	border: 1px solid var(--tw-border);
	border-radius: 24px;
	box-shadow: var(--tw-shadow);
	padding: 1.25rem;
}

.tw-dashboard-grid {
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
	gap: 1rem;
}

.tw-metric-card {
	position: relative;
	overflow: hidden;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 249, 252, 0.96));
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: 22px;
	box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
	padding: 1.25rem;
	min-height: 168px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.tw-metric-card::after {
	content: "";
	position: absolute;
	inset: auto -36px -36px auto;
	width: 120px;
	height: 120px;
	border-radius: 999px;
	background: rgba(var(--tw-primary-rgb), 0.08);
	pointer-events: none;
}

.tw-metric-card__head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
	position: relative;
	z-index: 1;
}

.tw-metric-card__label {
	display: block;
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--tw-muted);
	margin-bottom: 0.35rem;
}

.tw-metric-card__value {
	margin: 0;
	font-size: 2rem;
	line-height: 1;
	font-weight: 800;
	color: var(--tw-text);
}

.tw-metric-card__value small {
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--tw-muted);
}

.tw-metric-card__icon {
	width: 52px;
	height: 52px;
	border-radius: 16px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1.25rem;
	color: #fff;
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.24);
}

.tw-metric-card__meta {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 1rem;
	font-size: 0.92rem;
	color: var(--tw-muted);
}

.tw-metric-card__meta a {
	font-weight: 700;
	text-decoration: none;
}

.tw-metric-card--info .tw-metric-card__icon { background: linear-gradient(135deg, #4299ff, #2563eb); }
.tw-metric-card--success .tw-metric-card__icon { background: linear-gradient(135deg, #32c671, #16a34a); }
.tw-metric-card--warning .tw-metric-card__icon { background: linear-gradient(135deg, #f6c85f, #f59e0b); }
.tw-metric-card--danger .tw-metric-card__icon { background: linear-gradient(135deg, #fb7185, #e11d48); }
.tw-metric-card--primary .tw-metric-card__icon { background: linear-gradient(135deg, #7c6cff, #5b4ee5); }

.tw-chart-card {
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: 24px;
	box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
	overflow: hidden;
	height: 100%;
}

.tw-chart-card__header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
	padding: 1.25rem 1.25rem 0;
}

.tw-chart-card__header h4 {
	margin: 0;
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--tw-text);
}

.tw-chart-card__header p {
	margin: 0.35rem 0 0;
	color: var(--tw-muted);
	font-size: 0.94rem;
}

.tw-chart-card__body {
	padding: 1rem 1.25rem 1.25rem;
	height: calc(100% - 74px);
}

.tw-chart-card__canvas {
	position: relative;
	min-height: 300px;
	height: 300px;
	border-radius: 18px;
	background: linear-gradient(180deg, rgba(var(--tw-primary-rgb), 0.03), rgba(255,255,255,0));
	padding: 0.5rem;
}

.tw-shortcut-card {
	background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.96));
	border: 1px solid rgba(15, 23, 42, 0.08);
	border-radius: 22px;
	box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
	padding: 1.2rem;
	height: 100%;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.tw-shortcut-card__icon {
	width: 50px;
	height: 50px;
	border-radius: 16px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1.2rem;
	color: #fff;
}

.tw-shortcut-card__title {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--tw-text);
}

.tw-shortcut-card__text {
	margin: 0;
	color: var(--tw-muted);
	font-size: 0.94rem;
	line-height: 1.5;
}

.tw-shortcut-card__link {
	margin-top: auto;
	font-weight: 700;
	text-decoration: none;
}

.tw-shortcut-card--info .tw-shortcut-card__icon { background: linear-gradient(135deg, #4299ff, #2563eb); }
.tw-shortcut-card--success .tw-shortcut-card__icon { background: linear-gradient(135deg, #32c671, #16a34a); }
.tw-shortcut-card--warning .tw-shortcut-card__icon { background: linear-gradient(135deg, #f6c85f, #f59e0b); }
.tw-shortcut-card--danger .tw-shortcut-card__icon { background: linear-gradient(135deg, #fb7185, #e11d48); }

.tw-dashboard-section-title {
	margin: 0 0 1rem;
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--tw-text);
}

.tw-section-card {
	background: rgba(255, 255, 255, 0.92);
	border: 1px solid var(--tw-border);
	border-radius: 24px;
	box-shadow: var(--tw-shadow);
	overflow: hidden;
}

.tw-section-card__header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
	padding: 1.35rem 1.35rem 0;
}

.tw-section-card__header h3 {
	margin: 0.35rem 0 0;
	font-size: 1.3rem;
	font-weight: 700;
	color: var(--tw-text);
}

.tw-section-card__header p {
	margin: 0.4rem 0 0;
	color: var(--tw-muted);
}

.tw-section-card__body {
	padding: 1.35rem;
}

.tw-section-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
	padding: 1.35rem 1.35rem 0;
}

.tw-section-title {
	margin: 0;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--tw-text);
}

.tw-section-subtitle {
	margin: 0.35rem 0 0;
	color: var(--tw-muted);
}

.tw-toolbar {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.tw-toolbar .btn {
	border-radius: 12px;
	min-height: 42px;
	font-weight: 600;
}

.tw-toolbar.tw-toolbar-stretch .btn {
	min-width: 220px;
}

.tw-intro-banner {
	margin: 1.25rem 1.35rem 0;
	padding: 1rem 1.1rem;
	border-radius: 18px;
	background: linear-gradient(135deg, rgba(var(--tw-primary-rgb), 0.09), rgba(47, 179, 68, 0.06));
	border: 1px solid rgba(var(--tw-primary-rgb), 0.12);
}

.tw-intro-banner p {
	margin: 0.35rem 0 0;
	color: var(--tw-muted);
}

.tw-intro-banner__meta {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-wrap: wrap;
	margin-top: 0.95rem;
}

.tw-intro-banner__meta span {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.55rem 0.8rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.72);
	border: 1px solid rgba(var(--tw-primary-rgb), 0.12);
	color: var(--tw-text);
	font-weight: 600;
}

.tw-search-shell {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
	gap: 1rem;
	padding: 1.25rem 1.35rem 0;
}

.tw-search-panel,
.tw-help-panel {
	border: 1px solid var(--tw-border);
	border-radius: 22px;
	background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
	padding: 1.25rem;
}

.tw-help-panel__icon {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 16px;
	background: rgba(var(--tw-primary-rgb), 0.1);
	color: var(--tw-primary);
	font-size: 1.15rem;
	margin-bottom: 0.85rem;
}

.tw-help-panel h4 {
	margin: 0 0 0.65rem;
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--tw-text);
}

.tw-search-title {
	font-size: 1.2rem;
	font-weight: 700;
	margin: 0 0 0.35rem;
}

.tw-search-subtitle,
.tw-help-panel p,
.tw-help-list li {
	color: var(--tw-muted);
}

.tw-search-form {
	display: grid;
	grid-template-columns: 160px minmax(0, 1fr) auto;
	gap: 0.85rem;
	margin-top: 1rem;
	align-items: start;
}

.tw-search-form .form-control,
.tw-search-form .btn {
	min-height: 46px;
}

.tw-search-form .btn {
	border-radius: 12px;
	font-weight: 700;
	min-width: 150px;
}

.tw-help-list {
	padding-left: 1rem;
	margin: 0.75rem 0 0;
}

.tw-profile-shell {
	padding: 1.25rem 1.35rem 1.35rem;
}

.tw-profile-card {
	border: 1px solid var(--tw-border);
	border-radius: 24px;
	background: rgba(255,255,255,0.96);
	box-shadow: var(--tw-shadow);
	overflow: hidden;
}

.tw-profile-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 1.35rem;
	background: linear-gradient(135deg, rgba(var(--tw-primary-rgb), 0.1), rgba(14, 116, 144, 0.06));
	border-bottom: 1px solid var(--tw-border);
}

.tw-profile-headline {
	margin: 0;
	font-size: 1.25rem;
	font-weight: 800;
}

.tw-profile-meta {
	display: flex;
	gap: 0.6rem;
	flex-wrap: wrap;
	margin-top: 0.5rem;
}

.tw-profile-meta .tw-badge-soft {
	font-size: 0.8rem;
}

.tw-profile-body {
	padding: 1.35rem;
}

.tw-profile-grid {
	display: grid;
	grid-template-columns: 260px minmax(0, 1fr);
	gap: 1rem;
}

.tw-profile-aside,
.tw-profile-section {
	border: 1px solid var(--tw-border);
	border-radius: 22px;
	background: #fff;
	padding: 1.1rem;
}

.tw-profile-photo {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.tw-profile-photo img {
	width: 112px;
	height: 112px;
	object-fit: cover;
	border-radius: 18px;
	border: 4px solid rgba(var(--tw-primary-rgb), 0.08);
	box-shadow: var(--tw-shadow);
}

.tw-profile-photo small {
	color: var(--tw-muted);
	margin-top: 0.8rem;
}

.tw-section-stack {
	display: grid;
	gap: 1rem;
}

.tw-section-heading {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	margin-bottom: 0.85rem;
}

.tw-section-heading h4 {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 800;
}

.tw-section-heading p {
	margin: 0.3rem 0 0;
	color: var(--tw-muted);
	font-size: 0.9rem;
}

.tw-map-frame {
	overflow: hidden;
	border: 1px solid var(--tw-border);
	border-radius: 20px;
}

.tw-form-footer {
	display: flex;
	justify-content: flex-end;
	padding-top: 1rem;
}

.tw-form-footer .btn {
	min-height: 46px;
	border-radius: 12px;
	font-weight: 700;
}

.tw-inline-alert {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 0.95rem 1rem;
	border-radius: 18px;
	border: 1px solid rgba(var(--tw-primary-rgb), 0.12);
	background: rgba(var(--tw-primary-rgb), 0.06);
	color: var(--tw-text);
}

.tw-inline-alert i {
	color: var(--tw-primary);
	margin-top: 0.15rem;
}

.tw-kpi-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
	padding: 1.25rem 1.35rem;
}

.tw-kpi {
	position: relative;
	border: 1px solid var(--tw-border);
	border-radius: 18px;
	background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
	padding: 1rem 1.1rem;
}

.tw-kpi-label {
	display: block;
	color: var(--tw-muted);
	font-size: 0.83rem;
	margin-bottom: 0.45rem;
}

.tw-kpi-value {
	display: block;
	font-size: 1.75rem;
	line-height: 1;
	font-weight: 800;
	color: var(--tw-text);
}

.tw-kpi-icon {
	position: absolute;
	top: 1rem;
	right: 1rem;
	width: 38px;
	height: 38px;
	border-radius: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(var(--tw-primary-rgb), 0.1);
	color: var(--tw-primary);
}

.tw-table-wrap {
	padding: 0 1.35rem 1.35rem;
}

.tw-table-card {
	border: 1px solid var(--tw-border);
	border-radius: 20px;
	background: #fff;
	overflow: hidden;
}

.tw-table-topbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	padding: 1rem 1rem 0;
	flex-wrap: wrap;
}

.tw-table-note {
	color: var(--tw-muted);
	font-size: 0.92rem;
}

.tw-data-table {
	margin-bottom: 0 !important;
}

.tw-data-table tbody tr:hover {
	background: #f8fbff;
}

.tw-data-table td {
	vertical-align: middle;
}

.tw-cell-title {
	font-weight: 700;
	color: var(--tw-text);
}

.tw-cell-subtitle {
	display: block;
	color: var(--tw-muted);
	font-size: 0.85rem;
	margin-top: 0.2rem;
}

.tw-badge-soft {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	padding: 0.4rem 0.65rem;
	border-radius: 999px;
	background: rgba(var(--tw-primary-rgb), 0.1);
	color: var(--tw-primary);
	font-weight: 700;
	font-size: 0.78rem;
}

.tw-badge-soft.tw-badge-success {
	background: rgba(47, 179, 68, 0.12);
	color: var(--tw-success);
}

.tw-badge-soft.tw-badge-info {
	background: rgba(var(--tw-primary-rgb), 0.12);
	color: var(--tw-primary);
}

.tw-badge-soft.tw-badge-warning {
	background: rgba(245, 159, 0, 0.14);
	color: var(--tw-warning);
}

.tw-action-group {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	flex-wrap: wrap;
}

.tw-action-group .btn {
	min-width: 38px;
	border-radius: 10px;
}

.tw-empty-state {
	padding: 2rem 1rem;
	text-align: center;
	color: var(--tw-muted);
}

.tw-module-card {
	display: flex;
	flex-direction: column;
	border: 1px solid var(--tw-border);
	border-radius: 22px;
	background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
	padding: 1.15rem;
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.tw-module-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 16px 36px rgba(15, 23, 42, 0.1);
	border-color: rgba(var(--tw-primary-rgb), 0.22);
}

.tw-module-card__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1rem;
}

.tw-module-card__badge {
	display: inline-flex;
	align-items: center;
	padding: 0.4rem 0.7rem;
	border-radius: 999px;
	font-size: 0.76rem;
	font-weight: 700;
	background: rgba(var(--tw-primary-rgb), 0.08);
	color: var(--tw-primary);
}

.tw-module-card__icon {
	width: 52px;
	height: 52px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 18px;
	font-size: 1.3rem;
	background: rgba(var(--tw-primary-rgb), 0.12);
	color: var(--tw-primary);
}

.tw-module-card__body {
	flex: 1 1 auto;
}

.tw-module-card__body h4 {
	margin: 0 0 0.55rem;
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--tw-text);
}

.tw-module-card__body p {
	margin: 0;
	color: var(--tw-muted);
	line-height: 1.55;
}

.tw-module-card__footer {
	margin-top: 1rem;
}

.tw-module-card--success .tw-module-card__badge,
.tw-module-card--success .tw-module-card__icon {
	background: rgba(47, 179, 68, 0.12);
	color: var(--tw-success);
}

.tw-module-card--warning .tw-module-card__badge,
.tw-module-card--warning .tw-module-card__icon {
	background: rgba(245, 159, 0, 0.14);
	color: var(--tw-warning);
}

.tw-module-card--danger .tw-module-card__badge,
.tw-module-card--danger .tw-module-card__icon {
	background: rgba(214, 57, 57, 0.12);
	color: var(--tw-danger);
}

.tw-module-card--dark .tw-module-card__badge,
.tw-module-card--dark .tw-module-card__icon,
.tw-module-card--secondary .tw-module-card__badge,
.tw-module-card--secondary .tw-module-card__icon {
	background: rgba(24, 36, 51, 0.09);
	color: var(--tw-text);
}

.tw-summary-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 1rem;
	margin-bottom: 1rem;
}

.tw-summary-card {
	border: 1px solid var(--tw-border);
	border-radius: 18px;
	background: linear-gradient(180deg, #fff 0%, #f8faff 100%);
	padding: 1rem;
}

.tw-summary-card small {
	display: block;
	color: var(--tw-muted);
	margin-bottom: 0.4rem;
}

.tw-summary-card strong {
	display: block;
	color: var(--tw-text);
	font-size: 1rem;
	line-height: 1.25;
}

.tw-detail-list {
	display: grid;
	gap: 0.75rem;
}

.tw-detail-item {
	padding: 0.85rem 1rem;
	border: 1px solid var(--tw-border);
	border-radius: 16px;
	background: #fff;
	color: var(--tw-text);
}

.tw-detail-item strong {
	display: inline-block;
	min-width: 88px;
}

.tw-action-bar {
	display: flex;
	justify-content: flex-end;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.tw-action-bar .btn {
	min-height: 44px;
	border-radius: 12px;
	font-weight: 700;
}

.tw-inline-note {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.55rem 0.8rem;
	border-radius: 999px;
	font-size: 0.85rem;
	font-weight: 600;
	background: rgba(var(--tw-primary-rgb), 0.08);
	color: var(--tw-primary);
}

.modal-backdrop.show {
	opacity: 0.62;
}

.modal.tw-modal .modal-dialog,
.tw-modal .modal-dialog {
	margin-top: 2rem;
	margin-bottom: 2rem;
}

.modal.tw-modal .modal-content,
.tw-modal .modal-content {
	border: 1px solid rgba(var(--tw-primary-rgb), 0.12);
	border-radius: 26px;
	overflow: hidden;
	box-shadow: 0 26px 70px rgba(15, 23, 42, 0.22);
}

.modal.tw-modal .modal-header,
.tw-modal .modal-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
	padding: 1.25rem 1.35rem;
	background: linear-gradient(135deg, rgba(var(--tw-primary-rgb), 0.96), rgba(14, 116, 144, 0.92));
	color: #fff;
	border-bottom: 0;
}

.modal.tw-modal .modal-title,
.tw-modal .modal-title {
	font-weight: 700;
	font-size: 1.2rem;
	margin: 0;
}

.tw-modal-title-wrap {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.tw-modal-subtitle {
	color: rgba(255,255,255,0.82);
	font-size: 0.92rem;
	margin: 0;
}

.tw-modal-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	width: fit-content;
	padding: 0.42rem 0.7rem;
	border-radius: 999px;
	font-size: 0.76rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	background: rgba(255,255,255,0.14);
	border: 1px solid rgba(255,255,255,0.18);
}

.modal.tw-modal .close,
.tw-modal .close {
	color: #fff;
	text-shadow: none;
	opacity: 1;
	background: rgba(255,255,255,0.12);
	border: 0;
	border-radius: 12px;
	width: 40px;
	height: 40px;
	padding: 0;
}

.modal.tw-modal .modal-body,
.tw-modal .modal-body {
	padding: 1.35rem;
	background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
}

.modal.tw-modal .modal-footer,
.tw-modal .modal-footer {
	padding: 1rem 1.35rem 1.35rem;
	background: #f8faff;
	border-top: 1px solid var(--tw-border);
}

.tw-modal-section {
	border: 1px solid var(--tw-border);
	border-radius: 20px;
	background: #fff;
	padding: 1rem 1rem 0.25rem;
	margin-bottom: 1rem;
}

.tw-modal-section h5,
.tw-modal-section .sub-heading {
	font-weight: 700;
	margin-bottom: 0.25rem;
	color: var(--tw-text);
}

.tw-modal-help {
	color: var(--tw-muted);
	font-size: 0.9rem;
	margin-bottom: 0.9rem;
}

.tw-modal-actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.tw-modal-actions .btn {
	min-height: 44px;
	border-radius: 12px;
	font-weight: 600;
}

.tw-modal-stepbar {
	display: flex;
	gap: 0.65rem;
	flex-wrap: wrap;
	margin-bottom: 1rem;
}

.tw-modal-step {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	padding: 0.55rem 0.8rem;
	border-radius: 999px;
	background: rgba(var(--tw-primary-rgb), 0.08);
	color: var(--tw-primary);
	font-weight: 700;
	font-size: 0.82rem;
}

.tw-modal-step strong {
	width: 22px;
	height: 22px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--tw-primary);
	color: #fff;
	font-size: 0.76rem;
}

.tw-modal-message {
	text-align: center;
	padding: 0.5rem 0.25rem;
}

.tw-modal-message-icon {
	width: 66px;
	height: 66px;
	margin: 0 auto 1rem;
	border-radius: 20px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(47, 179, 68, 0.12);
	color: var(--tw-success);
	font-size: 1.6rem;
}

.tw-form-stack > .form-group,
.tw-form-stack .input-group {
	margin-bottom: 1rem;
}

.tw-table-topbar .btn-success,
.tw-toolbar .btn-success {
	background: var(--tw-success) !important;
	border-color: var(--tw-success) !important;
}

.tw-table-topbar .btn-success:hover,
.tw-toolbar .btn-success:hover {
	filter: brightness(0.95);
}

.dataTables_wrapper .row:first-child {
	margin: 0;
	padding: 0 1rem;
}

.dataTables_wrapper .row:last-child {
	margin: 0;
	padding: 1rem;
}

.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter {
	margin: 0.75rem 0 0;
}

.dataTables_wrapper .dataTables_filter input {
	margin-left: 0.5rem;
	min-height: 40px;
	border: 1px solid var(--tw-border);
	border-radius: 10px;
	padding: 0.5rem 0.75rem;
}

.dataTables_wrapper .dataTables_length select {
	min-height: 40px;
	border: 1px solid var(--tw-border);
	border-radius: 10px;
	padding: 0.35rem 2rem 0.35rem 0.75rem;
}

.dataTables_wrapper .dataTables_info {
	color: var(--tw-muted);
	padding-top: 0.35rem;
}

.dataTables_wrapper .pagination {
	gap: 0.35rem;
}

.login-page {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem 1rem;
}

.tw-login-layout {
	width: min(1120px, 100%);
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	overflow: hidden;
	border-radius: 28px;
	background: rgba(255,255,255,0.92);
	box-shadow: 0 24px 60px rgba(15, 23, 42, 0.18);
}

.tw-login-hero {
	position: relative;
	padding: 3rem;
	min-height: 680px;
	background:
		linear-gradient(150deg, rgba(var(--tw-primary-rgb), 0.92) 0%, rgba(14, 116, 144, 0.9) 100%),
		url('./../../img/IMG_20260112_124841-773x1024.jpg') center/cover no-repeat;
	color: #fff;
}

.tw-login-hero::after {
	content: '';
	position: absolute;
	inset: auto -120px -120px auto;
	width: 320px;
	height: 320px;
	border-radius: 50%;
	background: rgba(255,255,255,0.08);
}

.tw-login-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.55rem 0.85rem;
	border-radius: 999px;
	background: rgba(255,255,255,0.14);
	border: 1px solid rgba(255,255,255,0.16);
	margin-bottom: 1.25rem;
}

.tw-login-hero h1 {
	font-size: clamp(2rem, 4vw, 3.6rem);
	line-height: 1.05;
	margin: 0 0 1rem;
	font-weight: 800;
}

.tw-login-hero p {
	max-width: 520px;
	color: rgba(255,255,255,0.85);
	font-size: 1.02rem;
}

.tw-login-list {
	list-style: none;
	padding: 0;
	margin: 2rem 0 0;
}

.tw-login-list li {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 0.85rem;
}

.tw-login-card {
	padding: 3rem 2.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
}

.tw-login-panel {
	width: min(420px, 100%);
}

.tw-login-logo {
	display: block;
	margin: 0 auto 1.5rem;
	max-width: 290px;
	width: 100%;
	height: auto;
}

.tw-login-title {
	text-align: center;
	font-size: 1.8rem;
	font-weight: 700;
	margin-bottom: 0.35rem;
}

.tw-login-subtitle {
	text-align: center;
	color: var(--tw-muted);
	margin-bottom: 1.75rem;
}

.tw-form-field {
	margin-bottom: 1rem;
}

.tw-form-field .input-group-text {
	border-radius: 12px;
	border-color: var(--tw-border);
	background: #fff;
}

.tw-form-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 1.25rem;
}

.tw-btn-block {
	min-height: 46px;
	border-radius: 12px;
	font-weight: 600;
}

.modal-bienvenida .modal-header {
	background: var(--tw-primary);
}

@media (max-width: 991.98px) {
	.tw-kpi-grid {
		grid-template-columns: 1fr;
	}

	.tw-summary-grid {
		grid-template-columns: 1fr;
	}

	.tw-login-layout {
		grid-template-columns: 1fr;
	}

	.tw-login-hero {
		min-height: auto;
		padding: 2rem;
	}

	.tw-section-header,
	.tw-table-topbar {
		flex-direction: column;
		align-items: stretch;
	}

	.tw-search-shell,
	.tw-profile-grid {
		grid-template-columns: 1fr;
	}

	.tw-search-form {
		grid-template-columns: 1fr;
	}

	.tw-toolbar.tw-toolbar-stretch .btn {
		min-width: 100%;
	}

	.content-header {
		padding: 1rem 1rem 0.5rem;
	}
}

@media (max-width: 767.98px) {
	.main-header.navbar {
		padding: 0.75rem;
	}

	.tw-navbar-user .tw-user-meta {
		display: none;
	}

	.tw-login-card {
		padding: 2rem 1.25rem;
	}

	.tw-form-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.tw-modal-actions {
		justify-content: stretch;
	}
}