@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Poppins:wght@500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700;900&display=swap');

/* Global design tokens and legacy overrides - cache-bust 20260616 academic-forensic-v10 */
:root {
    --aimexe-font-body: 'Inter', sans-serif;
    --aimexe-font-heading: 'Poppins', sans-serif;
    --aimexe-brand-default: #03024d;
    --aimexe-primary: var(--theme-color, var(--aimexe-brand-default));
    --aimexe-on-primary: #ffffff;
    --aimexe-primary-dark: #03024d;
    --aimexe-highlight: #03024d;
    --aimexe-surface: #ffffff;
    --aimexe-surface-soft: #f8fbff;
    --aimexe-surface-alt: #f5f6f8;
    --aimexe-border-color: #e2e8f0;
    --aimexe-border-strong: #d7e0ec;
    --aimexe-border-muted: #e8eef6;
    --aimexe-border-accent: #c8d6ea;
    --aimexe-text-primary: #03024d;
    --aimexe-text-secondary: #5d7090;
    --aimexe-text-muted: #5d7090b5;
    --aimexe-text-strong: #03024d;
    --aimexe-section-text: #8396b4;
    --aimexe-focus-border: #9fb4d3;
    --aimexe-focus-ring: rgba(3, 2, 77, 0.12);
    --aimexe-accent: #2f5ea8;
    --aimexe-sidebar-icon: #2f4f83;
    --aimexe-sidebar-arrow: #6d84a8;
    --aimexe-hover-soft: rgba(3, 2, 77, 0.06);
    --aimexe-shadow-soft: 0 var(--aimexe-space-1, 4px) var(--aimexe-space-2, 8px) rgba(18, 42, 73, 0.04);
    --aimexe-card-shadow: 0 8px 20px rgba(18, 42, 73, 0.06);
    --aimexe-overlay-shadow: 2px 2px 6px rgba(0, 0, 0, 0.3);
    --aimexe-table-border: #e8edf4;
    --aimexe-table-striped: #f8fbff;
    --aimexe-table-hover: #eef4ff;
    --aimexe-table-head-bg: #f6f9ff;
    --aimexe-social-facebook: #3b5998;
    --aimexe-social-x: #1da1f2;
    --aimexe-social-linkedin: #0077b5;
    --aimexe-social-whatsapp: #25d366;
    --aimexe-gradient-start: #667eea;
    --aimexe-gradient-end: #764ba2;
    --aimexe-success: #16a36a;
    --aimexe-neutral: #6c757d;
    --aimexe-danger: #ff0000;
    --aimexe-light-gray: #e2e8f0;
    --aimexe-soft-yellow: #03024d;
    --aimexe-brand-deep: rgb(3, 2, 77);
}

/* Typography hard override over legacy style.min.css */
body,
button,
input,
select,
textarea,
.nav-link,
.menu-title,
.card,
.table,
.btn,
.form-control,
.custom-select,
.dropdown-item {
    font-family: var(--aimexe-font-body) !important;
}

body *:not(i):not(.fa):not(.fas):not(.far):not(.fab):not([class^='mdi']):not([class*=' mdi']) {
    font-family: var(--aimexe-font-body) !important;
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
    font-family: var(--aimexe-font-heading) !important;
}

.card .card-title,
.card .card-subtitle,
.card .card-description,
.badge,
.sidebar .nav .nav-item .nav-link .menu-title,
.navbar .navbar-menu-wrapper .navbar-nav .nav-item .nav-link {
    font-family: var(--aimexe-font-body) !important;
}

/* Button consistency */
.btn,
.main-panel .content-wrapper form .btn,
.main-panel .content-wrapper .modal .btn,
.navbar.default-layout-navbar .cache-clear .btn {
    background-color: var(--aimexe-primary) !important;
    border-color: var(--aimexe-primary) !important;
    color: var(--aimexe-on-primary) !important;
}

/* Table system override over style.min.css */
.main-panel .table,
.main-panel .jsgrid .jsgrid-table,
.main-panel .table th,
.main-panel .table td,
.main-panel .jsgrid .jsgrid-table th,
.main-panel .jsgrid .jsgrid-table td {
    color: var(--aimexe-text-primary) !important;
    border-color: var(--aimexe-table-border) !important;
}

.main-panel .table thead th,
.main-panel .jsgrid .jsgrid-table thead th {
    background: var(--aimexe-table-head-bg) !important;
    color: var(--aimexe-text-secondary) !important;
    border-bottom: 1px solid var(--aimexe-table-border) !important;
}

.main-panel .table-striped tbody tr:nth-of-type(odd) {
    background-color: var(--aimexe-table-striped) !important;
}

.main-panel .table-hover tbody tr:hover {
    background-color: var(--aimexe-table-hover) !important;
    color: var(--aimexe-text-primary) !important;
}

.remove-elective-subject {
    position: absolute;
    right: 20px;
    margin-top: 3px;
}

#external-events {
    z-index: 2;
    width: 150px;
    padding: 0 10px;
    border: 1px solid var(--aimexe-border-color);
    background: var(--aimexe-surface-soft);
}

#external-events .fc-event {
    cursor: move;
    margin: 3px 0;
    height: 45px;
    display: flex;
    align-items: center;
    padding-left: 10px;
}

.fc-customButton-button {
    font-size: 13px !important;
    position: absolute;
    top: 60px;
    left: 50%;
    transform: translateY(-50%);
}


.form-group {
    margin-bottom: 1rem;
}

.form-group > label {
    margin-bottom: 10px;
}

#delete-modal .modal-footer > .btn {

    border-radius: 3px !important;
    padding: 0 8px !important;
    font-size: 15px;
}

.fc-scroller {
    overflow-y: hidden !important;
}

.context-menu {
    position: absolute;
    z-index: 1000;
    background-color: var(--aimexe-surface);
    border: 1px solid var(--aimexe-border-color);
    border-radius: 4px;
    box-shadow: var(--aimexe-overlay-shadow);
    padding: 5px;
}

.context-menu ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.context-menu ul > li {
    display: block;;
    padding: 5px 15px;
    list-style-type: none;
    color: var(--aimexe-text-primary);
    cursor: pointer;
    margin: 0 auto;
    transition: 0.10s;
    font-size: 13px;
}

