/* 
 * ==========================================
 * Next-Level Premium UI/UX Custom Overrides
 * Design System: Antigravity Light Blue & White
 * ==========================================
 */

:root {
    --bg-main: #f4f7fc;
    --bg-card: #ffffff;
    --bg-sidebar: #ffffff;
    --border-color: rgba(226, 232, 240, 0.8); /* Slate 200 */
    --accent-glow: rgba(37, 99, 235, 0.08);
    --color-primary: #2563eb; /* Royal Blue */
    --color-secondary: #3b82f6; /* Accent Blue */
    --color-text-main: #1e293b; /* Dark Slate */
    --color-text-muted: #64748b; /* Slate Gray */
    --transition-smooth: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Global Font & Body Settings */
body {
    font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    background-color: var(--bg-main) !important;
    color: var(--color-text-main) !important;
    background-image: 
        radial-gradient(at 0% 0%, rgba(37, 99, 235, 0.03) 0px, transparent 50%),
        radial-gradient(at 100% 100%, rgba(59, 130, 246, 0.03) 0px, transparent 50%) !important;
    background-attachment: fixed !important;
}

/* Typography Overrides */
h1, h2, h3, h4, h5, h6, .media-title, .card-title {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-weight: 700 !important;
    color: #0f172a !important;
    letter-spacing: -0.025em;
}

/* Light Top Navbar */
.navbar {
    background-color: rgba(255, 255, 255, 0.9) !important;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border-color) !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.02);
    padding: 0.75rem 1.5rem !important;
}

.navbar h4 {
    background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 800 !important;
    letter-spacing: -0.05em;
}

.navbar .navbar-nav-link {
    color: var(--color-text-main) !important;
}

/* Premium White Sidebar */
.sidebar {
    background: var(--bg-sidebar) !important;
    border-right: 1px solid var(--border-color) !important;
    box-shadow: 4px 0 20px rgba(0, 0, 0, 0.02);
}

/* Remove any border/outline from sidebar logo */
.sidebar-user a,
.sidebar-user a:focus,
.sidebar-user a:active,
.sidebar-user a:hover,
.sidebar-user a img {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    text-decoration: none !important;
}

/* ============================================================
 * MAIN LAYOUT — Lock height to viewport, let children handle scroll
 * Framework already sets page-content as flex row,
 * and content-wrapper as flex column. We just lock heights.
 * ============================================================ */

/* Lock the full layout to viewport height */
body {
    height: 100dvh !important;
    overflow: hidden !important;
}

.page-content {
    height: 100dvh !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
}

/* Content wrapper: header fixed top, inner content scrolls */
.content-wrapper {
    overflow: hidden !important;    /* override framework's overflow:auto */
    display: flex !important;
    flex-direction: column !important;
}

/* Header never scrolls — pinned at top of content-wrapper */
.content-wrapper > .page-header {
    flex-shrink: 0 !important;
}

/* Inner .content area scrolls */
.content-wrapper > .content {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
}

/* Sidebar User Section */
.sidebar-user {
    border-bottom: 1px solid var(--border-color);
    background: rgba(37, 99, 235, 0.02);
    margin-bottom: 1rem;
}

.sidebar-user .media-title {
    color: var(--color-text-main) !important;
}

.sidebar-user .opacity-50 {
    color: var(--color-text-muted) !important;
    opacity: 1 !important;
}

.sidebar-user img {
    border: 2px solid var(--color-primary);
    box-shadow: 0 0 10px rgba(37, 99, 235, 0.2);
}

.sidebar-user a.text-white {
    color: var(--color-text-muted) !important;
}

/* Navigation Links */
.nav-sidebar .nav-item > .nav-link {
    font-weight: 600 !important;
    color: var(--color-text-muted) !important;
    padding: 0.7rem 1.25rem !important;
    border-radius: 100px !important;
    margin: 0.25rem 0.75rem !important;
    transition: var(--transition-smooth) !important;
    display: flex;
    align-items: center;
}

/* Hover States */
.nav-sidebar .nav-item > .nav-link:hover {
    color: var(--color-primary) !important;
    background-color: rgba(37, 99, 235, 0.05) !important;
    transform: translateX(4px);
}

