/* Custom Bootstrap 5 Colors - Modern Template Optimized */
:root {
    /* Primary - Deep Blue (matches gradient) */
    --bs-primary: #667eea;
    --bs-primary-rgb: 102, 126, 234;
    --bs-primary-hover: #5a67d8;

    /* Secondary - Purple (matches gradient) */
    --bs-secondary: #764ba2;
    --bs-secondary-rgb: 118, 75, 162;
    --bs-secondary-hover: #5d3a7f;

    /* Success - Modern Teal */
    --bs-success: #10b981;
    --bs-success-rgb: 16, 185, 129;
    --bs-success-hover: #059669;

    /* Info - Sky Blue */
    --bs-info: #06b6d4;
    --bs-info-rgb: 6, 182, 212;
    --bs-info-hover: #0891b2;

    /* Warning - Amber */
    --bs-warning: #f59e0b;
    --bs-warning-rgb: 245, 158, 11;
    --bs-warning-hover: #d97706;
    --bs-warning-dark: #b45309; /* Darker warning for better contrast */

    /* Danger - Modern Red */
    --bs-danger: #ef4444;
    --bs-danger-rgb: 239, 68, 68;
    --bs-danger-hover: #dc2626;
    --bs-danger-dark: #b91c1c; /* Darker red for better contrast */

    /* Light & Dark - Refined */
    --bs-light: #f8fafc;
    --bs-light-rgb: 248, 250, 252;
    --bs-dark: #1e293b;
    --bs-dark-rgb: 30, 41, 59;

    /* Contrast-aware color variants */
    --bs-primary-dark: #4338ca;
    --bs-secondary-dark: #5b21b6;
    --bs-success-dark: #047857;
    --bs-info-dark: #0369a1;

    /* Custom Template Colors */
    --template-gradient-start: #667eea;
    --template-gradient-end: #764ba2;
    --template-accent: #8b5cf6;
    --template-muted: #64748b;
    --template-surface: #ffffff;
    --template-background: #f1f5f9;

    /* Subtle Background Colors */
    --bs-primary-subtle: rgba(102, 126, 234, 0.1);
    --bs-secondary-subtle: rgba(118, 75, 162, 0.1);
    --bs-success-subtle: rgba(16, 185, 129, 0.1);
    
    /* Additional Custom Colors for Modal */
    --bs-purple: #8b5cf6;
    --bs-purple-rgb: 139, 92, 246;
    --bs-indigo: #6366f1;
    --bs-indigo-rgb: 99, 102, 241;
    --bs-teal: #14b8a6;
    --bs-teal-rgb: 20, 184, 166;
    --bs-emerald: #10b981;
    --bs-emerald-rgb: 16, 185, 129;
    --bs-orange: #f97316;
    --bs-orange-rgb: 249, 115, 22;
    --bs-slate: #64748b;
    --bs-slate-rgb: 100, 116, 139;
    --bs-info-subtle: rgba(6, 182, 212, 0.1);
    --bs-warning-subtle: rgba(245, 158, 11, 0.1);
    --bs-danger-subtle: rgba(239, 68, 68, 0.1);

    /* Focus ring colors */
    --bs-focus-ring-width: 0.25rem;
    --bs-focus-ring-opacity: 0.25;
    --bs-focus-ring-color-primary: rgba(var(--bs-primary-rgb), var(--bs-focus-ring-opacity));
    --bs-focus-ring-color-secondary: rgba(var(--bs-secondary-rgb), var(--bs-focus-ring-opacity));
    --bs-focus-ring-color-success: rgba(var(--bs-success-rgb), var(--bs-focus-ring-opacity));
    --bs-focus-ring-color-info: rgba(var(--bs-info-rgb), var(--bs-focus-ring-opacity));
    --bs-focus-ring-color-warning: rgba(var(--bs-warning-rgb), var(--bs-focus-ring-opacity));
    --bs-focus-ring-color-danger: rgba(var(--bs-danger-rgb), var(--bs-focus-ring-opacity));
}

/* Buttons */
.btn-primary {
    background-color: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
}
.btn-primary:hover {
    background-color: var(--bs-primary-hover) !important;
}

