/* PU Branding Theme - Admin & User (Cleaner Version) */
:root {
    --pu-blue: #364878;
    --pu-yellow: #ffc800;
    --pu-blue-deep: #003366;
    --pu-gray-light: #f4f7fa;
    --pu-border: #e0e6ed;
}

body,
html,
* {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
}

/* Backgrounds */
.bg-primary {
    background-color: var(--pu-blue) !important;
}

.bg-warning {
    background-color: var(--pu-yellow) !important;
}

/* Text */
.text-primary {
    color: var(--pu-blue) !important;
}

.text-warning {
    color: var(--pu-yellow) !important;
}

/* Base UI */
#wrapper {
    background-color: var(--pu-gray-light);
}

.content-page {
    background-color: var(--pu-gray-light);
}

.card {
    border: none !important;
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
    border-radius: 8px !important;
}

/* Topbar - Clean White with Blue/Yellow accents */
.topbar {
    background-color: #ffffff !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05) !important;
}

.topbar-left {
    background-color: var(--pu-blue) !important;
}

.navbar-custom {
    background-color: #ffffff !important;
}

.navbar-custom .nav-link {
    color: #6c757d !important;
}

.navbar-custom .nav-link:hover {
    color: var(--pu-blue) !important;
}

/* Sidebar - Modern Dark or Light */
.side-menu {
    background-color: #ffffff !important;
    border-right: 1px solid var(--pu-border);
}

#sidebar-menu>ul>li>a {
    color: #495057 !important;
    font-weight: 500;
    padding: 12px 20px !important;
    transition: all 0.3s;
}

#sidebar-menu>ul>li>a:hover {
    color: var(--pu-blue) !important;
    background-color: rgba(0, 51, 102, 0.05) !important;
}

/* mm-active: Active Page or Expanded Menu */
#sidebar-menu li.mm-active>a {
    color: var(--pu-blue) !important;
    background-color: rgba(0, 51, 102, 0.08) !important;
}

/* The actual active link (leaf node) */
#sidebar-menu li.mm-active>a.mm-active {
    background-color: var(--pu-blue) !important;
    color: var(--pu-yellow) !important;
    box-shadow: 0 4px 6px rgba(0, 51, 102, 0.15);
}

#sidebar-menu li.mm-active>a.mm-active i,
#sidebar-menu li.mm-active>a.mm-active span {
    color: var(--pu-yellow) !important;
}

#sidebar-menu .submenu {
    background-color: #ffffff !important;
    padding-left: 0;
}

#sidebar-menu .submenu>li>a {
    color: #555 !important;
    font-size: 13.5px !important;
    padding: 10px 20px 10px 55px !important;
    transition: all 0.2s;
}

#sidebar-menu .submenu>li>a:hover,
#sidebar-menu .submenu>li.mm-active>a {
    color: var(--pu-blue) !important;
    background-color: rgba(0, 51, 102, 0.05) !important;
}

#sidebar-menu .submenu>li.mm-active>a.mm-active {
    color: var(--pu-blue) !important;
    background-color: #f0f0f0 !important;
    font-weight: 600;
    box-shadow: inset 3px 0 0 var(--pu-blue);
}

.menu-title {
    color: #adb5bd !important;
    font-size: 11px !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 15px 20px 5px !important;
}

/* Buttons */
.btn-primary {
    background-color: var(--pu-blue) !important;
    border-color: var(--pu-blue) !important;
    padding: 8px 20px !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
}

.btn-primary:hover {
    background-color: #004080 !important;
    border-color: #004080 !important;
    transform: translateY(-1px);
}

/* Footer */
.footer {
    background: #ffffff !important;
    border-top: 1px solid var(--pu-border) !important;
    color: #6c757d !important;
    padding: 15px 30px !important;
    bottom: 0;
    width: 100%;
}

/* Account Pages (Login/Register Refined) */
.accountbg {
    background-color: var(--pu-blue);
    background-size: cover;
}

.card-pages {
    border-top: 5px solid var(--pu-yellow) !important;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1) !important;
}

/* Custom for CI tables and elements */
.badge-primary {
    background-color: var(--pu-blue) !important;
}

.badge-warning {
    background-color: var(--pu-yellow) !important;
    color: #333 !important;
}

.logo-light {
    color: var(--pu-yellow) !important;
    font-weight: 800;
    letter-spacing: 1px;
}

/* DataTables Responsive Refinements */
table.dataTable.dtr-inline.collapsed>tbody>tr>td.dtr-control:before,
table.dataTable.dtr-inline.collapsed>tbody>tr>th.dtr-control:before {
    background-color: var(--pu-blue) !important;
    top: 50% !important;
    margin-top: -9px !important;
    box-shadow: none !important;
}

table.dataTable.dtr-inline.collapsed>tbody>tr.parent>td.dtr-control:before,
table.dataTable.dtr-inline.collapsed>tbody>tr.parent>th.dtr-control:before {
    background-color: var(--pu-yellow) !important;
    color: #333 !important;
}

.dtr-details {
    width: 100%;
}

@media screen and (max-width: 767px) {

    div.dataTables_wrapper div.dataTables_length,
    div.dataTables_wrapper div.dataTables_filter,
    div.dataTables_wrapper div.dataTables_info,
    div.dataTables_wrapper div.dataTables_paginate {
        text-align: center;
    }

    .card-body {
        padding: 15px !important;
    }
}

/* Preloader - Rotating Dots PU */
#preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.85);
    z-index: 99999;
    display: flex;
    justify-content: center;
    align-items: center;
}

.pu-spinner {
    width: 50px;
    aspect-ratio: 1;
    display: grid;
    border-radius: 50%;
    background:
        radial-gradient(farthest-side, var(--pu-blue) 94%, #0000) top/10px 10px no-repeat,
        conic-gradient(#0000 30%, var(--pu-blue));
    -webkit-mask: radial-gradient(farthest-side, #0000 calc(100% - 10px), #000 0);
    mask: radial-gradient(farthest-side, #0000 calc(100% - 10px), #000 0);
    animation: pu-spin 1s infinite linear;
}

@keyframes pu-spin {
    100% {
        transform: rotate(1turn)
    }
}

/* Sidebar Enlarged/Minified Mode Fixes */
.enlarged .left.side-menu #sidebar-menu>ul>li:hover>a {
    background-color: var(--pu-blue-deep) !important;
    color: var(--pu-yellow) !important;
    width: 260px !important;
}

.enlarged .left.side-menu #sidebar-menu>ul>li:hover>a i {
    color: var(--pu-yellow) !important;
    background-color: var(--pu-blue-deep) !important;
    margin-right: 20px !important;
}

.enlarged .left.side-menu #sidebar-menu>ul>li:hover>a span {
    color: var(--pu-yellow) !important;
    background-color: var(--pu-blue-deep) !important;
    display: inline-block !important;
}

.enlarged .left.side-menu #sidebar-menu>ul>li:hover>ul {
    background-color: #ffffff !important;
    box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.1) !important;
    padding-bottom: 10px !important;
    padding-top: 10px !important;
}

.enlarged .left.side-menu #sidebar-menu>ul>li:hover>ul a {
    color: #495057 !important;
    background-color: #ffffff !important;
}

.enlarged .left.side-menu #sidebar-menu>ul>li:hover>ul a:hover {
    color: var(--pu-blue) !important;
    background-color: rgba(0, 51, 102, 0.05) !important;
}

.enlarged .left.side-menu #sidebar-menu>ul>li.mm-active>a {
    /* background-color: rgba(0, 84, 156, 0.1) !important;
    color: var(--pu-blue) !important; */
}