/* Active Link State */
.nav-sidebar .nav-item > .nav-link.active,
.nav-sidebar .nav-item-open > .nav-link {
    color: var(--color-primary) !important;
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.08) 0%, rgba(59, 130, 246, 0.03) 100%) !important;
    font-weight: 700 !important;
}

.nav-sidebar .nav-link i {
    font-size: 1.2rem;
    margin-right: 15px;
    color: var(--color-text-muted);
    transition: var(--transition-smooth);
}

.nav-sidebar .nav-item > .nav-link.active i,
.nav-sidebar .nav-item > .nav-link:hover i {
    color: var(--color-primary) !important;
}

/* Submenu layout */
.nav-group-sub {
    background-color: rgba(0, 0, 0, 0.02) !important;
    margin: 0.2rem 0.75rem !important;
    border-radius: 8px;
    padding: 0.4rem 0 !important;
}

.nav-group-sub .nav-link {
    padding-left: 3rem !important;
}

/* iOS Segmented Control styled nav-pills */
.nav-pills {
    background: rgba(15, 23, 42, 0.05) !important;
    border-radius: 14px !important;
    padding: 4px !important;
    border: none !important;
}

.nav-pills .nav-item {
    margin: 0 !important;
}

.nav-pills .nav-link {
    color: var(--color-text-muted) !important;
    background: transparent !important;
    border-radius: 10px !important;
    font-weight: 700 !important;
    font-size: 0.85rem !important;
    padding: 0.65rem 1.4rem !important;
    transition: var(--transition-smooth) !important;
    border: none !important;
    box-shadow: none !important;
}

.nav-pills .nav-link:hover {
    color: var(--color-text-main) !important;
}

.nav-pills .nav-link.active {
    color: var(--color-primary) !important;
    background: #ffffff !important;
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.08) !important;
}

/* Cards Redesign */
.card {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 24px !important;
    box-shadow: 0 4px 20px rgba(15, 23, 42, 0.03) !important;
    margin-bottom: 2rem;
    overflow: hidden;
    transition: var(--transition-smooth);
}