.btn-secondary {
    background-color: var(--bs-secondary) !important;
    border-color: var(--bs-secondary) !important;
}
.btn-secondary:hover {
    background-color: var(--bs-secondary-hover) !important;
}

.btn-success {
    background-color: var(--bs-success) !important;
    border-color: var(--bs-success) !important;
}
.btn-success:hover {
    background-color: var(--bs-success-hover) !important;
}

.btn-info {
    background-color: var(--bs-info) !important;
    border-color: var(--bs-info) !important;
}
.btn-info:hover {
    background-color: var(--bs-info-hover) !important;
}

.btn-warning {
    background-color: var(--bs-warning) !important;
    border-color: var(--bs-warning) !important;
}
.btn-warning:hover {
    background-color: var(--bs-warning-hover) !important;
}

.btn-danger {
    background-color: var(--bs-danger) !important;
    border-color: var(--bs-danger) !important;
}
.btn-danger:hover {
    background-color: var(--bs-danger-hover) !important;
}

/* Background utilities */
.bg-primary { background-color: var(--bs-primary) !important; }
.bg-secondary { background-color: var(--bs-secondary) !important; }
.bg-success { background-color: var(--bs-success) !important; }
.bg-info { background-color: var(--bs-info) !important; }
.bg-warning { background-color: var(--bs-warning) !important; }
.bg-danger { background-color: var(--bs-danger) !important; }
.bg-light { background-color: var(--bs-light) !important; }
.bg-dark { background-color: var(--bs-dark) !important; }

/* Subtle Background utilities */
.bg-primary-subtle { background-color: var(--bs-primary-subtle) !important; }
.bg-secondary-subtle { background-color: var(--bs-secondary-subtle) !important; }
.bg-success-subtle { background-color: var(--bs-success-subtle) !important; }
.bg-info-subtle { background-color: var(--bs-info-subtle) !important; }
.bg-warning-subtle { background-color: var(--bs-warning-subtle) !important; }
.bg-danger-subtle { background-color: var(--bs-danger-subtle) !important; }