.context-menu ul > li:hover {
    color: var(--aimexe-on-primary);
    background-color: var(--aimexe-primary);
    border-radius: 2px;
}

/*.fa, .fas {*/
/*    font-size: 13px;*/
/*    margin-right: 4px;*/
/*}*/

.no-header-toolbar .fc-header-toolbar.fc-toolbar {
    margin-top: 0;
    margin-bottom: 0;
}

.fc-h-event {
    border: none;
}

.remove-timetable {
    padding: 2px 3px;
}

.remove-timetable:hover {
    background: var(--aimexe-surface);
    color: var(--aimexe-text-primary);
    border-radius: 10px;
}

label.filter-menu {
    font-size: 13px;
    color: var(--aimexe-text-secondary);
    font-weight: 500;
    position: absolute;
    top: -8px;
    /*left: 27px;*/
    /*left: 1%;*/
    background: var(--aimexe-surface);
    /*margin-bottom: 0;*/
    margin-left: 5px;
    padding: 0 5px;
    z-index: 99;
    border-radius: 20px;
}

/*.select2-container--default.select2-container--focus .select2-selection--multiple {*/
/*    height: 45px;*/
/*}*/

/*.select2-container .select2-selection--multiple {*/
/*    min-height: 45px;*/
/*}*/

.w-fit-content {
    width: fit-content;
}

.select2-container--default .select2-selection--single {
    padding: 0.94rem 0.6rem !important;
}

.select2-container--default .select2-selection--multiple {
    padding: 0.34rem 0.6rem !important;
}

.select2-search__field::placeholder {
    color: var(--aimexe-text-primary);
    font-size: 0.8125rem;
}

.asColorPicker-alpha {
    display: none;
}

.remove-number-increment::-webkit-inner-spin-button,
.remove-number-increment::-webkit-outer-spin-button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0;
}

.total_paidable_amount {
    background-color: var(--aimexe-light-gray);
}
.dashboard-description {
    font-size: 13px;
}
.v-scroll {
    height: 385px;
    overflow-y: scroll;
}
.custom-card-body {
    padding: 1.25rem !important;
}
.image-tile img {
    height: 200px;
    object-fit: cover;
}
.text-wrap div {
    white-space: normal !important;
}

.package-type-badge {
    position: absolute;
    left: auto;
    right: -10px;
    clip-path: polygon(50% 0%,100% 0%,100% 100%,0% 100%,14% 52%,0% 0%);
    width: 130px;
    height: 38px;
    top: 8px;
    color: var(--aimexe-on-primary) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}
.package-type-badge{
    right: -2px;
}

.postpaid-color {
    background: var(--primary-color);
}
.prepaid-color {
    background: var(--secondary-color);
}

.addon-border-primary {
    overflow: hidden;
}
.addon-ribbon {
    font: bold 15px sans-serif;
    color: var(--aimexe-text-primary);
    text-align: center;
    -webkit-transform: rotate(-45deg);
    -moz-transform:    rotate(-45deg);
    -ms-transform:     rotate(-45deg);
    -o-transform:      rotate(-45deg);
    position: absolute;
    padding: 7px 0;
    top: 15px;
    left: -30px;
    width: 120px;
    background-color: var(--aimexe-danger);
    color: var(--aimexe-on-primary);
}
.sidebar .nav .nav-item .nav-link i.menu-icon {
    margin-left: 5px !important;
    width: 30px;
}
.sidebar .nav .nav-item {
    padding: 0 1.25rem !important;
}
@media (min-width: 992px) {
    .sidebar-icon-only .sidebar .nav .nav-item {
        position: relative;
        padding: 0 !important;
    }
}
.sidebar .nav .nav-item .nav-link i.menu-arrow {
    font-size: 1.5rem !important;
}

.aimexe-sidebar {
    --aimexe-space-1: 4px;
    --aimexe-space-2: 8px;
    --aimexe-space-3: 12px;
    --aimexe-space-4: 16px;
    --aimexe-space-5: 20px;
    --aimexe-space-6: 24px;
    --aimexe-size-item-h: 40px;
    --aimexe-size-sub-item-h: 36px;
    --aimexe-size-icon: 16px;
    --aimexe-size-indicator-w: 4px;
    --aimexe-font-section: 12px;
    --aimexe-font-menu: 14px;
    --aimexe-font-submenu: 14px;
    --aimexe-sidebar-border: var(--aimexe-border-color);
    --aimexe-item-border: var(--aimexe-border-color);
    --aimexe-item-border-hover: var(--aimexe-border-muted);
    --aimexe-item-border-active: var(--aimexe-border-accent);
    --aimexe-item-bg: var(--aimexe-surface);
    --aimexe-item-bg-hover: var(--aimexe-surface-soft);
    --aimexe-item-bg-active: var(--aimexe-table-hover);
    --aimexe-item-text: var(--aimexe-text-primary);
    --aimexe-sub-text: var(--aimexe-text-secondary);
    --aimexe-sub-text-hover: var(--aimexe-text-primary);
    --aimexe-sub-text-active: var(--aimexe-primary-dark);
    --aimexe-section-text: var(--aimexe-section-text);
    --aimexe-accent: var(--aimexe-accent);
    background: linear-gradient(180deg, var(--aimexe-surface) 0%, var(--aimexe-surface-soft) 100%);
    border-right: 1px solid var(--aimexe-sidebar-border);
}

.aimexe-sidebar .sidebar-search .form-control {
    border: 1px solid var(--aimexe-border-muted);
    border-radius: var(--aimexe-space-2);
    background: var(--aimexe-surface);
    box-shadow: none;
}