/* Stat Cards on Dashboard */
.stat-card {
    border: none !important;
    border-radius: 24px !important;
    color: #ffffff !important;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.04) !important;
    transition: var(--transition-smooth) !important;
}
.stat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 15px 35px rgba(15, 23, 42, 0.08) !important;
}
.stat-card.stat-blue   { background: linear-gradient(135deg, #2563eb, #3b82f6) !important; }
.stat-card.stat-red    { background: linear-gradient(135deg, #e11d48, #f43f5e) !important; }
.stat-card.stat-green  { background: linear-gradient(135deg, #059669, #10b981) !important; }
.stat-card.stat-purple { background: linear-gradient(135deg, #7c3aed, #8b5cf6) !important; }

.stat-card h3 {
    color: #ffffff !important;
    font-size: 1.85rem !important;
    font-weight: 800 !important;
    margin-bottom: 0.25rem !important;
}

.stat-card span {
    color: rgba(255, 255, 255, 0.85) !important;
    font-weight: 700 !important;
}

.stat-card .stat-icon {
    background: rgba(255, 255, 255, 0.2) !important;
    border-radius: 50% !important;
    width: 54px;
    height: 54px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
}

.stat-card .stat-icon i {
    font-size: 1.5rem;
    color: #ffffff !important;
}



.card-header {
    background-color: #ffffff !important;
    border-bottom: 1px solid var(--border-color) !important;
    padding: 1.25rem 1.5rem !important;
}

/* Buttons Styling */
.btn {
    font-weight: 700 !important;
    border-radius: 10px !important;
    padding: 0.65rem 1.5rem !important;
    transition: var(--transition-smooth) !important;
    text-transform: uppercase;
    font-size: 0.75rem !important;
    letter-spacing: 0.05em;
    box-shadow: none !important;
}

.btn-primary {
    background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)) !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(37, 99, 235, 0.25) !important;
    color: #ffffff !important;
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(37, 99, 235, 0.4) !important;
}

.btn-light {
    background: #ffffff !important;
    border: 1px solid var(--border-color) !important;
    color: var(--color-text-main) !important;
}

.btn-light:hover {
    background: rgba(15, 23, 42, 0.02) !important;
    border-color: rgba(15, 23, 42, 0.15) !important;
}

/* Tables Styling */
.table {
    color: var(--color-text-main) !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    width: 100% !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    margin-bottom: 1.5rem !important;
}

.table th {
    font-weight: 700 !important;
    color: #475569 !important;
    border-top: none !important;
    border-bottom: 2px solid var(--border-color) !important;
    background-color: rgba(37, 99, 235, 0.03) !important;
    text-transform: uppercase !important;
    font-size: 0.72rem !important;
    letter-spacing: 0.08em !important;
    padding: 1rem 1.25rem !important;
    vertical-align: middle !important;
}

.table td {
    border-top: 1px solid rgba(226, 232, 240, 0.6) !important;
    border-bottom: none !important;
    padding: 1rem 1.25rem !important;
    vertical-align: middle !important;
    color: #334155 !important;
    font-size: 0.875rem !important;
}

/* Ensure outer cells align with table border-radius */
.table thead tr:first-child th:first-child {
    border-top-left-radius: 12px !important;
}

.table thead tr:first-child th:last-child {
    border-top-right-radius: 12px !important;
}

.table tbody tr:last-child td:first-child {
    border-bottom-left-radius: 12px !important;
}

.table tbody tr:last-child td:last-child {
    border-bottom-right-radius: 12px !important;
}

.table-striped tbody tr:nth-of-type(even) {
    background-color: rgba(248, 250, 252, 0.4) !important;
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: #ffffff !important;
}

.table-hover tbody tr {
    transition: background-color 0.15s ease !important;
}

.table-hover tbody tr:hover {
    background-color: rgba(37, 99, 235, 0.02) !important;
}

/* Actions Menu styling inside table cells */
.list-icons-item {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: rgba(15, 23, 42, 0.03) !important;
    color: var(--color-text-muted) !important;
    transition: all 0.2s ease !important;
}

.list-icons-item:hover {
    background: rgba(37, 99, 235, 0.08) !important;
    color: var(--color-primary) !important;
    text-decoration: none !important;
}

.list-icons-item i {
    font-size: 1rem !important;
}

/* Dropdown menus inside tables */
.dropdown-menu {
    border-radius: 16px !important;
    border: 1px solid rgba(15, 23, 42, 0.08) !important;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08) !important;
    padding: 0.5rem !important;
}

.dropdown-item {
    border-radius: 8px !important;
    padding: 0.5rem 1rem !important;
    font-weight: 500 !important;
    color: var(--color-text-main) !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    transition: all 0.15s ease !important;
}

.dropdown-item:hover {
    background-color: rgba(37, 99, 235, 0.05) !important;
    color: var(--color-primary) !important;
}

.dropdown-item i {
    font-size: 1rem !important;
    color: var(--color-text-muted) !important;
    margin-right: 0 !important;
    width: 1.25rem !important;
    text-align: center !important;
}

.dropdown-item:hover i {
    color: var(--color-primary) !important;
}

/* Forms and Inputs */
.form-control {
    background-color: #ffffff !important;
    border: 1px solid rgba(15, 23, 42, 0.15) !important;
    color: var(--color-text-main) !important;
    border-radius: 10px !important;
    padding: 0.75rem 1rem !important;
    transition: var(--transition-smooth) !important;
}

.form-control:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 10px rgba(37, 99, 235, 0.15) !important;
}

/* Alert Boxes */
.alert {
    border-radius: 12px !important;
    border: 1px solid rgba(0, 0, 0, 0.05) !important;
}

.alert-danger {
    background-color: #fef2f2 !important;
    color: #991b1b !important;
}

.alert-success {
    background-color: #ecfdf5 !important;
    color: #065f46 !important;
}

/* Custom Scrollbars */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--bg-main);
}

::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.1);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.2);
}

/* Badges */
.badge {
    border-radius: 6px !important;
    padding: 0.35em 0.65em !important;
    font-weight: 600 !important;
}

/* Styled File Input (Uniform Uploader) Spacing and Alignment Fix */
.uniform-uploader {
    display: flex !important;
    align-items: center;
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
    width: 100% !important;
}

.uniform-uploader .filename {
    border: 1px solid rgba(15, 23, 42, 0.15) !important;
    border-radius: 10px !important;
    margin-right: 15px !important; /* Spacing between input bar and button */
    padding: 0.75rem 1rem !important;
    height: auto !important;
    line-height: normal !important;
    background-color: #ffffff !important;
    flex: 1 !important;
    display: flex !important;
    align-items: center !important;
}