/* Template Gradient Backgrounds */
.bg-gradient-primary {
    background: linear-gradient(135deg, var(--template-gradient-start) 0%, var(--template-gradient-end) 100%) !important;
}
.bg-gradient-secondary {
    background: linear-gradient(135deg, var(--bs-secondary) 0%, var(--bs-primary) 100%) !important;
}
.bg-gradient-success {
    background: linear-gradient(135deg, var(--bs-success) 0%, #0d9488 100%) !important;
}
.bg-gradient-info {
    background: linear-gradient(135deg, var(--bs-info) 0%, #0284c7 100%) !important;
}
.bg-gradient-warning {
    background: linear-gradient(135deg, var(--bs-warning) 0%, #ea580c 100%) !important;
}
.bg-gradient-danger {
    background: linear-gradient(135deg, var(--bs-danger) 0%, #b91c1c 100%) !important;
}

/* Text utilities */
.text-primary { color: var(--bs-primary) !important; }
.text-secondary { color: var(--bs-secondary) !important; }
.text-success { color: var(--bs-success) !important; }
.text-info { color: var(--bs-info) !important; }
.text-warning { color: var(--bs-warning) !important; }
.text-danger { color: var(--bs-danger) !important; }
.text-light { color: var(--bs-light) !important; }
.text-dark { color: var(--bs-dark) !important; }

/* Contrast-aware color combinations for better visibility */
/* Light backgrounds should have darker text */
.bg-primary-subtle .text-primary { color: #4338ca !important; } /* Darker blue on light blue */
.bg-secondary-subtle .text-secondary { color: #5b21b6 !important; } /* Darker purple on light purple */
.bg-success-subtle .text-success { color: #047857 !important; } /* Darker green on light green */
.bg-info-subtle .text-info { color: #0369a1 !important; } /* Darker cyan on light cyan */
.bg-warning-subtle .text-warning { color: #b45309 !important; } /* Darker orange on light orange */
.bg-danger-subtle .text-danger { color: #b91c1c !important; } /* Darker red on light red */

/* Dark backgrounds should have white text */
.bg-primary, .bg-secondary, .bg-success, .bg-info, .bg-warning, .bg-danger, .bg-dark {
    color: #ffffff !important;
}

/* Specific overrides for warning combinations */
.bg-warning .text-white { color: #ffffff !important; }
.bg-warning-subtle { 
    background-color: rgba(245, 158, 11, 0.1) !important; 
    color: #b45309 !important; 
}

/* Better warning text on warning background */
.bg-warning.bg-opacity-10, 
.bg-warning.bg-opacity-15,
.bg-warning.bg-opacity-20 {
    color: #b45309 !important; /* Dark orange text on light warning background */
}

/* Ensure readable combinations */
.bg-warning.bg-opacity-10 .text-warning,
.bg-warning.bg-opacity-15 .text-warning,
.bg-warning.bg-opacity-20 .text-warning {
    color: #b45309 !important; /* Force darker warning color */
}

/* Override Bootstrap's default warning text color when on light warning background */
.bg-warning-subtle, 
.bg-warning.bg-opacity-10,
.bg-warning.bg-opacity-15,
.bg-warning.bg-opacity-20 {
    --bs-warning: #b45309;
}

/* Similar fixes for other colors */
.bg-primary.bg-opacity-10 .text-primary,
.bg-primary.bg-opacity-15 .text-primary,
.bg-primary.bg-opacity-20 .text-primary { color: #4338ca !important; }

.bg-success.bg-opacity-10 .text-success,
.bg-success.bg-opacity-15 .text-success,
.bg-success.bg-opacity-20 .text-success { color: #047857 !important; }

.bg-info.bg-opacity-10 .text-info,
.bg-info.bg-opacity-15 .text-info,
.bg-info.bg-opacity-20 .text-info { color: #0369a1 !important; }

.bg-danger.bg-opacity-10 .text-danger,
.bg-danger.bg-opacity-15 .text-danger,
.bg-danger.bg-opacity-20 .text-danger { color: #b91c1c !important; }

/* Focus Ring Customization */
.btn:focus, .form-control:focus {
    box-shadow: 0 0 0 var(--bs-focus-ring-width) var(--bs-focus-ring-color-primary);
}
.btn-primary:focus {
    box-shadow: 0 0 0 var(--bs-focus-ring-width) var(--bs-focus-ring-color-primary);
}
.btn-secondary:focus {
    box-shadow: 0 0 0 var(--bs-focus-ring-width) var(--bs-focus-ring-color-secondary);
}
.btn-success:focus {
    box-shadow: 0 0 0 var(--bs-focus-ring-width) var(--bs-focus-ring-color-success);
}
.btn-info:focus {
    box-shadow: 0 0 0 var(--bs-focus-ring-width) var(--bs-focus-ring-color-info);
}
.btn-warning:focus {
    box-shadow: 0 0 0 var(--bs-focus-ring-width) var(--bs-focus-ring-color-warning);
}
.btn-danger:focus {
    box-shadow: 0 0 0 var(--bs-focus-ring-width) var(--bs-focus-ring-color-danger);
}


.progress-bar{
    background-color: var(--bs-success);
}



/* Custom CSS overrides for Bootstrap card components using !important */

/* Override for the entire card */
.card {
    /*background-color: #f8f9fa !important; */
    border: 1px solid #dee2e6 !important; /* Default border but enforced */
    border-radius: 0.5rem !important; /* Slightly rounded corners */
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important; /* Subtle shadow */
}

/* Override for card header */
.card-header {
    background: linear-gradient(135deg, var(--template-gradient-start) 0%, var(--template-gradient-end) 100%) !important;
    color: #ffffff !important;
    padding: 1rem !important;
    justify-content: space-between !important;
    align-items: center !important;
    border-bottom: 1px solid #dee2e6 !important;
    border-top-left-radius: 0.5rem !important;
    border-top-right-radius: 0.5rem !important;
    border: none !important;
    position: relative !important;
}

.card-header.bg-light {
    background: #f8fafc !important;
    color: #1e293b !important;
}

/* Specific overrides for elements inside header */
.card-header h5 {
    margin-bottom: 0 !important;
    font-weight: 600 !important; /* fw-semibold is font-weight: 600 */
    /* color: inherit !important;  */
}

.card-header .btn-group .btn {
    font-size: 0.875rem !important; /* btn-sm */
    border: 1px solid #007bff !important; /* btn-outline-primary border */
    /*color: #007bff !important;*/
    /*background-color: transparent !important;*/
}

.card-header .btn-group .btn:hover {
    color: #ffffff !important;
    background-color: #007bff !important;
    border-color: #007bff !important;
}

/* Override for card body */
.card-body {
    padding: 1.25rem !important; /* Default Bootstrap padding but enforced */
    /*background-color: #ffffff !important; */
    /*color: #212529 !important; /* Dark text */
}

/* Modern Template Enhancements */

/* Enhanced Card Styles */
.card-modern {
    border: none !important;
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.1) !important;
    border-radius: 1rem !important;
    transition: all 0.3s ease !important;
}

.card-modern:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.15) !important;
}

/* Modern Badge Styles */
.badge-modern {
    padding: 0.5em 1em !important;
    border-radius: 2rem !important;
    font-weight: 500 !important;
    font-size: 0.75rem !important;
}

/* Modern Button Enhancements */
.btn-modern {
    border-radius: 0.75rem !important;
    padding: 0.75rem 1.5rem !important;
    font-weight: 600 !important;
    transition: all 0.3s ease !important;
    border: none !important;
    box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.1) !important;
}

.btn-modern:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;
}

/* Progress Bar Enhancements */
.progress-modern {
    height: 0.75rem !important;
    border-radius: 1rem !important;
    background-color: var(--bs-light) !important;
    overflow: hidden !important;
}

.progress-modern .progress-bar {
    border-radius: 1rem !important;
    background: linear-gradient(45deg, var(--bs-primary), var(--bs-secondary)) !important;
    transition: width 0.6s ease !important;
}

/* Table Enhancements */
.table-modern {
    border-radius: 0.75rem !important;
    overflow: hidden !important;
    box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.05) !important;
}

.table-modern thead th {
    background: linear-gradient(135deg, var(--bs-light), #e2e8f0) !important;
    border: none !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    font-size: 0.75rem !important;
    letter-spacing: 0.05em !important;
    color: var(--template-muted) !important;
}

.table-modern tbody tr {
    border: none !important;
    transition: background-color 0.2s ease !important;
}

.table-modern tbody tr:hover {
    background-color: var(--bs-primary-subtle) !important;
}

/* Modern Form Styles */
.form-modern .form-control {
    border: 2px solid #e2e8f0 !important;
    border-radius: 0.75rem !important;
    padding: 0.75rem 1rem !important;
    transition: all 0.3s ease !important;
}

.form-modern .form-control:focus {
    border-color: var(--bs-primary) !important;
    box-shadow: 0 0 0 0.2rem var(--bs-focus-ring-color-primary) !important;
    transform: translateY(-1px) !important;
}

/* Modern Alert Styles */
.alert-modern {
    border: none !important;
    border-radius: 1rem !important;
    border-left: 4px solid !important;
    padding: 1rem 1.5rem !important;
    font-weight: 500 !important;
}

.alert-modern.alert-primary {
    background-color: var(--bs-primary-subtle) !important;
    border-left-color: var(--bs-primary) !important;
    color: var(--bs-primary) !important;
}

.alert-modern.alert-success {
    background-color: var(--bs-success-subtle) !important;
    border-left-color: var(--bs-success) !important;
    color: var(--bs-success) !important;
}

.alert-modern.alert-warning {
    background-color: var(--bs-warning-subtle) !important;
    border-left-color: var(--bs-warning) !important;
    color: var(--bs-warning) !important;
}

.alert-modern.alert-danger {
    background-color: var(--bs-danger-subtle) !important;
    border-left-color: var(--bs-danger) !important;
    color: var(--bs-danger) !important;
}

/* Modern Avatar Styles */
.avatar-modern {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    background: linear-gradient(135deg, var(--bs-primary), var(--bs-secondary)) !important;
    color: white !important;
    font-weight: 600 !important;
    box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.1) !important;
}

/* Utility Classes */
.text-gradient {
    background: linear-gradient(135deg, var(--bs-primary), var(--bs-secondary)) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    font-weight: 700 !important;
}

.shadow-modern {
    box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.1) !important;
}

.shadow-modern-lg {
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.15) !important;
}

/* Additional Color Classes for Modal */
.text-purple { color: var(--bs-purple) !important; }
.bg-purple { background-color: var(--bs-purple) !important; }
.bg-purple.bg-opacity-10 { background-color: rgba(var(--bs-purple-rgb), 0.1) !important; }
.bg-purple.bg-opacity-15 { background-color: rgba(var(--bs-purple-rgb), 0.15) !important; }

.text-indigo { color: var(--bs-indigo) !important; }
.bg-indigo { background-color: var(--bs-indigo) !important; }
.bg-indigo.bg-opacity-8 { background-color: rgba(var(--bs-indigo-rgb), 0.08) !important; }
.bg-indigo.bg-opacity-15 { background-color: rgba(var(--bs-indigo-rgb), 0.15) !important; }

.text-teal { color: var(--bs-teal) !important; }
.bg-teal { background-color: var(--bs-teal) !important; }
.bg-teal.bg-opacity-8 { background-color: rgba(var(--bs-teal-rgb), 0.08) !important; }
.bg-teal.bg-opacity-15 { background-color: rgba(var(--bs-teal-rgb), 0.15) !important; }

.text-emerald { color: var(--bs-emerald) !important; }
.bg-emerald { background-color: var(--bs-emerald) !important; }
.bg-emerald.bg-opacity-8 { background-color: rgba(var(--bs-emerald-rgb), 0.08) !important; }
.bg-emerald.bg-opacity-15 { background-color: rgba(var(--bs-emerald-rgb), 0.15) !important; }

.text-orange { color: var(--bs-orange) !important; }
.bg-orange { background-color: var(--bs-orange) !important; }
.bg-orange.bg-opacity-8 { background-color: rgba(var(--bs-orange-rgb), 0.08) !important; }
.bg-orange.bg-opacity-15 { background-color: rgba(var(--bs-orange-rgb), 0.15) !important; }

.text-slate { color: var(--bs-slate) !important; }
.bg-slate { background-color: var(--bs-slate) !important; }
.bg-slate.bg-opacity-8 { background-color: rgba(var(--bs-slate-rgb), 0.08) !important; }
.bg-slate.bg-opacity-15 { background-color: rgba(var(--bs-slate-rgb), 0.15) !important; }
.bg-slate.bg-opacity-20 { background-color: rgba(var(--bs-slate-rgb), 0.2) !important; }

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

::-webkit-scrollbar-track {
    background: var(--bs-light);
    border-radius: 10px;
}

::-webkit-scrollbar-thumb {
    background: linear-gradient(135deg, var(--bs-primary), var(--bs-secondary));
    border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(135deg, var(--bs-primary-hover), var(--bs-secondary-hover));
}

/* ============================================================================
   PERMISSIONS MODAL STYLES - Centralized from inline styles
   ============================================================================ */

/* Enhanced Premium Modal Styles */
.permissions-modal .modal-content {
    border-radius: 20px;
    border: none;
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(10px);
}

.permissions-modal .modal-header {
    border-radius: 20px 20px 0 0;
    position: relative;
    overflow: hidden;
}

.permissions-modal .modal-header::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(45deg, rgba(255,255,255,0.1) 0%, transparent 100%);
    pointer-events: none;
}

.modern-permissions-table {
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.modern-permissions-table thead th {
    background: linear-gradient(135deg, #f8f9fa, #e9ecef);
    border: none;
    font-weight: 600;
    color: #495057;
    padding: 20px 24px;
}

.modern-permissions-table tbody tr {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.modern-permissions-table tbody tr:hover {
    background-color: #f8f9fa;
}

.modern-permissions-table tbody td {
    padding: 20px 24px;
    vertical-align: middle;
    border: none;
}

/* Dark mode support for permissions modal and table */
html[data-bs-theme="dark"] .permissions-modal .modal-content {
    background-color: #2e2d2d !important;
    color: #e9ecef !important;
}

html[data-bs-theme="dark"] .permissions-modal .modal-body {
    background-color: #2e2d2d !important;
    color: #e9ecef !important;
}

html[data-bs-theme="dark"] .modern-permissions-table {
    background-color: #2e2d2d !important;
    color: #e9ecef !important;
}

html[data-bs-theme="dark"] .modern-permissions-table thead th {
    background: linear-gradient(135deg, #343a40, #495057) !important;
    color: #e9ecef !important;
}

html[data-bs-theme="dark"] .modern-permissions-table tbody td {
    color: #e9ecef !important;
}

html[data-bs-theme="dark"] .modern-permissions-table tbody tr:hover {
    background-color: #495057 !important;
}

/* Force all text in permissions modal to be visible in dark mode */
html[data-bs-theme="dark"] .permissions-modal * {
    color: #e9ecef !important;
}

html[data-bs-theme="dark"] .permissions-modal .fw-semibold,
html[data-bs-theme="dark"] .permissions-modal .permission-name,
html[data-bs-theme="dark"] .permissions-modal td,
html[data-bs-theme="dark"] .permissions-modal th {
    color: #e9ecef !important;
}

/* Fix modal footer text in dark mode */
html[data-bs-theme="dark"] .permissions-modal .modal-footer {
    background-color: #343a40 !important;
    color: #e9ecef !important;
}

html[data-bs-theme="dark"] .permissions-modal .modal-footer .text-muted,
html[data-bs-theme="dark"] .permissions-modal .modal-footer small,
html[data-bs-theme="dark"] .permissions-modal .modal-footer span {
    color: #adb5bd !important;
}

/* Fix main table permission names in dark mode (outside modal) */
html[data-bs-theme="dark"] .table tbody td,
html[data-bs-theme="dark"] .table-modern tbody td,
html[data-bs-theme="dark"] .modern-table tbody td {
    color: #e9ecef !important;
}

html[data-bs-theme="dark"] .table thead th,
html[data-bs-theme="dark"] .table-modern thead th,
html[data-bs-theme="dark"] .modern-table thead th {
    color: #e9ecef !important;
}

/* Premium Toggle Switches */
.permission-toggle {
    position: relative;
    display: inline-block;
    width: 60px;
    height: 30px;
}

.permission-toggle input {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, #e9ecef, #dee2e6);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    border-radius: 30px;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.toggle-slider:before {
    position: absolute;
    content: "";
    height: 24px;
    width: 24px;
    left: 3px;
    bottom: 3px;
    background: linear-gradient(135deg, #ffffff, #f8f9fa);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.permission-toggle input:checked + .toggle-slider {
    background: linear-gradient(135deg, #667eea, #764ba2);
    box-shadow: 0 0 20px rgba(102, 126, 234, 0.3);
}

.permission-toggle input:checked + .toggle-slider:before {
    transform: translateX(30px);
    background: linear-gradient(135deg, #ffffff, #f8f9fa);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.permission-toggle:hover .toggle-slider {
    box-shadow: 0 0 20px rgba(102, 126, 234, 0.2);
}

.permission-name {
    font-weight: 500;
    color: #495057;
    display: flex;
    align-items: center;
    gap: 12px;
}

/* Dark mode support for permission names */
html[data-bs-theme="dark"] .permission-name {
    color: #e9ecef !important;
}

.permission-icon {
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.1), rgba(118, 75, 162, 0.1));
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #667eea;
}

.permission-description {
    font-size: 0.85rem;
    color: #6c757d;
    margin-top: 4px;
}

/* Dark mode support for permission descriptions */
html[data-bs-theme="dark"] .permission-description {
    color: #adb5bd !important;
}

.shadow-2xl {
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.avatar-lg {
    width: 60px;
    height: 60px;
    border-radius: 15px;
}

.rounded-4 {
    border-radius: 15px;
}

/* Animation for modal entrance */
.permissions-modal.modal.fade .modal-dialog {
    transform: scale(0.8) translateY(-50px);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.permissions-modal.modal.show .modal-dialog {
    transform: scale(1) translateY(0);
}

/* Enhanced Text Contrast and Visibility */

/* Ensure white text on dark backgrounds */
.bg-primary, .bg-gradient-primary,
.bg-secondary, .bg-gradient-secondary,
.bg-success, .bg-gradient-success,
.bg-info, .bg-gradient-info,
.bg-warning, .bg-gradient-warning,
.bg-danger, .bg-gradient-danger,
.bg-dark, .bg-purple, .bg-indigo,
.bg-teal, .bg-emerald, .bg-orange {
    color: #ffffff !important;
}

/* Ensure white text on gradient headers */
.card-header,
.modal-header,
.bg-gradient-primary,
.bg-gradient-secondary,
.bg-gradient-success,
.bg-gradient-info,
.bg-gradient-warning,
.bg-gradient-danger {
    color: #ffffff !important;
}

/* Ensure dark text on light backgrounds */
.bg-light,
.bg-white,
.card-body,
.modal-body,
.bg-primary-subtle,
.bg-secondary-subtle,
.bg-success-subtle,
.bg-info-subtle,
.bg-warning-subtle,
.bg-danger-subtle,
.bg-purple.bg-opacity-10,
.bg-purple.bg-opacity-15,
.bg-indigo.bg-opacity-8,
.bg-indigo.bg-opacity-15,
.bg-teal.bg-opacity-8,
.bg-teal.bg-opacity-15,
.bg-emerald.bg-opacity-8,
.bg-emerald.bg-opacity-15,
.bg-orange.bg-opacity-8,
.bg-orange.bg-opacity-15,
.bg-slate.bg-opacity-8,
.bg-slate.bg-opacity-15,
.bg-slate.bg-opacity-20 {
    color: #1e293b !important;
}

/* Specific text color overrides for better visibility */
.text-on-white {
    color: #1e293b !important;
}

.text-on-dark {
    color: #ffffff !important;
}

.text-on-gradient {
    color: #ffffff !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1) !important;
}

/* Button text contrast */
.btn-primary, .btn-secondary, .btn-success, 
.btn-info, .btn-warning, .btn-danger, 
.btn-dark, .btn-purple, .btn-indigo,
.btn-teal, .btn-emerald, .btn-orange {
    color: #ffffff !important;
}

.btn-light, .btn-outline-primary, .btn-outline-secondary,
.btn-outline-success, .btn-outline-info, .btn-outline-warning,
.btn-outline-danger, .btn-outline-dark {
    color: #1e293b !important;
}

/* Table text contrast */
.table thead th {
    color: #475569 !important;
}

.table tbody td {
    color: #1e293b !important;
}

.table-dark thead th,
.table-dark tbody td {
    color: #ffffff !important;
}

/* Badge text contrast */
.badge {
    font-weight: 600 !important;
}

.badge.bg-light,
.badge.bg-white,
.badge[style*="background-color: #f8f9fa"],
.badge[style*="background-color: #ffffff"] {
    color: #1e293b !important;
}

/* Form text contrast */
.form-control {
    color: #1e293b !important;
}

.form-control::placeholder {
    color: #64748b !important;
}

/* Alert text contrast enhancements */
.alert {
    font-weight: 500 !important;
}

.alert-light {
    color: #1e293b !important;
}

/* Navbar text contrast */
.navbar-dark .navbar-nav .nav-link,
.navbar-dark .navbar-brand {
    color: #ffffff !important;
}

.navbar-light .navbar-nav .nav-link,
.navbar-light .navbar-brand {
    color: #1e293b !important;
}

/* Card text improvements */
.card-title {
    color: inherit !important;
    font-weight: 600 !important;
}

.card-text {
    color: inherit !important;
}

/* Modal text improvements */
.modal-title {
    color: inherit !important;
    font-weight: 600 !important;
}

/* Dropdown text contrast */
.dropdown-menu {
    color: #1e293b !important;
}

.dropdown-item {
    color: #1e293b !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: var(--bs-primary-subtle) !important;
    color: var(--bs-primary) !important;
}

/* Dark mode dropdown fixes */
html[data-bs-theme="dark"] .dropdown-menu {
    background-color: #2e2d2d !important;
    color: #e9ecef !important;
    border: 1px solid #495057 !important;
}

html[data-bs-theme="dark"] .dropdown-item {
    color: #e9ecef !important;
}

html[data-bs-theme="dark"] .dropdown-item:hover,
html[data-bs-theme="dark"] .dropdown-item:focus {
    background-color: #495057 !important;
    color: #ffffff !important;
}

html[data-bs-theme="dark"] .dropdown-header {
    background-color: #343a40 !important;
    color: #e9ecef !important;
    border-bottom: 1px solid #495057 !important;
}

html[data-bs-theme="dark"] .dropdown-divider {
    border-color: #495057 !important;
}

/* User dropdown specific fixes */
html[data-bs-theme="dark"] .user-dropdown-btn {
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    color: #e9ecef !important;
}

html[data-bs-theme="dark"] .user-dropdown-btn .text-muted {
    color: #adb5bd !important;
}

html[data-bs-theme="dark"] .user-dropdown-btn .user-name-text {
    color: #e9ecef !important;
}

/* List group text contrast */
.list-group-item {
    color: #1e293b !important;
}

.list-group-item-primary {
    color: var(--bs-primary) !important;
}

.list-group-item-success {
    color: var(--bs-success) !important;
}

.list-group-item-warning {
    color: var(--bs-warning) !important;
}

.list-group-item-danger {
    color: var(--bs-danger) !important;
}

/* Breadcrumb text contrast */
.breadcrumb-item {
    color: #64748b !important;
}

.breadcrumb-item.active {
    color: #1e293b !important;
}

/* Pagination text contrast */
.page-link {
    color: var(--bs-primary) !important;
}

.page-item.active .page-link {
    color: #ffffff !important;
}

/* Progress bar text */
.progress-bar {
    color: #ffffff !important;
    font-weight: 600 !important;
}

/* Toast text contrast */
.toast {
    color: #1e293b !important;
}

.toast-header {
    color: #1e293b !important;
}

/* Tooltip and popover text */
.tooltip-inner {
    color: #ffffff !important;
}

.popover-body {
    color: #1e293b !important;
}

/* Ensure visibility in all working contexts */
.working-text,
.status-text,
.dynamic-text {
    font-weight: 600 !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1) !important;
}

/* High contrast utility classes */
.text-high-contrast-light {
    color: #ffffff !important;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.8) !important;
}

.text-high-contrast-dark {
    color: #1e293b !important;
    text-shadow: 1px 1px 2px rgba(255, 255, 255, 0.8) !important;
}

/* Specific contrast for interactive elements */
a, .btn, .nav-link, .dropdown-item {
    transition: all 0.2s ease !important;
}

/* Ensure readability in all states */
*:not(.btn):not(.badge):not(.alert) {
    text-rendering: optimizeLegibility !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
}

/* Avatar Fix - Simple circular avatars */
.avatar-xl, .avatar-lg, .avatar-sm {
    width: auto;
    height: auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.avatar-xl { width: 4rem; height: 4rem; }
.avatar-lg { width: 3.5rem; height: 3.5rem; }
.avatar-sm { width: 2.5rem; height: 2.5rem; }

.avatar-title {
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
}

/* Hamburger Menu Button - Dynamic Theming */
.topnav-hamburger {
    border: none !important;
    background: transparent !important;
}

/* Light header - dark button background, light lines */
[data-bs-theme="light"] .topnav-hamburger {
    background-color: #1e293b !important;
}

[data-bs-theme="light"] .topnav-hamburger .hamburger-icon span {
    background-color: #ffffff !important;
}

/* Dark header - light button background, dark lines */
[data-bs-theme="dark"] .topnav-hamburger {
    background-color: #ffffff !important;
}

[data-bs-theme="dark"] .topnav-hamburger .hamburger-icon span {
    background-color: #1e293b !important;
}

/* Hamburger icon styling */
.hamburger-icon {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 20px;
    height: 16px;
    position: relative;
}

.hamburger-icon span {
    display: block;
    height: 2px;
    width: 100%;
    border-radius: 1px;
    transform-origin: center;
}

/* All hover effects disabled */
/*
.topnav-hamburger:hover {
    transform: scale(1.05);
    opacity: 0.8;
}

.topnav-hamburger:active {
    transform: scale(0.95);
}

.hamburger-icon span {
    transition: all 0.3s ease;
}

.topnav-hamburger {
    transition: all 0.3s ease !important;
}
*/