.aimexe-sidebar .nav .nav-item {
    padding: 0 var(--aimexe-space-4) !important;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item:not(.aimexe-nav-section) {
    margin-bottom: var(--aimexe-space-1);
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item:not(.aimexe-nav-section) > .nav-link,
.aimexe-sidebar .aimexe-module-card > .nav-link {
    display: flex;
    align-items: center;
    min-height: var(--aimexe-size-item-h);
    padding: var(--aimexe-space-2) var(--aimexe-space-3);
    border: 1px solid var(--aimexe-item-border);
    border-radius: var(--aimexe-space-2);
    background: var(--aimexe-item-bg);
    box-shadow: var(--aimexe-shadow-soft);
    transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, transform 0.22s ease;
    position: relative;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item:not(.aimexe-nav-section) > .nav-link::before,
.aimexe-sidebar .aimexe-module-card > .nav-link::before {
    content: "";
    position: absolute;
    left: 0;
    top: var(--aimexe-space-2);
    bottom: var(--aimexe-space-2);
    width: var(--aimexe-size-indicator-w);
    border-radius: 999px;
    background: transparent;
    transition: background-color 0.2s ease;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item:not(.aimexe-nav-section) > .nav-link .menu-title,
.aimexe-sidebar .aimexe-module-card > .nav-link .menu-title {
    color: var(--aimexe-item-text);
    font-weight: 500;
    font-size: var(--aimexe-font-menu);
    line-height: 1.25;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item:not(.aimexe-nav-section) > .nav-link:hover,
.aimexe-sidebar .aimexe-module-card > .nav-link:hover {
    border-color: var(--aimexe-item-border-hover);
    background: var(--aimexe-item-bg-hover);
    transform: translateX(var(--aimexe-space-1));
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item:not(.aimexe-nav-section) > .nav-link.active,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item:not(.aimexe-nav-section) > .nav-link[aria-expanded="true"],
.aimexe-sidebar .aimexe-module-card > .nav-link.active,
.aimexe-sidebar .aimexe-module-card > .nav-link[aria-expanded="true"] {
    border-color: var(--aimexe-border-accent);
    background: var(--aimexe-item-bg-active);
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item:not(.aimexe-nav-section) > .nav-link.active .menu-title,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item:not(.aimexe-nav-section) > .nav-link[aria-expanded="true"] .menu-title,
.aimexe-sidebar .aimexe-module-card > .nav-link.active .menu-title,
.aimexe-sidebar .aimexe-module-card > .nav-link[aria-expanded="true"] .menu-title {
    color: #ffffff;
    font-weight: 600;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item:not(.aimexe-nav-section) > .nav-link.active::before,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item:not(.aimexe-nav-section) > .nav-link[aria-expanded="true"]::before,
.aimexe-sidebar .aimexe-module-card > .nav-link.active::before,
.aimexe-sidebar .aimexe-module-card > .nav-link[aria-expanded="true"]::before {
    background: var(--aimexe-accent);
}

.aimexe-sidebar .nav .nav-item .nav-link i.menu-icon {
    width: var(--aimexe-size-icon);
    margin-left: 0 !important;
    margin-right: var(--aimexe-space-2);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--aimexe-sidebar-icon);
    font-size: var(--aimexe-size-icon) !important;
    line-height: 1;
}

.aimexe-sidebar .nav .nav-item .nav-link i.menu-icon.fa {
    font-weight: normal;
}

.aimexe-sidebar .nav .nav-item .nav-link i.menu-arrow {
    font-size: var(--aimexe-size-icon) !important;
    color: var(--aimexe-sidebar-arrow);
}

.aimexe-sidebar .aimexe-nav-section {
    margin-top: var(--aimexe-space-3);
    margin-bottom: var(--aimexe-space-1);
    padding-top: var(--aimexe-space-1) !important;
    padding-bottom: var(--aimexe-space-1) !important;
}

.aimexe-sidebar .aimexe-nav-section .nav-link {
    pointer-events: none;
    cursor: default;
    border: 0;
    min-height: auto;
    padding: var(--aimexe-space-1) var(--aimexe-space-2);
    background: transparent;
    box-shadow: none;
}

.aimexe-sidebar .aimexe-nav-section .menu-title {
    font-size: var(--aimexe-font-section);
    font-weight: 500;
    letter-spacing: 0.09em;
    color: var(--aimexe-section-text);
    text-transform: uppercase;
}

.aimexe-sidebar .aimexe-module-card {
    margin-bottom: var(--aimexe-space-1);
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu {
    margin-top: var(--aimexe-space-1);
    margin-bottom: var(--aimexe-space-2);
    padding-left: var(--aimexe-space-2);
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link {
    min-height: var(--aimexe-size-sub-item-h);
    padding: var(--aimexe-space-2) var(--aimexe-space-3);
    border-radius: var(--aimexe-space-2);
    color: var(--aimexe-sub-text);
    font-weight: 500;
    font-size: var(--aimexe-font-submenu);
    line-height: 1.25;
    transition: color 0.18s ease, background-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link:hover {
    color: var(--aimexe-sub-text-hover);
    background: var(--aimexe-surface-soft);
    transform: translateX(var(--aimexe-space-1));
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link.active {
    color: #ffffff;
    background: #03024d;
    font-weight: 600;
    box-shadow: inset 2px 0 0 #03024d;
}

.aimexe-sidebar .nav .nav-item .collapse,
.aimexe-sidebar .nav .nav-item .collapsing {
    transition: height 0.22s ease !important;
}

.aimexe-sidebar .nav .nav-item .collapse .sub-menu {
    opacity: 0;
    transform: translateY(calc(var(--aimexe-space-1) * -1));
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.aimexe-sidebar .nav .nav-item .collapse.show .sub-menu {
    opacity: 1;
    transform: translateY(0);
}

/* Sidebar groups: flat SaaS-style hierarchy */
.aimexe-sidebar {
    font-family: "Roboto", sans-serif;
    background: #f7f8fa;
}

.aimexe-sidebar .sidebar-search .form-control {
    background: #ffffff;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item {
    margin-bottom: 6px;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link,
.aimexe-sidebar .aimexe-module-card > .nav-link,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link {
    border: 0 !important;
    border-radius: 8px !important;
    background: transparent !important;
    box-shadow: none !important;
    transform: none !important;
    position: relative;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link,
.aimexe-sidebar .aimexe-module-card > .nav-link {
    min-height: 38px;
    padding: 8px 12px 8px 16px;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link::before,
.aimexe-sidebar .aimexe-module-card > .nav-link::before,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link::before {
    content: "";
    position: absolute;
    left: 0;
    top: 6px;
    bottom: 6px;
    width: 3px;
    border-radius: 999px;
    background: transparent;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link:hover,
.aimexe-sidebar .aimexe-module-card > .nav-link:hover,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link:hover {
    background: #eef2f6 !important;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link.active,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link[aria-expanded="true"],
.aimexe-sidebar .aimexe-module-card > .nav-link.active,
.aimexe-sidebar .aimexe-module-card > .nav-link[aria-expanded="true"],
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link.active,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link[aria-expanded="true"] {
    background: #03024d !important;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link.active::before,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link[aria-expanded="true"]::before,
.aimexe-sidebar .aimexe-module-card > .nav-link.active::before,
.aimexe-sidebar .aimexe-module-card > .nav-link[aria-expanded="true"]::before,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link.active::before,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link[aria-expanded="true"]::before {
    background: #03024d;
}

.aimexe-sidebar .nav .nav-item .nav-link .menu-title {
    font-size: 13px;
    font-weight: 500;
    line-height: 1.3;
    color: #1f2937;
    text-transform: uppercase;
}

.aimexe-sidebar .nav .nav-item .nav-link {
    text-transform: uppercase;
}

.aimexe-sidebar .nav .nav-item .nav-link.active .menu-title,
.aimexe-sidebar .nav .nav-item .nav-link[aria-expanded="true"] .menu-title {
    font-weight: 700;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link.active,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link[aria-expanded="true"] {
    color: #ffffff !important;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link.active .menu-title,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link[aria-expanded="true"] .menu-title {
    color: #ffffff !important;
    font-weight: 600 !important;
}

.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link.active i.menu-icon,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link[aria-expanded="true"] i.menu-icon,
.aimexe-sidebar .aimexe-module-card > .nav-link.active i.menu-icon,
.aimexe-sidebar .aimexe-module-card > .nav-link[aria-expanded="true"] i.menu-icon,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link.active i.menu-arrow,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item > .nav-link[aria-expanded="true"] i.menu-arrow,
.aimexe-sidebar .aimexe-module-card > .nav-link.active i.menu-arrow,
.aimexe-sidebar .aimexe-module-card > .nav-link[aria-expanded="true"] i.menu-arrow,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link.active i.menu-icon,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link[aria-expanded="true"] i.menu-icon,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link.active i.menu-arrow,
.aimexe-sidebar .nav.aimexe-nav-shell > .nav-item .sub-menu .nav-link[aria-expanded="true"] i.menu-arrow {
    color: #ffffff !important;
}

.aimexe-sidebar .nav .nav-item .nav-link i.menu-icon {
    width: 18px;
    margin-right: 10px;
    color: #4b5563;
    font-size: 14px !important;
}

.aimexe-sidebar .nav .nav-item .nav-link i.menu-arrow {
    font-size: 13px !important;
    color: #94a3b8;
}

.aimexe-sidebar .aimexe-group-item {
    margin-bottom: 6px;
    border-top: 0;
    padding-top: 0 !important;
}

.aimexe-sidebar .aimexe-group-item > .nav-link {
    min-height: 36px;
    padding: 8px 12px 8px 16px;
}

.aimexe-sidebar .aimexe-group-item > .nav-link .menu-title {
    font-size: 13.5px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #0f172a;
}

.aimexe-sidebar .aimexe-group-submenu {
    margin-top: 4px;
    margin-bottom: 10px;
    padding-left: 14px !important;
}

.aimexe-sidebar .aimexe-group-submenu > .nav-item {
    margin-bottom: 5px;
}

.aimexe-sidebar .aimexe-group-submenu > .nav-item > .nav-link {
    min-height: 34px;
    padding: 6px 12px 6px 18px;
}

.aimexe-sidebar .aimexe-group-submenu > .nav-item > .nav-link .menu-title {
    font-size: 12.75px !important;
    font-weight: 500 !important;
    text-transform: none !important;
}

.aimexe-sidebar .aimexe-group-submenu > .nav-item > .collapse .sub-menu .nav-link {
    padding-left: 30px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    text-transform: none !important;
}

.aimexe-sidebar .aimexe-group-submenu > .nav-item > .nav-link,
.aimexe-sidebar .aimexe-group-submenu > .nav-item > .collapse .sub-menu .nav-link {
    text-transform: none !important;
}

.aimexe-admin-layout .btn-warning,
.aimexe-admin-layout .badge-warning,
.aimexe-admin-layout .bg-warning,
.aimexe-admin-layout .text-warning,
.aimexe-admin-layout .border-warning,
.aimexe-admin-layout .btn-inverse-warning,
.aimexe-admin-layout .alert-warning {
    background-color: #03024d !important;
    border-color: #03024d !important;
    color: #ffffff !important;
}

.aimexe-admin-layout .btn-warning:hover,
.aimexe-admin-layout .btn-inverse-warning:hover {
    background-color: #02013f !important;
    border-color: #02013f !important;
    color: #ffffff !important;
}

.student-id-card-demo {
    position: fixed;
    width: -webkit-fill-available;
    margin-right: 20px;
}

.action-column-dropdown-menu {
    left: -2rem !important;
}
.action-column-menu {

    /* position: absolute; */
    /* transform: translate(-50%, -50%); */

    /* position: absolute;
    transform: translate(-50%, -50%);
    white-space: nowrap;
    z-index: 1000; */

    /* top: 50%;
    left: 50%; */
}

.action-td-cell {
    /* position: absolute; */
    /* border: 0px !important; */
    /* top: 40px; */
}

/* AIMEXE Design Tokens - Layout spacing */
:root {
    --aimexe-space-1: 4px;
    --aimexe-space-2: 8px;
    --aimexe-space-3: 12px;
    --aimexe-space-4: 16px;
    --aimexe-space-5: 20px;
    --aimexe-space-6: 24px;
    --aimexe-space-7: 28px;
    --aimexe-space-8: 32px;
    --aimexe-radius-sm: 8px;
    --aimexe-radius-md: 12px;
    --aimexe-topbar-height: 72px;
    --aimexe-card-padding: 24px;
    --aimexe-field-height: 44px;
    --aimexe-btn-height: 40px;
    --aimexe-font-label: 12px;
    --aimexe-font-field: 14px;
}

/* Phase 1 - Header / Topbar */
.navbar.default-layout-navbar {
    border-bottom: 1px solid var(--aimexe-border-color);
}

.navbar.fixed-top + .page-body-wrapper {
    padding-top: var(--aimexe-topbar-height);
}

@media (min-width: 992px) {
    .sidebar-fixed .sidebar {
        top: var(--aimexe-topbar-height);
        height: calc(100vh - var(--aimexe-topbar-height));
    }

    .sidebar-fixed .sidebar .nav {
        max-height: calc(100vh - var(--aimexe-topbar-height)) !important;
    }
}

.page-body-wrapper,
.main-panel {
    min-height: calc(100vh - var(--aimexe-topbar-height));
}

.navbar.default-layout-navbar .navbar-brand-wrapper,
.navbar.default-layout-navbar .navbar-menu-wrapper {
    height: var(--aimexe-topbar-height);
}

.navbar.default-layout-navbar .navbar-brand-wrapper .navbar-brand {
    align-items: center;
    justify-content: center;
}

.navbar.default-layout-navbar .navbar-brand-wrapper .navbar-brand.brand-logo {
    display: flex;
}

.navbar.default-layout-navbar .navbar-brand-wrapper .navbar-brand.brand-logo-mini {
    display: none;
}

.navbar.default-layout-navbar .navbar-brand-wrapper .navbar-brand img {
    width: auto !important;
    height: auto !important;
    max-width: 185px !important;
    max-height: 48px !important;
    object-fit: contain;
}

.navbar.default-layout-navbar .navbar-brand-wrapper .navbar-brand.brand-logo-mini img {
    width: auto !important;
    height: auto !important;
    max-width: 34px !important;
    max-height: 34px !important;
    object-fit: contain;
}

@media (min-width: 992px) {
    .sidebar-icon-only .navbar.default-layout-navbar .navbar-brand-wrapper .navbar-brand.brand-logo {
        display: none;
    }

    .sidebar-icon-only .navbar.default-layout-navbar .navbar-brand-wrapper .navbar-brand.brand-logo-mini {
        display: flex;
    }
}

.navbar.default-layout-navbar .navbar-menu-wrapper {
    padding-left: var(--aimexe-space-4);
    padding-right: var(--aimexe-space-4);
}

.navbar.default-layout-navbar .navbar-menu-wrapper .navbar-toggler {
    height: var(--aimexe-topbar-height);
    padding-left: var(--aimexe-space-2);
    padding-right: var(--aimexe-space-4);
}

.navbar.default-layout-navbar .navbar-menu-wrapper .navbar-nav .nav-item .nav-link {
    height: var(--aimexe-topbar-height);
    margin-left: var(--aimexe-space-3);
    margin-right: var(--aimexe-space-3);
}

.navbar.default-layout-navbar .cache-clear {
    margin: 0 var(--aimexe-space-2) !important;
    display: flex;
    align-items: center;
}

.navbar.default-layout-navbar .cache-clear .btn {
    min-height: 32px;
    padding: 0 var(--aimexe-space-3) !important;
    border-radius: var(--aimexe-space-2);
    font-size: 12px;
}

.navbar.default-layout-navbar .call-support-text {
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    font-size: 12px;
    line-height: 16px;
    color: var(--aimexe-text-secondary);
}

/* Phase 2 - Cards / Dashboard Widgets */
.main-panel .content-wrapper .grid-margin {
    margin-bottom: var(--aimexe-space-6);
}

.main-panel .content-wrapper .col-md-2-4 {
    padding-left: var(--aimexe-space-2);
    padding-right: var(--aimexe-space-2);
}

.main-panel .content-wrapper .card:not(.border-0) {
    border: 1px solid var(--aimexe-border-color);
    border-radius: var(--aimexe-radius-md);
    box-shadow: var(--aimexe-card-shadow);
    background: var(--aimexe-surface);
}

.main-panel .content-wrapper .card:not(.border-0) .card-body {
    padding: var(--aimexe-card-padding);
}

.main-panel .content-wrapper .card:not(.border-0) .card-header,
.main-panel .content-wrapper .card:not(.border-0) .card-footer {
    padding: var(--aimexe-space-4) var(--aimexe-card-padding);
    background: var(--aimexe-surface-soft);
}

.main-panel .content-wrapper .aimexe-kpi-card {
    background-color: var(--aimexe-soft-yellow);
    border-radius: var(--aimexe-radius-md);
    padding: var(--aimexe-space-6) var(--aimexe-space-5);
    position: relative;
    overflow: visible;
    min-height: 104px;
    box-shadow: var(--aimexe-card-shadow);
}

.main-panel .content-wrapper .aimexe-kpi-content {
    flex: 1;
}

.main-panel .content-wrapper .aimexe-kpi-title {
    margin-bottom: var(--aimexe-space-2);
    font-size: 16px;
    font-weight: 600;
    line-height: 24px;
    color: var(--aimexe-text-strong);
}

.main-panel .content-wrapper .aimexe-kpi-value {
    margin: 0;
    font-size: 24px;
    font-weight: 700;
    line-height: 28px;
    color: var(--aimexe-text-strong);
}

.main-panel .content-wrapper .aimexe-kpi-art {
    position: relative;
    width: 88px;
    height: 88px;
}

.main-panel .content-wrapper .aimexe-kpi-image {
    position: absolute;
    right: -28px;
    top: -24px;
    height: 120px;
}

/* Phase 3 - Forms (Inputs / Buttons / Labels) */
.main-panel .content-wrapper .form-group {
    margin-bottom: var(--aimexe-space-4);
}

.main-panel .content-wrapper .form-group > label,
.main-panel .content-wrapper label:not(.form-check-label):not(.custom-file-label):not(.filter-menu) {
    margin-bottom: var(--aimexe-space-2);
    font-size: var(--aimexe-font-label);
    font-weight: 500;
    letter-spacing: 0.02em;
    line-height: 16px;
    color: var(--aimexe-text-secondary);
}

.main-panel .content-wrapper .form-control,
.main-panel .content-wrapper .custom-select {
    height: var(--aimexe-field-height);
    min-height: var(--aimexe-field-height);
    padding: 0 var(--aimexe-space-3);
    border-radius: var(--aimexe-space-2);
    border: 1px solid var(--aimexe-border-strong);
    font-size: var(--aimexe-font-field);
    line-height: 20px;
    color: var(--aimexe-text-primary);
    box-shadow: none;
}

.main-panel .content-wrapper textarea.form-control {
    height: auto;
    min-height: 88px;
    padding-top: var(--aimexe-space-2);
    padding-bottom: var(--aimexe-space-2);
}

.main-panel .content-wrapper .form-control:focus,
.main-panel .content-wrapper .custom-select:focus {
    border-color: var(--aimexe-focus-border);
    box-shadow: 0 0 0 var(--aimexe-space-1) var(--aimexe-focus-ring);
}

.main-panel .content-wrapper .select2-container--default .select2-selection--single {
    height: var(--aimexe-field-height);
    min-height: var(--aimexe-field-height);
    padding: 0 var(--aimexe-space-3) !important;
    border-radius: var(--aimexe-space-2);
    border: 1px solid var(--aimexe-border-strong);
    display: flex;
    align-items: center;
}

.main-panel .content-wrapper .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: calc(var(--aimexe-field-height) - 2px);
    padding-left: 0;
}

.main-panel .content-wrapper .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: var(--aimexe-field-height);
}

.main-panel .content-wrapper .select2-container--default .select2-selection--multiple {
    min-height: var(--aimexe-field-height);
    padding: var(--aimexe-space-1) var(--aimexe-space-3) !important;
    border-radius: var(--aimexe-space-2);
    border: 1px solid var(--aimexe-border-strong);
}

.main-panel .content-wrapper form .btn,
.main-panel .content-wrapper .modal .btn {
    min-height: var(--aimexe-btn-height);
    padding: 0 var(--aimexe-space-4);
    border-radius: var(--aimexe-space-2);
    font-size: var(--aimexe-font-field);
    font-weight: 500;
    line-height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--aimexe-space-2);
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.main-panel .content-wrapper form .btn:hover,
.main-panel .content-wrapper .modal .btn:hover {
    transform: translateY(-1px);
}

.main-panel .content-wrapper .btn.btn-sm,
.navbar.default-layout-navbar .btn.btn-sm {
    min-height: 32px;
    padding: 0 var(--aimexe-space-3);
    font-size: 12px;
    line-height: 16px;
}

@media (max-width: 991px) {
    .sidebar-offcanvas {
        top: 64px;
        max-height: calc(100vh - 64px);
    }

    .navbar.fixed-top + .page-body-wrapper {
        padding-top: 64px;
    }

    .page-body-wrapper,
    .main-panel {
        min-height: calc(100vh - 64px);
    }

    .navbar.default-layout-navbar .navbar-menu-wrapper {
        height: 64px;
        padding-left: 0;
        padding-right: var(--aimexe-space-3);
    }

    .navbar.default-layout-navbar .navbar-brand-wrapper {
        height: 64px;
    }

    .navbar.default-layout-navbar .navbar-menu-wrapper .navbar-toggler {
        height: 64px;
    }
}

/* Dashboard SaaS refresh */
.navbar.default-layout-navbar.aimexe-saas-header {
    background: linear-gradient(90deg, #e8decb 0%, #d9e5f2 100%) !important;
    border-bottom: 1px solid rgba(19, 32, 71, 0.12) !important;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.10);
}

.navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper,
.navbar.default-layout-navbar.aimexe-saas-header .navbar-menu-wrapper {
    background: transparent !important;
}

.navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper {
    background: rgba(255, 255, 255, 0.42) !important;
    border-right: 1px solid rgba(19, 32, 71, 0.12) !important;
    padding: 0 16px;
    justify-content: flex-start;
}

body .navbar.default-layout-navbar.aimexe-saas-header *:not(i):not(.fa):not(.fas):not(.far):not(.fab):not([class^='mdi']):not([class*=' mdi']) {
    font-family: 'Roboto', sans-serif !important;
}

.navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper .navbar-brand.brand-logo {
    display: flex;
    align-items: center;
    height: var(--aimexe-topbar-height);
    margin: 0;
    padding: 0 !important;
    background: transparent !important;
    min-width: 0;
}

.navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper .navbar-brand.brand-logo .header-logo-variant {
    display: none;
}

.navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper .navbar-brand.brand-logo .header-logo-dark-bg {
    display: block;
}

.navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper .navbar-brand.brand-logo img {
    width: auto !important;
    height: 52px !important;
    max-width: 240px !important;
    max-height: 52px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    object-fit: contain;
    filter: none !important;
}

.navbar.default-layout-navbar.aimexe-saas-header[data-navbar-theme='dark'] .navbar-brand-wrapper .navbar-brand.brand-logo .header-logo-dark-bg {
    display: block;
}

.navbar.default-layout-navbar.aimexe-saas-header[data-navbar-theme='light'] .navbar-brand-wrapper .navbar-brand.brand-logo .header-logo-dark-bg {
    display: none;
}

.navbar.default-layout-navbar.aimexe-saas-header[data-navbar-theme='light'] .navbar-brand-wrapper .navbar-brand.brand-logo .header-logo-light-bg {
    display: block;
}

.navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper .navbar-brand.brand-logo-mini {
    display: none !important;
}

.navbar.default-layout-navbar.aimexe-saas-header .navbar-menu-wrapper {
    display: flex;
    align-items: center;
    gap: 8px;
    padding-left: 12px;
    padding-right: 16px;
}

.navbar.default-layout-navbar.aimexe-saas-header .header-left-zone .navbar-toggler {
    margin-right: 4px;
}

.navbar.default-layout-navbar.aimexe-saas-header .header-center-zone {
    min-width: 0;
    padding: 0 14px;
}

.navbar.default-layout-navbar.aimexe-saas-header .header-page-title {
    display: block;
    width: 100%;
    color: #132047;
    font-weight: 700;
    font-size: 16px;
    letter-spacing: 0.01em;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.navbar.default-layout-navbar.aimexe-saas-header .navbar-toggler,
.navbar.default-layout-navbar.aimexe-saas-header .navbar-toggler .fa,
.navbar.default-layout-navbar.aimexe-saas-header .navbar-nav .nav-link,
.navbar.default-layout-navbar.aimexe-saas-header .nav-profile-text p,
.navbar.default-layout-navbar.aimexe-saas-header .header-session-info,
.navbar.default-layout-navbar.aimexe-saas-header .header-support-text,
.navbar.default-layout-navbar.aimexe-saas-header .header-support-text a {
    color: #132047 !important;
}

.navbar.default-layout-navbar.aimexe-saas-header .header-meta-block {
    display: none !important;
}

.navbar.default-layout-navbar.aimexe-saas-header .header-support-text {
    font-size: 12px;
    font-weight: 600;
    opacity: 0.95;
    white-space: nowrap;
}

.navbar.default-layout-navbar.aimexe-saas-header .header-session-info {
    font-weight: 600;
    font-size: 13px;
    margin-right: 0;
    opacity: 0.92;
    white-space: nowrap;
}

.navbar.default-layout-navbar.aimexe-saas-header .header-right-zone {
    margin-left: auto;
    gap: 14px;
}

.navbar.default-layout-navbar.aimexe-saas-header .header-email-alert .alert {
    margin: 0 !important;
    padding: 7px 10px;
    font-size: 12px;
}

.navbar.default-layout-navbar.aimexe-saas-header .header-cache-btn {
    background: #132047 !important;
    border: 1px solid #132047 !important;
    color: #ffffff !important;
    border-radius: 10px !important;
    min-height: 34px !important;
    padding: 0 14px !important;
    font-weight: 700 !important;
}

.navbar.default-layout-navbar.aimexe-saas-header .header-cache-btn:hover {
    background: #1f3a68 !important;
    border-color: #1f3a68 !important;
    color: #ffffff !important;
}

.navbar.default-layout-navbar.aimexe-saas-header .nav-profile-img img {
    width: 34px;
    height: 34px;
    object-fit: cover;
    border: 2px solid rgba(19, 32, 71, 0.14);
}

@media (min-width: 992px) {
    .sidebar-icon-only .navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper {
        justify-content: center;
        padding: 0;
    }

    .sidebar-icon-only .navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper .navbar-brand.brand-logo {
        display: flex;
    }

    .sidebar-icon-only .navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper .navbar-brand.brand-logo img {
        max-width: 44px !important;
        max-height: 44px !important;
    }
}

@media (max-width: 991px) {
    .navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper {
        padding: 0 12px;
    }

    .navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper .navbar-brand.brand-logo img {
        max-width: 178px !important;
        max-height: 44px !important;
        height: 44px !important;
    }

    .navbar.default-layout-navbar.aimexe-saas-header .header-center-zone {
        display: none !important;
    }

    .navbar.default-layout-navbar.aimexe-saas-header .header-right-zone .header-session-info,
    .navbar.default-layout-navbar.aimexe-saas-header .header-right-zone .header-support-item {
        display: none !important;
    }
}

body .dashboard-saas *:not(i):not(.fa):not(.fas):not(.far):not(.fab):not([class^='mdi']):not([class*=' mdi']) {
    font-family: 'Roboto', sans-serif !important;
}

.dashboard-saas {
    background: #f4f6fb !important;
    padding: 24px !important;
}

.dashboard-saas .page-title {
    color: #03024d !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    margin-bottom: 0;
}

.dashboard-saas .page-title-icon {
    background: #03024d !important;
    color: #ffffff !important;
    border-radius: 10px !important;
    box-shadow: 0 8px 15px rgba(3, 2, 77, 0.14);
}

.dashboard-saas .grid-margin {
    margin-bottom: 20px !important;
}

.dashboard-saas .card {
    border: 1px solid #e6eaf2 !important;
    border-radius: 14px !important;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06) !important;
    background: #ffffff !important;
}

.dashboard-saas .card .card-body {
    padding: 22px !important;
}

.dashboard-saas .card .card-title {
    color: #03024d !important;
    font-weight: 700 !important;
    letter-spacing: 0.01em;
}

.dashboard-saas .aimexe-kpi-card {
    border: 1px solid #e3e8f3 !important;
    border-radius: 14px !important;
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.06) !important;
    background: #ffffff !important;
    min-height: 128px;
    position: relative;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.dashboard-saas .aimexe-kpi-card .card-body {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 18px !important;
}

.dashboard-saas .aimexe-kpi-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    border-radius: 14px 0 0 14px;
    background: #03024d;
}

.dashboard-saas .aimexe-kpi-card::after {
    content: "";
    position: absolute;
    top: 14px;
    right: 14px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #03024d;
}

.dashboard-saas .aimexe-kpi-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.1) !important;
}

.dashboard-saas .aimexe-kpi-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: #eef2ff;
    color: #03024d;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    flex-shrink: 0;
    margin-right: 0;
    border: 1px solid #d5dcef;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.dashboard-saas .aimexe-kpi-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 72px;
}

.dashboard-saas .aimexe-kpi-title {
    margin: 0 0 8px;
    font-size: 13px !important;
    font-weight: 600 !important;
    letter-spacing: 0.01em;
    text-transform: none;
    color: #5f6b84 !important;
    line-height: 1.35;
}

.dashboard-saas .aimexe-kpi-value {
    margin: 0;
    font-size: 38px !important;
    line-height: 1.05 !important;
    font-weight: 800 !important;
    color: #03024d !important;
}

.dashboard-saas .aimexe-kpi-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 18px;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.dashboard-saas .aimexe-kpi-grid > [class*='col-'] {
    max-width: 100%;
    flex: 0 0 100%;
    padding-left: 0;
    padding-right: 0;
    margin: 0 !important;
}

.dashboard-saas .aimexe-kpi-grid .grid-margin {
    margin-bottom: 0 !important;
}

.dashboard-saas .form-control,
.dashboard-saas .custom-select,
.dashboard-saas .select2-container--default .select2-selection--single {
    border: 1px solid #dbe3ef !important;
    border-radius: 10px !important;
    min-height: 44px;
    color: #03024d !important;
    background: #ffffff !important;
}

.dashboard-saas .form-control:focus,
.dashboard-saas .custom-select:focus {
    border-color: #03024d !important;
    box-shadow: 0 0 0 3px rgba(3, 2, 77, 0.12) !important;
}

.dashboard-saas .btn,
.dashboard-saas .btn-theme,
.dashboard-saas .btn-primary,
.dashboard-saas .btn-success,
.dashboard-saas .btn-info {
    background: #03024d !important;
    border-color: #03024d !important;
    color: #ffffff !important;
    border-radius: 10px !important;
    font-weight: 600;
}

.dashboard-saas .btn:hover,
.dashboard-saas .btn-theme:hover,
.dashboard-saas .btn-primary:hover,
.dashboard-saas .btn-success:hover,
.dashboard-saas .btn-info:hover {
    background: #02013f !important;
    border-color: #02013f !important;
}

.dashboard-saas .table thead th {
    background: #f5f6f8 !important;
    color: #5f6b84 !important;
    border-bottom: 1px solid #e4eaf4 !important;
    font-size: 12px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.dashboard-saas .table tbody td {
    color: #03024d !important;
    border-color: #edf1f7 !important;
}

.dashboard-saas .table tbody tr:hover {
    background: #f9fafc !important;
}

.dashboard-saas .chartjs-wrapper,
.dashboard-saas #expenseChart,
.dashboard-saas #attendanChart,
.dashboard-saas #fees_details_chart,
.dashboard-saas #gender-ratio-chart {
    min-height: 320px;
}

@media (max-width: 1199px) {
    .dashboard-saas .aimexe-kpi-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .dashboard-saas .aimexe-kpi-value {
        font-size: 30px !important;
    }
}

@media (max-width: 991px) {
    .navbar.default-layout-navbar.aimexe-saas-header .header-meta-block,
    .navbar.default-layout-navbar.aimexe-saas-header .header-session-info {
        display: none !important;
    }

    .dashboard-saas {
        padding: 16px !important;
    }

    .dashboard-saas .aimexe-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575px) {
    .dashboard-saas .aimexe-kpi-grid {
        grid-template-columns: 1fr;
    }
}

/* Superadmin UI hardening: keep brand colors and sidebar rhythm stable */
body.aimexe-superadmin-layout {
    --theme-color: #334155 !important;
    --aimexe-primary: #03024d;
    --aimexe-primary-dark: #03024d;
    --aimexe-accent: #03024d;
    --aimexe-highlight: #03024d;
}

body.aimexe-superadmin-layout .navbar.default-layout-navbar.aimexe-saas-header,
body.aimexe-superadmin-layout .navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper,
body.aimexe-superadmin-layout .navbar.default-layout-navbar.aimexe-saas-header .navbar-menu-wrapper {
    background: transparent !important;
}

body.aimexe-superadmin-layout .navbar.default-layout-navbar.aimexe-saas-header .navbar-brand-wrapper {
    background: rgba(255, 255, 255, 0.42) !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar {
    background: #f7f8fa !important;
    border-right: 1px solid #e3e8f2;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .sidebar-search {
    padding-left: 12px !important;
    padding-right: 12px !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .sidebar-search .form-control {
    height: 42px;
    border: 1px solid #20447d !important;
    border-radius: 10px !important;
    background: #ffffff !important;
    box-shadow: none !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item {
    margin-bottom: 6px;
    padding: 0 8px !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item > .nav-link,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item .sub-menu .nav-link {
    position: relative;
    min-height: 38px;
    padding: 8px 12px 8px 14px;
    border: 0 !important;
    border-radius: 8px !important;
    background: transparent !important;
    box-shadow: none !important;
    transform: none !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item > .nav-link::before,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item .sub-menu .nav-link::before {
    content: "";
    position: absolute;
    left: 0;
    top: 6px;
    bottom: 6px;
    width: 3px;
    border-radius: 999px;
    background: transparent;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item > .nav-link:hover,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item .sub-menu .nav-link:hover {
    background: #eef2f6 !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item > .nav-link.active,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item > .nav-link[aria-expanded="true"],
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item .sub-menu .nav-link.active,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item .sub-menu .nav-link[aria-expanded="true"] {
    background: #03024d !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item > .nav-link.active .menu-title,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item > .nav-link[aria-expanded="true"] .menu-title,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item .sub-menu .nav-link.active .menu-title,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item .sub-menu .nav-link[aria-expanded="true"] .menu-title {
    color: #132047 !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item .sub-menu .nav-link.active,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item .sub-menu .nav-link[aria-expanded="true"] {
    color: #132047 !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item > .nav-link.active::before,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item > .nav-link[aria-expanded="true"]::before,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item .sub-menu .nav-link.active::before,
body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav.aimexe-superadmin-nav-shell > .nav-item .sub-menu .nav-link[aria-expanded="true"]::before {
    background: #03024d;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav .nav-item .nav-link .menu-title {
    color: #132047;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.35;
    text-transform: none !important;
    letter-spacing: 0;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .aimexe-group-item {
    margin-bottom: 6px;
    border-top: 0;
    padding-top: 0 !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .aimexe-group-item > .nav-link .menu-title {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .aimexe-group-submenu {
    margin-top: 4px;
    margin-bottom: 10px;
    padding-left: 12px !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .aimexe-group-submenu > .nav-item > .nav-link {
    min-height: 34px;
    padding: 7px 12px 7px 14px;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .aimexe-group-submenu > .nav-item > .nav-link .menu-title {
    font-size: 13px !important;
    font-weight: 500 !important;
    text-transform: none !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .aimexe-group-submenu > .nav-item > .collapse .sub-menu .nav-link {
    padding-left: 28px !important;
    font-size: 12.5px !important;
    font-weight: 500 !important;
    text-transform: none !important;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav .nav-item .nav-link i.menu-icon {
    width: 18px;
    margin-right: 10px;
    color: #35527f;
    font-size: 14px !important;
    line-height: 1;
}

body.aimexe-superadmin-layout .aimexe-superadmin-sidebar .nav .nav-item .nav-link i.menu-arrow {
    margin-left: auto;
    color: #8da0bc;
    font-size: 13px !important;
}