.uniform-uploader .action {
    border-radius: 10px !important;
    padding: 0.75rem 1.5rem !important;
    height: auto !important;
    line-height: normal !important;
    margin-top: 0 !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    font-size: 0.75rem !important;
    letter-spacing: 0.05em !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* ==========================================
 * Premium Login Page Styling (Glassmorphism)
 * ==========================================
 */
.login-cover {
    background: radial-gradient(circle at 10% 20%, rgba(37, 99, 235, 0.05) 0%, transparent 45%),
                radial-gradient(circle at 90% 80%, rgba(59, 130, 246, 0.07) 0%, transparent 55%),
                linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%) !important;
    background-size: cover !important;
    position: relative;
    overflow: hidden;
}

/* Background animated subtle pulse */
.login-cover::before {
    content: '';
    position: absolute;
    top: -20%;
    left: -20%;
    width: 60%;
    height: 60%;
    background: radial-gradient(circle, rgba(37, 99, 235, 0.12) 0%, transparent 70%);
    z-index: 0;
    pointer-events: none;
    animation: pulseGlow 15s infinite alternate ease-in-out;
}

.login-cover::after {
    content: '';
    position: absolute;
    bottom: -20%;
    right: -20%;
    width: 60%;
    height: 60%;
    background: radial-gradient(circle, rgba(59, 130, 246, 0.1) 0%, transparent 70%);
    z-index: 0;
    pointer-events: none;
    animation: pulseGlow 18s infinite alternate-reverse ease-in-out;
}

@keyframes pulseGlow {
    0% {
        transform: translate(0, 0) scale(1);
    }
    100% {
        transform: translate(8%, 8%) scale(1.15);
    }
}

.login-cover .content-wrapper {
    z-index: 1;
}

/* Glassmorphism Login Card - Light Theme */
.login-form {
    width: 100%;
    max-width: 440px;
    margin: 0 auto;
}

.login-form .card {
    background: rgba(255, 255, 255, 0.75) !important;
    backdrop-filter: blur(30px) !important;
    -webkit-backdrop-filter: blur(30px) !important;
    border: 1px solid rgba(255, 255, 255, 0.6) !important;
    border-radius: 32px !important;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.08) !important;
    overflow: visible;
}

.login-form .card-body {
    padding: 2.75rem 2.25rem !important;
}

.login-form h5 {
    color: #0f172a !important;
    font-size: 1.6rem !important;
    font-weight: 800 !important;
    letter-spacing: -0.03em;
    margin-top: 0.75rem;
}

.login-form .text-muted {
    color: #64748b !important;
    font-size: 0.9rem;
    font-weight: 500;
}

/* Interactive Input Groups - Light Theme */
.login-form .form-group {
    position: relative;
    margin-bottom: 1.5rem;
}

.login-form .form-control {
    background: #ffffff !important;
    border: 1px solid #cbd5e1 !important;
    color: #0f172a !important;
    font-weight: 500;
    border-radius: 100px !important;
    padding: 0.85rem 1.25rem !important;
    font-size: 0.95rem;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.login-form .form-control::placeholder {
    color: #94a3b8 !important;
}

.login-form .form-control:focus {
    background: #ffffff !important;
    border-color: #2563eb !important;
    box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.15) !important;
    transform: translateY(-1px);
}

/* Custom Checkbox and Links - Light Theme */
.login-form .form-check-label {
    color: #475569 !important;
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    display: flex;
    align-items: center;
}

.login-form .form-check-input {
    position: static !important;
    margin-top: 0 !important;
    margin-right: 8px !important;
    width: 16px;
    height: 16px;
    background-color: #f8fafc !important;
    border: 1px solid #cbd5e1 !important;
    border-radius: 4px;
    cursor: pointer;
}

.login-form a {
    color: #2563eb !important;
    font-size: 0.85rem;
    font-weight: 600;
    transition: all 0.2s ease;
}

.login-form a:hover {
    color: #1d4ed8 !important;
    text-decoration: underline !important;
}

/* Login Button */
.login-form .btn-primary {
    background: linear-gradient(135deg, #2563eb 0%, #3b82f6 100%) !important;
    border: none !important;
    border-radius: 100px !important;
    padding: 0.9rem 1.5rem !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em;
    text-transform: none !important;
    box-shadow: 0 6px 20px rgba(37, 99, 235, 0.25) !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    color: #ffffff !important;
}

.login-form .btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(37, 99, 235, 0.45) !important;
}

.login-form .btn-primary:active {
    transform: translateY(0);
}

/* Header & Footer on Login Screen - Light Theme overrides */
.login-cover .navbar-dark {
    background-color: rgba(255, 255, 255, 0.8) !important;
    backdrop-filter: blur(24px) !important;
    -webkit-backdrop-filter: blur(24px) !important;
    border: 1px solid rgba(255, 255, 255, 0.45) !important;
    padding: 0.4rem 2rem !important;
    position: sticky;
    top: 15px;
    margin: 15px auto 0;
    max-width: 1240px;
    width: calc(100% - 40px);
    border-radius: 100px;
    z-index: 1000;
    box-shadow: 0 12px 40px rgba(15, 23, 42, 0.06) !important;
}

.login-cover .navbar-dark .navbar-nav-link {
    color: #334155 !important;
    font-weight: 600;
    font-size: 0.92rem;
    padding: 0.5rem 1.1rem !important;
    border-radius: 100px;
    transition: all 0.3s ease;
}

.login-cover .navbar-dark .navbar-nav-link:hover {
    color: #2563eb !important;
    background-color: rgba(37, 99, 235, 0.06) !important;
}

.login-cover .navbar-light {
    background-color: rgba(255, 255, 255, 0.65) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    border-top: 1px solid rgba(15, 23, 42, 0.06) !important;
    color: #64748b !important;
    padding: 0.75rem 2rem !important;
}

.login-cover .navbar-light .navbar-text,
.login-cover .navbar-light .navbar-nav-link {
    color: #64748b !important;
    font-size: 0.85rem;
    transition: all 0.3s ease;
}

.login-cover .navbar-light .navbar-nav-link:hover {
    color: #2563eb !important;
}
}

/* Styling for login logo */
.login-logo {
    transition: transform 0.3s ease;
}

/* Premium FullCalendar Styling Overrides */
.fc-button {
    background: #ffffff !important;
    border: 1px solid var(--border-color) !important;
    color: var(--color-text-main) !important;
    border-radius: 100px !important;
    padding: 0.45rem 1.25rem !important;
    font-weight: 700 !important;
    font-size: 0.75rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    box-shadow: none !important;
    transition: var(--transition-smooth) !important;
    height: auto !important;
}

.fc-button:hover {
    background: rgba(37, 99, 235, 0.05) !important;
    color: var(--color-primary) !important;
    border-color: rgba(37, 99, 235, 0.2) !important;
}

.fc-button-active {
    background: var(--color-primary) !important;
    color: #ffffff !important;
    border-color: var(--color-primary) !important;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.2) !important;
}

.fc-head-container, .fc-widget-header {
    background: rgba(37, 99, 235, 0.02) !important;
    border-bottom: 2px solid var(--border-color) !important;
}

.fc-day-header {
    padding: 12px 0 !important;
    font-weight: 700 !important;
    color: var(--color-text-main) !important;
    font-size: 0.8rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.fc-day-number {
    font-weight: 600 !important;
    padding: 10px !important;
    color: var(--color-text-muted) !important;
}

.fc-today {
    background: rgba(37, 99, 235, 0.03) !important;
}

.fc-event {
    background-color: var(--color-primary) !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 4px 8px !important;
    font-weight: 600 !important;
    box-shadow: 0 2px 6px rgba(37, 99, 235, 0.15) !important;
}

/* Sidebar nested card outline strip */
.sidebar .card {
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    margin: 0 !important;
}

/* Premium Page Header Overrides — compact height */
.page-header {
    background-color: #ffffff !important;
    border-bottom: 1px solid var(--border-color) !important;
    padding: 0.6rem 1.5rem !important;
    box-shadow: 0 2px 12px rgba(15, 23, 42, 0.03) !important;
    min-height: 52px !important;
}

.page-header .page-header-content {
    min-height: 40px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.page-header h4 {
    font-size: 1.1rem !important;
    margin-bottom: 0 !important;
}

.page-header .btn-link {
    color: var(--color-text-main) !important;
    font-size: 0.82rem !important;
    text-transform: none !important;
    font-weight: 700 !important;
    border-radius: 100px !important;
    padding: 0.45rem 1.15rem !important;
    background: rgba(37, 99, 235, 0.05) !important;
    border: 1px solid rgba(37, 99, 235, 0.08) !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    transition: var(--transition-smooth) !important;
    letter-spacing: normal !important;
}

.page-header .btn-link:hover {
    background: rgba(37, 99, 235, 0.09) !important;
    text-decoration: none !important;
}

.page-header .btn-link i {
    font-size: 0.95rem !important;
    margin-right: 0 !important;
}

/* User Profile Dropdown Pill */
.page-header .dropdown-toggle {
    padding: 0.4rem 1.15rem 0.4rem 0.4rem !important;
    border-radius: 100px !important;
    background: #ffffff !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.02) !important;
    transition: var(--transition-smooth) !important;
    color: var(--color-text-main) !important;
}

.page-header .dropdown-toggle:hover {
    border-color: rgba(37, 99, 235, 0.2) !important;
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.04) !important;
}

.page-header .dropdown-toggle::after {
    margin-left: 8px !important;
    vertical-align: middle !important;
}

/* Dropdown Menu styling */
.dropdown-menu {
    border-radius: 16px !important;
    border: 1px solid rgba(15, 23, 42, 0.08) !important;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06) !important;
    padding: 0.5rem !important;
    background: #ffffff !important;
}

.dropdown-item {
    border-radius: 8px !important;
    padding: 0.55rem 1rem !important;
    font-weight: 600 !important;
    font-size: 0.85rem !important;
    color: var(--color-text-main) !important;
    transition: var(--transition-smooth) !important;
}

.dropdown-item:hover {
    background-color: rgba(37, 99, 235, 0.05) !important;
    color: var(--color-primary) !important;
}

.dropdown-item.text-danger:hover {
    background-color: #fef2f2 !important;
    color: #ef4444 !important;
}

/* ============================================================
 * SIDEBAR FLEX COLUMN — logo top + nav scroll + footer bottom
 * ============================================================ */

/* sidebar-content fills sidebar height as a flex column */
.sidebar-content {
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    overflow: hidden !important;
    min-height: 0 !important;
}

/* Sidebar XS adaptations for clean collapsed view */
.sidebar-xs .sidebar-main,
.sidebar-xs .sidebar-main .sidebar-content {
    width: 3.5rem !important;
    min-width: 3.5rem !important;
    max-width: 3.5rem !important;
    overflow: visible !important;
}

.sidebar-xs .sidebar-logo-container {
    padding: 1rem 0 !important;
    width: 3.5rem !important;
    max-width: 3.5rem !important;
    margin: 0 auto !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    overflow: hidden !important;
}

.sidebar-xs .sidebar-logo-link {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}

.sidebar-xs .sidebar-logo-img {
    margin: 0 auto !important;
    display: block !important;
    height: 32px !important;
    width: auto !important;
}

.sidebar-xs .sidebar-logo-text {
    display: none !important;
}

.sidebar-xs .sidebar-main .nav-sidebar > .nav-item > .nav-link {
    width: 2.75rem !important;
    height: 2.75rem !important;
    margin: 0.25rem auto !important;
    padding: 0 !important;
    border-radius: 50% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}

.sidebar-xs .sidebar-main .nav-sidebar > .nav-item > .nav-link i {
    margin: 0 !important;
    padding: 0 !important;
    font-size: 1.15rem !important;
    display: block !important;
}

.sidebar-xs .sidebar-footer {
    padding: 0.75rem 0 !important;
    width: 3.5rem !important;
    max-width: 3.5rem !important;
    margin: 0 auto !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    overflow: hidden !important;
}

.sidebar-xs .sidebar-footer .d-flex {
    width: 100% !important;
    justify-content: center !important;
    align-items: center !important;
}

.sidebar-xs .footer-session-info {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 0 !important;
}

.sidebar-xs .footer-session-icon {
    margin: 0 auto !important;
}

.sidebar-xs .footer-session-text {
    display: none !important;
}

.sidebar-xs .footer-settings-cog {
    display: none !important;
}

/* ============================================================
 * SIDEBAR INTERNAL SCROLL — Only .card-sidebar-mobile scrolls
 * Logo pinned top, session footer pinned bottom
 * ============================================================ */

/* Sidebar itself: no scroll — sidebar-content handles layout */
.sidebar {
    overflow: hidden !important;
}

/* Expanded sidebar: nav card is the scroll zone */
body:not(.sidebar-xs) .card-sidebar-mobile {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
}

/* Slim 4px scrollbar on the nav card */
.card-sidebar-mobile::-webkit-scrollbar {
    width: 4px !important;
}

.card-sidebar-mobile::-webkit-scrollbar-track {
    background: transparent !important;
}

.card-sidebar-mobile::-webkit-scrollbar-thumb {
    background: rgba(100, 116, 139, 0.18) !important;
    border-radius: 100px !important;
}

.card-sidebar-mobile::-webkit-scrollbar-thumb:hover {
    background: rgba(37, 99, 235, 0.35) !important;
}

/* Collapsed sidebar: nav fits in icons, no scroll needed */
.sidebar-xs .card-sidebar-mobile {
    overflow: visible !important;
}

/* ============================================================
 * DataTables Integration & Modern UI
 * ============================================================ */

/* Top header and bottom footer containers */
.datatable-header {
    padding: 1.25rem 1.5rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: wrap !important;
    gap: 1rem !important;
    border-bottom: 1px solid var(--border-color) !important;
    background: rgba(248, 250, 252, 0.3) !important;
}

.datatable-footer {
    padding: 1.25rem 1.5rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: wrap !important;
    gap: 1rem !important;
    border-top: 1px solid var(--border-color) !important;
    background: rgba(248, 250, 252, 0.2) !important;
}

/* Scroll wrapper for dataTable */
.datatable-scroll {
    overflow-x: auto !important;
    width: 100% !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 12px !important;
    margin: 1.25rem 0 !important;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.01) !important;
}

/* Strip boundaries of table inside .datatable-scroll */
.datatable-scroll .table {
    border: none !important;
    margin-bottom: 0 !important;
    border-radius: 0 !important;
}

/* Search input container (.dataTables_filter) */
.dataTables_filter {
    margin: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
}

.dataTables_filter label {
    display: flex !important;
    align-items: center !important;
    margin-bottom: 0 !important;
    position: relative !important;
}

.dataTables_filter label span {
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    color: var(--color-text-muted) !important;
    margin-right: 0.75rem !important;
}

.dataTables_filter input {
    background-color: #ffffff !important;
    border: 1px solid var(--border-color) !important;
    color: var(--color-text-main) !important;
    border-radius: 12px !important;
    padding: 0.55rem 1rem 0.55rem 2.25rem !important;
    font-size: 0.875rem !important;
    min-width: 240px !important;
    transition: var(--transition-smooth) !important;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.02) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: 12px center !important;
    background-size: 15px !important;
}

.dataTables_filter input:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.1) !important;
    outline: none !important;
}

/* Page Length Selector (.dataTables_length) */
.dataTables_length {
    margin: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
}

.dataTables_length label {
    display: flex !important;
    align-items: center !important;
    margin-bottom: 0 !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    color: var(--color-text-muted) !important;
    gap: 0.5rem !important;
}

/* Override Select2 container inside length menu */
.dataTables_length .select2-container {
    font-weight: 600 !important;
}

.dataTables_length .select2-selection--single {
    background-color: #ffffff !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 10px !important;
    height: 38px !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 0.5rem !important;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.02) !important;
    transition: var(--transition-smooth) !important;
}

.dataTables_length .select2-selection--single:hover {
    border-color: rgba(15, 23, 42, 0.25) !important;
}

.dataTables_length .select2-selection__rendered {
    color: var(--color-text-main) !important;
    padding-right: 1.5rem !important;
}

/* Export Buttons (.dt-buttons) styling */
.dt-buttons,
.dataTables_wrapper .dt-buttons {
    display: inline-flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin: 0 !important;
}

.dt-buttons .dt-button,
.dataTables_wrapper .dt-buttons .dt-button {
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    padding: 0.55rem 1rem !important;
    border-radius: 10px !important;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
    margin: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Color Code Buttons for Premium Feel */
.dt-buttons .buttons-copy,
.dataTables_wrapper .dt-buttons .buttons-copy {
    color: #4f46e5 !important;
    border: 1px solid rgba(79, 70, 229, 0.15) !important;
    background: rgba(79, 70, 229, 0.03) !important;
}

.dt-buttons .buttons-copy:hover,
.dataTables_wrapper .dt-buttons .buttons-copy:hover {
    background: #4f46e5 !important;
    color: #ffffff !important;
    border-color: #4f46e5 !important;
    box-shadow: 0 4px 12px rgba(79, 70, 229, 0.15) !important;
    transform: translateY(-1px);
}

.dt-buttons .buttons-excel,
.dataTables_wrapper .dt-buttons .buttons-excel {
    color: #16a34a !important;
    border: 1px solid rgba(22, 163, 74, 0.15) !important;
    background: rgba(22, 163, 74, 0.03) !important;
}

.dt-buttons .buttons-excel:hover,
.dataTables_wrapper .dt-buttons .buttons-excel:hover {
    background: #16a34a !important;
    color: #ffffff !important;
    border-color: #16a34a !important;
    box-shadow: 0 4px 12px rgba(22, 163, 74, 0.15) !important;
    transform: translateY(-1px);
}

.dt-buttons .buttons-pdf,
.dataTables_wrapper .dt-buttons .buttons-pdf {
    color: #dc2626 !important;
    border: 1px solid rgba(220, 38, 38, 0.15) !important;
    background: rgba(220, 38, 38, 0.03) !important;
}

.dt-buttons .buttons-pdf:hover,
.dataTables_wrapper .dt-buttons .buttons-pdf:hover {
    background: #dc2626 !important;
    color: #ffffff !important;
    border-color: #dc2626 !important;
    box-shadow: 0 4px 12px rgba(22, 163, 74, 0.15) !important;
    transform: translateY(-1px);
}

/* Visibility dropdown button styling */
.dt-buttons .buttons-colvis,
.dataTables_wrapper .dt-buttons .buttons-colvis {
    color: #0284c7 !important;
    border: 1px solid rgba(2, 132, 199, 0.15) !important;
    background: rgba(2, 132, 199, 0.03) !important;
}

.dt-buttons .buttons-colvis:hover,
.dataTables_wrapper .dt-buttons .buttons-colvis:hover {
    background: #0284c7 !important;
    color: #ffffff !important;
    border-color: #0284c7 !important;
    box-shadow: 0 4px 12px rgba(2, 132, 199, 0.15) !important;
    transform: translateY(-1px);
}

/* Page Info Text */
.dataTables_info {
    color: var(--color-text-muted) !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

/* Pagination Control (.dataTables_paginate) */
.dataTables_paginate {
    display: inline-flex !important;
    gap: 6px !important;
    align-items: center !important;
}

.dataTables_paginate .paginate_button {
    padding: 0 !important;
    min-width: 36px !important;
    height: 36px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 10px !important;
    border: 1px solid var(--border-color) !important;
    background: #ffffff !important;
    color: #475569 !important;
    font-weight: 600 !important;
    font-size: 0.85rem !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    margin: 0 !important;
}

.dataTables_paginate .paginate_button:hover {
    background: rgba(37, 99, 235, 0.05) !important;
    color: var(--color-primary) !important;
    border-color: rgba(37, 99, 235, 0.2) !important;
}

.dataTables_paginate .paginate_button.current,
.dataTables_paginate .paginate_button.current:hover {
    background: linear-gradient(135deg, var(--color-primary), var(--color-secondary)) !important;
    color: #ffffff !important;
    border-color: transparent !important;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.2) !important;
}

.dataTables_paginate .paginate_button.disabled,
.dataTables_paginate .paginate_button.disabled:hover {
    opacity: 0.4 !important;
    background: #f8fafc !important;
    color: #94a3b8 !important;
    border-color: var(--border-color) !important;
    cursor: not-allowed !important;
    box-shadow: none !important;
}

/* Modern Empty State */
.dataTables_wrapper .dataTables_empty {
    padding: 3rem 1.5rem !important;
    font-weight: 500 !important;
    color: var(--color-text-muted) !important;
    background-color: #ffffff !important;
    font-size: 0.925rem !important;
}

