/* Modern Compact Design with Sleek Sidebar */

/* Base Reset - Compact and Clean */
* {
    box-sizing: border-box !important;
    margin: 0;
    padding: 0;
}

:root {
    --primary: #2563eb;
    --primary-dark: #1d4ed8;
    --secondary: #f1f5f9;
    --accent: #7c3aed;
    --text: #1e293b;
    --text-light: #64748b;
    --border: #e2e8f0;
    --success: #10b981;
    --warning: #f59e0b;
    --danger: #ef4444;
    --white: #ffffff;
    --sidebar-width: 220px;
    --topbar-height: 56px;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    background: var(--secondary) !important;
    color: var(--text) !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    overflow-x: hidden !important;
}

/* Page System - Compact Layout */
.page {
    display: none !important;
    min-height: 100vh !important;
    width: 100% !important;
}

.page.active {
    display: flex !important;
    flex-direction: column !important;
}

/* Login Page - Modern & Minimal */
#loginPage {
    background: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%) !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 100vh !important;
    padding: 1rem !important;
}

#loginPage.active {
    display: flex !important;
}

.login-container {
    width: 100% !important;
    max-width: 400px !important;
}

.login-box {
    background: var(--white) !important;
    border-radius: 16px !important;
    padding: 2rem !important;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04) !important;
    backdrop-filter: blur(10px) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
}

.login-box h2 {
    text-align: center !important;
    margin-bottom: 1.5rem !important;
    color: var(--text) !important;
    font-weight: 700 !important;
    font-size: 1.5rem !important;
}

.input-group {
    margin-bottom: 1.25rem !important;
}

.input-group label {
    display: block !important;
    margin-bottom: 0.5rem !important;
    font-weight: 500 !important;
    color: var(--text-light) !important;
    font-size: 0.875rem !important;
}

.input-group input {
    width: 100% !important;
    padding: 0.75rem 1rem !important;
    border: 2px solid var(--border) !important;
    border-radius: 10px !important;
    font-size: 0.95rem !important;
    transition: all 0.2s ease !important;
    background: var(--white) !important;
}

.input-group input:focus {
    outline: none !important;
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1) !important;
}

.login-btn {
    width: 100% !important;
    padding: 0.75rem !important;
    background: var(--primary) !important;
    color: var(--white) !important;
    border: none !important;
    border-radius: 10px !important;
    font-weight: 600 !important;
    font-size: 1rem !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    margin-top: 0.5rem !important;
}

.login-btn:hover {
    background: var(--primary-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1) !important;
}

/* Dashboard Layout - Modern Compact */
#clientDashboardPage.active, #adminDashboardPage.active {
    display: flex !important;
    flex-direction: column !important;
    min-height: 100vh !important;
}

.dashboard-layout {
    display: flex !important;
    flex: 1 !important;
    background: var(--secondary) !important;
    overflow: hidden !important;
}

/* Sleek Sidebar */
.sidebar {
    width: var(--sidebar-width) !important;
    background: var(--white) !important;
    border-right: 1px solid var(--border) !important;
    display: flex !important;
    flex-direction: column !important;
    box-shadow: 2px 0 10px rgba(0, 0, 0, 0.03) !important;
    z-index: 100 !important;
    transition: all 0.3s ease !important;
}

/* Collapsed Sidebar State */
.sidebar.collapsed {
    width: 70px !important;
}

.sidebar.collapsed .sidebar-header span,
.sidebar.collapsed .nav-item span {
    display: none !important;
}

.sidebar.collapsed .sidebar-header {
    justify-content: center !important;
}

.sidebar.collapsed .sidebar-content {
    text-align: center !important;
}

.sidebar-header {
    padding: 1.25rem 1rem !important;
    border-bottom: 1px solid var(--border) !important;
    background: linear-gradient(to right, var(--primary), var(--accent)) !important;
    color: var(--white) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
}

.sidebar-header h2 {
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.sidebar-header h2::before {
    content: "📊" !important;
    font-size: 1.5rem !important;
}

.menu-container {
    flex: 1 !important;
    overflow-y: auto !important;
    padding: 0.75rem 0 !important;
}

.menu-list {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.menu-item {
    margin: 0 !important;
}

.menu-link {
    display: flex !important;
    align-items: center !important;
    padding: 0.75rem 1.25rem !important;
    color: var(--text-light) !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    border-left: 3px solid transparent !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    position: relative !important;
}

.menu-link:hover {
    background: var(--secondary) !important;
    color: var(--primary) !important;
    border-left-color: var(--primary) !important;
    transform: translateX(3px) !important;
}

.menu-link.active {
    background: rgba(37, 99, 235, 0.08) !important;
    color: var(--primary) !important;
    border-left-color: var(--primary) !important;
    font-weight: 600 !important;
}

.menu-link::before {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    width: 3px !important;
    background: var(--primary) !important;
    transform: scaleY(0) !important;
    transition: transform 0.2s ease !important;
}

.menu-link.active::before {
    transform: scaleY(1) !important;
}

.menu-icon {
    margin-right: 0.75rem !important;
    font-size: 1.1rem !important;
    width: 20px !important;
    text-align: center !important;
    opacity: 0.8 !important;
}

/* Main Content Area */
.main-content {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    background: var(--secondary) !important;
    min-width: 0 !important;
}

/* Modern Top Bar */
.top-bar {
    height: var(--topbar-height) !important;
    padding: 0 1.5rem !important;
    background: var(--white) !important;
    border-bottom: 1px solid var(--border) !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05) !important;
    z-index: 900 !important;
    position: sticky !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
}

.top-bar-left {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    flex: 1 !important;
}

.app-title {
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    color: var(--text) !important;
}

.user-info {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}

.user-avatar {
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: linear-gradient(135deg, var(--primary), var(--accent)) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--white) !important;
    font-weight: 600 !important;
    font-size: 0.8rem !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

.user-name {
    font-weight: 500 !important;
    color: var(--text) !important;
    font-size: 0.9rem !important;
}

.logout-btn {
    background: var(--danger) !important;
    color: var(--white) !important;
    border: none !important;
    padding: 0.5rem 1rem !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    font-weight: 500 !important;
    font-size: 0.85rem !important;
    transition: all 0.2s ease !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.logout-btn:hover {
    background: #dc2626 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1) !important;
}

/* Enhanced Client Dashboard Styles */

/* Top Bar Enhancements */
.top-bar {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 0 1.5rem !important;
}

.top-bar-left {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}

.top-bar-left h2 {
    margin: 0 !important;
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    color: var(--text) !important;
}

.top-bar-right {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}

/* Sidebar Toggle Button */
.sidebar-toggle {
    background: var(--primary) !important;
    color: white !important;
    border: none !important;
    border-radius: 6px !important;
    width: 40px !important;
    height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

.sidebar-toggle:hover {
    background: var(--primary-dark) !important;
    transform: scale(1.05) !important;
}

.sidebar-toggle:active {
    transform: scale(0.95) !important;
}

.sidebar-toggle i {
    font-size: 18px !important;
}

/* User Info in Top Bar */
.user-info {
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
    padding: 0.5rem 1rem !important;
    background: rgba(255, 255, 255, 0.8) !important;
    border-radius: 50px !important;
    border: 1px solid var(--border) !important;
}

.user-avatar {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    background: linear-gradient(135deg, var(--primary), var(--accent)) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: white !important;
    font-size: 1rem !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

.user-details {
    text-align: left !important;
}

.user-name {
    font-weight: 600 !important;
    color: var(--text) !important;
    font-size: 0.9rem !important;
    margin-bottom: 0.1rem !important;
}

.user-company {
    font-size: 0.75rem !important;
    color: var(--text-light) !important;
    font-weight: 400 !important;
}

/* Welcome Section */
.welcome-section {
    margin-bottom: 2rem !important;
}

.welcome-card {
    background: linear-gradient(135deg, var(--primary), var(--accent)) !important;
    border-radius: 16px !important;
    padding: 2rem !important;
    color: white !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    box-shadow: 0 4px 15px rgba(37, 99, 235, 0.2) !important;
}

.welcome-content h1 {
    font-size: 1.75rem !important;
    font-weight: 700 !important;
    margin-bottom: 0.5rem !important;
    color: white !important;
}

.welcome-content p {
    font-size: 1rem !important;
    opacity: 0.9 !important;
    margin: 0 !important;
}

.welcome-stats {
    display: flex !important;
    gap: 2rem !important;
}

.stat-item {
    text-align: center !important;
}

.stat-number {
    display: block !important;
    font-size: 2rem !important;
    font-weight: 700 !important;
    margin-bottom: 0.25rem !important;
}

.stat-label {
    font-size: 0.85rem !important;
    opacity: 0.85 !important;
}

/* Enhanced Dashboard Cards */
.dashboard-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    gap: 1.5rem !important;
    margin-bottom: 2rem !important;
}

.dashboard-card {
    background: white !important;
    border-radius: 12px !important;
    padding: 1.5rem !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05) !important;
    border: 1px solid var(--border) !important;
    transition: all 0.3s ease !important;
}

.dashboard-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1) !important;
}

.card-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 1rem !important;
}

.card-header h3 {
    margin: 0 !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: var(--text) !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.card-header h3 i {
    color: var(--primary) !important;
    font-size: 1.2rem !important;
}

.card-value {
    font-size: 2rem !important;
    font-weight: 700 !important;
    color: var(--text) !important;
}

/* Card Icon Styles */
.card-icon {
    width: 60px !important;
    height: 60px !important;
    border-radius: 12px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 1.5rem !important;
    color: white !important;
    flex-shrink: 0 !important;
}

.card-icon.blue { background: #2563eb !important; }
.card-icon.green { background: #10b981 !important; }
.card-icon.purple { background: #8b5cf6 !important; }
.card-icon.orange { background: #f97316 !important; }
.card-icon.red { background: #ef4444 !important; }
.card-icon.teal { background: #0d9488 !important; }
.card-icon.yellow { background: #f59e0b !important; }

/* Dashboard Isolation - Prevent cross-contamination */
#clientDashboardPage .recent-activity-section,
#clientDashboardPage .quick-actions-section {
    display: none !important;
}

#adminDashboardPage .welcome-section,
#adminDashboardPage .client-only-content {
    display: none !important;
}

/* Ensure proper visibility based on active page */
.page.hidden {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.page.active {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.card-body {
    border-top: 1px solid var(--border) !important;
    padding-top: 1rem !important;
}

.trend {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    margin-bottom: 1rem !important;
    font-size: 0.85rem !important;
}

.trend.positive {
    color: var(--success) !important;
}

.trend.negative {
    color: var(--danger) !important;
}

.trend.neutral {
    color: var(--text-light) !important;
}

.card-actions {
    display: flex !important;
    gap: 0.5rem !important;
}

/* Buttons */
.btn {
    padding: 0.5rem 1rem !important;
    border-radius: 6px !important;
    font-weight: 500 !important;
    font-size: 0.875rem !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    border: none !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.btn-primary {
    background: var(--primary) !important;
    color: white !important;
}

.btn-primary:hover {
    background: var(--primary-dark) !important;
    transform: translateY(-1px) !important;
}

.btn-secondary {
    background: var(--text-light) !important;
    color: white !important;
}

.btn-secondary:hover {
    background: #4b5563 !important;
}

.btn-success {
    background: var(--success) !important;
    color: white !important;
}

.btn-success:hover {
    background: #059669 !important;
}

.btn-warning {
    background: var(--warning) !important;
    color: white !important;
}

.btn-warning:hover {
    background: #d97706 !important;
}

.btn-sm {
    padding: 0.25rem 0.75rem !important;
    font-size: 0.75rem !important;
}

.btn-outline {
    background: transparent !important;
    border: 1px solid var(--border) !important;
    color: var(--text) !important;
}

.btn-outline:hover {
    background: var(--secondary) !important;
}

/* Recent Activity Section */
.recent-activity-section {
    background: white !important;
    border-radius: 12px !important;
    padding: 1.5rem !important;
    margin-bottom: 2rem !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05) !important;
    border: 1px solid var(--border) !important;
}

.section-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 1.5rem !important;
    padding-bottom: 1rem !important;
    border-bottom: 1px solid var(--border) !important;
}

.section-header h2 {
    margin: 0 !important;
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    color: var(--text) !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.section-header h2 i {
    color: var(--primary) !important;
}

.activity-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 1rem !important;
}

.activity-item {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1rem !important;
    border-radius: 8px !important;
    background: var(--secondary) !important;
    transition: all 0.2s ease !important;
}

.activity-item:hover {
    background: #e2e8f0 !important;
    transform: translateX(3px) !important;
}

.activity-icon {
    width: 40px !important;
    height: 40px !important;
    border-radius: 10px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: white !important;
    font-size: 1rem !important;
    flex-shrink: 0 !important;
}

.bg-blue {
    background: var(--primary) !important;
}

.bg-green {
    background: var(--success) !important;
}

.bg-orange {
    background: var(--warning) !important;
}

.activity-content {
    flex: 1 !important;
}

.activity-title {
    font-weight: 500 !important;
    color: var(--text) !important;
    margin-bottom: 0.25rem !important;
}

.activity-time {
    font-size: 0.85rem !important;
    color: var(--text-light) !important;
}

.status-badge {
    padding: 0.25rem 0.75rem !important;
    border-radius: 20px !important;
    font-size: 0.75rem !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
}

.status-pending {
    background: #fef3c7 !important;
    color: #92400e !important;
}

.status-in-transit {
    background: #dbeafe !important;
    color: #1d4ed8 !important;
}

.status-paid {
    background: #d1fae5 !important;
    color: #065f46 !important;
}

/* Quick Actions Section */
.quick-actions-section {
    background: white !important;
    border-radius: 12px !important;
    padding: 1.5rem !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05) !important;
    border: 1px solid var(--border) !important;
}

.quick-actions-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
    gap: 1rem !important;
}

.quick-action-btn {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1.25rem !important;
    border: 2px solid var(--border) !important;
    border-radius: 10px !important;
    background: white !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    text-align: left !important;
}

.quick-action-btn:hover {
    border-color: var(--primary) !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 5px 15px rgba(37, 99, 235, 0.1) !important;
}

.action-icon {
    width: 48px !important;
    height: 48px !important;
    border-radius: 12px !important;
    background: rgba(37, 99, 235, 0.1) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--primary) !important;
    font-size: 1.25rem !important;
    flex-shrink: 0 !important;
}

.action-text h4 {
    margin: 0 0 0.25rem 0 !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: var(--text) !important;
}

.action-text p {
    margin: 0 !important;
    font-size: 0.85rem !important;
    color: var(--text-light) !important;
}

/* Responsive Design Enhancements */
@media (max-width: 768px) {
    .welcome-card {
        flex-direction: column !important;
        text-align: center !important;
        gap: 1.5rem !important;
    }
    
    .welcome-stats {
        justify-content: center !important;
        gap: 1.5rem !important;
    }
    
    .dashboard-grid {
        grid-template-columns: 1fr !important;
    }
    
    .top-bar {
        flex-direction: column !important;
        gap: 1rem !important;
        padding: 1rem !important;
    }
    
    .top-bar-right {
        width: 100% !important;
        justify-content: center !important;
    }
    
    .quick-actions-grid {
        grid-template-columns: 1fr !important;
    }
    
    .activity-item {
        flex-direction: column !important;
        text-align: center !important;
        gap: 0.75rem !important;
    }
}

/* Placeholder Content Styles */
.placeholder-content {
    text-align: center !important;
    padding: 3rem 1rem !important;
    background: white !important;
    border-radius: 12px !important;
    border: 2px dashed var(--border) !important;
    margin: 1rem 0 !important;
}

.placeholder-content p {
    color: var(--text-light) !important;
    margin: 1rem 0 !important;
    font-size: 1rem !important;
}

/* Form Elements */
.form-group {
    margin-bottom: 1rem !important;
}

.form-control {
    width: 100% !important;
    padding: 0.75rem 1rem !important;
    border: 2px solid var(--border) !important;
    border-radius: 8px !important;
    font-size: 1rem !important;
    transition: all 0.2s ease !important;
    background: white !important;
}

.form-control:focus {
    outline: none !important;
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1) !important;
}

/* CAPTCHA Container */
.captcha-container {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.captcha-display {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 0.5rem !important;
    background: var(--secondary) !important;
    border: 2px solid var(--border) !important;
    border-radius: 8px !important;
    min-width: 120px !important;
}

.captcha-code {
    font-family: 'Courier New', monospace !important;
    font-size: 1.2rem !important;
    font-weight: bold !important;
    letter-spacing: 2px !important;
    color: var(--primary) !important;
    user-select: none !important;
}

.captcha-refresh {
    background: var(--primary) !important;
    color: white !important;
    border: none !important;
    border-radius: 50% !important;
    width: 30px !important;
    height: 30px !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 1rem !important;
    transition: all 0.2s ease !important;
}

.captcha-refresh:hover {
    background: var(--primary-dark) !important;
    transform: rotate(90deg) !important;
}

/* Tab Content */
.tab-content {
    background: white !important;
    border-radius: 12px !important;
    padding: 2rem !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05) !important;
    border: 1px solid var(--border) !important;
    margin-bottom: 1.5rem !important;
    display: block !important;  /* Ensure content is visible by default */
}

.tab-content h2 {
    margin-top: 0 !important;
    margin-bottom: 1.5rem !important;
    color: var(--text) !important;
    font-size: 1.5rem !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.tab-content h2 i {
    color: var(--primary) !important;
}

/* Ensure responsive behavior */
@media (max-width: 768px) {
    .tab-content {
        padding: 1.5rem !important;
    }
    
    .placeholder-content {
        padding: 2rem 1rem !important;
    }
    
    .form-control {
        padding: 0.6rem 0.8rem !important;
        font-size: 0.95rem !important;
    }
}

@media (max-width: 480px) {
    .content-area {
        padding: 1rem !important;
    }
    
    .welcome-card {
        padding: 1.5rem !important;
    }
    
    .welcome-content h1 {
        font-size: 1.5rem !important;
    }
    
    .stat-number {
        font-size: 1.5rem !important;
    }
    
    .dashboard-card {
        padding: 1.25rem !important;
    }
    
    .card-value {
        font-size: 1.75rem !important;
    }
}

.dashboard-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    gap: 1.25rem !important;
    margin-bottom: 1.5rem !important;
}

.dashboard-card {
    background: var(--white) !important;
    border-radius: 12px !important;
    padding: 1.25rem !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05) !important;
    border: 1px solid var(--border) !important;
    transition: all 0.2s ease !important;
}

.dashboard-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1) !important;
}

.dashboard-card h3 {
    margin: 0 0 1rem 0 !important;
    color: var(--text) !important;
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.dashboard-card h3::before {
    content: "📊" !important;
    font-size: 1.2rem !important;
}

/* Menu Content */
/* Active tab content styling */
.tab-content.active {
    display: block !important;
}

.menu-content {
    background: var(--white) !important;
    border-radius: 12px !important;
    padding: 1.5rem !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05) !important;
    border: 1px solid var(--border) !important;
    margin-bottom: 1.25rem !important;
}

.menu-content h3 {
    margin: 0 0 1rem 0 !important;
    color: var(--text) !important;
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    border-bottom: 2px solid var(--border) !important;
    padding-bottom: 0.5rem !important;
}

/* Utility Classes */
.text-center {
    text-align: center !important;
}

.mt-3 {
    margin-top: 0.75rem !important;
}

.mb-3 {
    margin-bottom: 0.75rem !important;
}

.p-3 {
    padding: 0.75rem !important;
}

.text-muted {
    color: var(--text-light) !important;
}

.font-medium {
    font-weight: 500 !important;
}

.font-semibold {
    font-weight: 600 !important;
}

/* Hide sidebar close button on desktop */
.sidebar-close-btn {
    display: none !important;
}

/* Mobile Responsive Design */
@media (max-width: 768px) {
    :root {
        --sidebar-width: 70px;
        --topbar-height: 56px;
    }
    
    /* Mobile navbar improvements */
    .top-bar {
        height: var(--topbar-height) !important;
        padding: 0 1rem !important;
        z-index: 900 !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        background: white !important;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
    }
    
    .top-bar-left {
        display: flex !important;
        align-items: center !important;
        gap: 0.75rem !important;
    }
    
    /* Mobile sidebar toggle button */
    .sidebar-toggle,
    .sidebar-show-btn {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 40px !important;
        height: 40px !important;
        background: #2563eb !important;
        color: white !important;
        border: none !important;
        border-radius: 8px !important;
        cursor: pointer !important;
        font-size: 1.1rem !important;
        padding: 0 !important;
        flex-shrink: 0 !important;
    }
    
    .sidebar-toggle:hover,
    .sidebar-show-btn:hover {
        background: #1d4ed8 !important;
    }
    
    .top-bar h2,
    .top-bar h1 {
        font-size: 1.1rem !important;
        font-weight: 600 !important;
        margin: 0 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        color: #1e293b !important;
    }
    
    /* Hide user info on mobile to save space */
    .top-bar-right .user-info {
        display: none !important;
    }
    
    /* Mobile sidebar behavior - Off-canvas menu */
    .sidebar {
        position: fixed !important;
        left: 0 !important;
        top: var(--topbar-height) !important;
        height: calc(100vh - var(--topbar-height)) !important;
        z-index: 1000 !important;
        width: 280px !important;
        transform: translateX(-100%) !important;
        box-shadow: 2px 0 20px rgba(0, 0, 0, 0.15) !important;
        transition: transform 0.3s ease !important;
    }
    
    .sidebar.expanded {
        transform: translateX(0) !important;
    }
    
    .sidebar.collapsed {
        transform: translateX(-100%) !important;
    }
    
    /* Mobile overlay */
    .mobile-overlay {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        background: rgba(0, 0, 0, 0.5) !important;
        z-index: 999 !important;
        display: none !important;
    }
    
    .mobile-overlay.active {
        display: block !important;
    }
    
    /* Mobile sidebar header */
    .sidebar-header {
        justify-content: space-between !important;
        padding: 1rem !important;
    }
    
    .sidebar-header h2 span {
        display: inline !important;
    }
    
    /* Mobile close button */
    .sidebar-close-btn {
        background: none !important;
        border: none !important;
        color: white !important;
        font-size: 1.5rem !important;
        cursor: pointer !important;
        padding: 0.25rem !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }
    
    /* Mobile navigation items */
    .nav-item {
        justify-content: flex-start !important;
        padding: 1rem 1.5rem !important;
    }
    
    .nav-item span {
        display: inline !important;
    }
    
    /* Mobile sidebar footer */
    .sidebar-footer {
        display: block !important;
        padding: 1rem !important;
    }
    
    .logout-btn {
        width: 100% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 1rem !important;
        font-size: 1rem !important;
    }
    
    .logout-btn span {
        display: inline !important;
    }
    
    /* Main content adjustments */
    .main-content {
        margin-left: 0 !important;
        width: 100% !important;
        padding-top: var(--topbar-height) !important;
    }
    
    .content-area {
        padding: 1rem !important;
        overflow-y: auto !important;
    }
    .sidebar-toggle {
        width: 40px !important;
        height: 40px !important;
        background: #2563eb !important;
        color: white !important;
        border: none !important;
        border-radius: 8px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        cursor: pointer !important;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
    }
    
    .sidebar-toggle i {
        font-size: 18px !important;
    }
    
    .menu-link span {
        display: none !important;
    }
    
    .content-area {
        padding: 1rem !important;
    }
    
    .dashboard-grid {
        grid-template-columns: 1fr !important;
        gap: 1rem !important;
    }
    
    .summary-cards {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 0.75rem !important;
    }
    
    .quick-actions-grid {
        grid-template-columns: 1fr !important;
        gap: 0.75rem !important;
    }
    
    /* Table adjustments */
    .table-responsive {
        overflow-x: auto !important;
    }
    
    table {
        font-size: 0.85rem !important;
    }
    
    th, td {
        padding: 0.5rem !important;
    }
}

@media (max-width: 480px) {
    /* Extra small devices */
    .sidebar {
        width: 100vw !important;
        max-width: 300px !important;
    }
    
    .dashboard-layout {
        flex-direction: column !important;
    }
    
    .menu-container {
        display: flex !important;
        overflow-x: auto !important;
        padding: 0.5rem !important;
    }
    
    .menu-list {
        display: flex !important;
        flex-direction: row !important;
        gap: 0.25rem !important;
    }
    
    .menu-link {
        white-space: nowrap !important;
        border-left: none !important;
        border-bottom: 3px solid transparent !important;
        padding: 0.75rem 1rem !important;
    }
    
    .menu-link:hover, .menu-link.active {
        border-left: none !important;
        border-bottom-color: var(--primary) !important;
        transform: translateY(0) !important;
    }
    
    .top-bar {
        padding: 0 1rem !important;
    }
    
    .content-area {
        padding: 0.75rem !important;
    }
    
    /* Compact navigation */
    .nav-item {
        padding: 0.75rem 1rem !important;
        font-size: 0.9rem !important;
    }
    
    .sidebar-header {
        padding: 0.75rem !important;
    }
    
    .logo {
        font-size: 1.1rem !important;
    }
    
    /* Summary cards */
    .summary-cards {
        grid-template-columns: 1fr !important;
    }
    
    /* Compact forms */
    .form-group {
        margin-bottom: 1rem !important;
    }
    
    input, select, textarea {
        font-size: 16px !important; /* Prevent zoom on iOS */
    }
    
    /* Compact buttons */
    .btn {
        padding: 0.5rem 1rem !important;
        font-size: 0.9rem !important;
    }
}

/* Loading States */
.loading {
    opacity: 0.7;
    pointer-events: none;
}

.loading-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 3px solid #e2e8f0;
    border-radius: 50%;
    border-top-color: #3b82f6;
    animation: spin 1s ease-in-out infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* CORRECTED SIDEBAR STYLING - Matching Actual HTML Structure */

/* Base Reset */
* {
    box-sizing: border-box !important;
    margin: 0;
    padding: 0;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    background: #f1f5f9 !important;
    color: #1e293b !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    overflow-x: hidden !important;
}

/* Page System */
.page {
    display: none !important;
    min-height: 100vh !important;
    width: 100% !important;
}

.page.active {
    display: flex !important;
    flex-direction: column !important;
}

/* Dashboard Layout */
#clientDashboardPage.active, #adminDashboardPage.active {
    display: flex !important;
    flex-direction: column !important;
    min-height: 100vh !important;
}

.dashboard-layout {
    display: flex !important;
    flex: 1 !important;
    min-height: 100vh !important;
    background: #f1f5f9 !important;
}

/* CORRECTED SIDEBAR STYLING - Using Actual Classes */
.sidebar {
    width: 220px !important;
    background: white !important;
    border-right: 1px solid #e2e8f0 !important;
    display: flex !important;
    flex-direction: column !important;
    box-shadow: 2px 0 10px rgba(0, 0, 0, 0.03) !important;
    position: relative !important;
    z-index: 100 !important;
    min-height: 100vh !important;
    transition: all 0.3s ease !important;
}

/* Collapsed Sidebar State - Zero-gap layout */
.sidebar.collapsed {
    width: 70px !important;
    box-shadow: none !important;
}

.sidebar.collapsed .sidebar-header span,
.sidebar.collapsed .nav-item span {
    display: none !important;
}

.sidebar.collapsed .sidebar-header {
    justify-content: center !important;
}

.sidebar.collapsed .logo {
    gap: 0 !important;
}

/* Ensure no gaps in layout */
.dashboard-layout {
    display: flex !important;
    width: 100% !important;
    position: relative !important;
}

.main-content {
    flex: 1 !important;
    transition: all 0.3s ease !important;
    position: relative !important;
}

/* Mobile responsive - Full hide/show behavior */
@media (max-width: 768px) {
    /* Allow fixed elements to escape the container */
    .dashboard-layout {
        overflow: visible !important;
    }
    
    .sidebar {
        position: fixed !important;
        top: 56px !important;
        left: 0 !important;
        height: calc(100vh - 56px) !important;
        width: 280px !important;
        transform: translateX(-100%) !important;
        transition: transform 0.3s ease !important;
        z-index: 1000 !important;
        box-shadow: 2px 0 10px rgba(0, 0, 0, 0.1) !important;
    }
    
    .sidebar.collapsed {
        transform: translateX(-100%) !important;
        width: 280px !important;
    }
    
    .sidebar.expanded {
        transform: translateX(0) !important;
        width: 280px !important;
    }
    
    .sidebar.collapsed .sidebar-header,
    .sidebar.collapsed .sidebar-content,
    .sidebar.collapsed .sidebar-footer {
        visibility: hidden !important;
    }
    
    .sidebar.expanded .sidebar-header,
    .sidebar.expanded .sidebar-content,
    .sidebar.expanded .sidebar-footer {
        visibility: visible !important;
    }
    
    /* Main content takes full width on mobile */
    .main-content {
        margin-left: 0 !important;
        width: 100% !important;
        padding-top: 56px !important;
    }
}

/* Sidebar Header */
.sidebar-header {
    padding: 20px 16px !important;
    border-bottom: 1px solid #e2e8f0 !important;
    background: linear-gradient(to right, #2563eb, #7c3aed) !important;
    color: white !important;
    min-height: 60px !important;
    display: flex !important;
    align-items: center !important;
}

.logo {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: white !important;
}

.logo i {
    font-size: 24px !important;
}

/* Sidebar Content */
.sidebar-content {
    flex: 1 !important;
    overflow-y: auto !important;
    padding: 12px 0 !important;
    background: white !important;
}

/* CORRECTED NAVIGATION - Using Actual sidebar-nav and nav-item */
.sidebar-nav {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
}

.nav-item {
    display: flex !important;
    align-items: center !important;
    padding: 12px 20px !important;
    color: #64748b !important;
    text-decoration: none !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border-left: 3px solid transparent !important;
    transition: all 0.2s ease !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    position: relative !important;
    min-height: 44px !important;
}

.nav-item:hover {
    background: #f1f5f9 !important;
    color: #2563eb !important;
    border-left-color: #2563eb !important;
    transform: translateX(3px) !important;
    text-decoration: none !important;
}

.nav-item.active {
    background: rgba(37, 99, 235, 0.08) !important;
    color: #2563eb !important;
    border-left-color: #2563eb !important;
    font-weight: 600 !important;
}

.nav-item i {
    width: 20px !important;
    margin-right: 12px !important;
    font-size: 16px !important;
    text-align: center !important;
    display: inline-block !important;
    min-width: 20px !important;
}

.nav-item span {
    display: inline-block !important;
    flex: 1 !important;
    text-align: left !important;
}

/* Sidebar Footer */
.sidebar-footer {
    padding: 16px !important;
    border-top: 1px solid #e2e8f0 !important;
    background: #f8fafc !important;
}

.logout-btn {
    width: 100% !important;
    padding: 10px 16px !important;
    background: #ef4444 !important;
    color: white !important;
    border: none !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    font-weight: 500 !important;
    font-size: 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    transition: all 0.2s ease !important;
}

.logout-btn:hover {
    background: #dc2626 !important;
    transform: translateY(-1px) !important;
}

/* Main Content */
.main-content {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    min-width: 0 !important;
    background: #f1f5f9 !important;
    min-height: 100vh !important;
}

/* Top Bar */
.top-bar {
    height: 56px !important;
    padding: 0 24px !important;
    background: white !important;
    border-bottom: 1px solid #e2e8f0 !important;
    display: flex !important;
    align-items: center !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05) !important;
    min-height: 56px !important;
}

.top-bar h2 {
    margin: 0 !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    color: #1e293b !important;
}

/* Content Area */
.content-area {
    flex: 1 !important;
    padding: 24px !important;
    overflow-y: auto !important;
    background: #f1f5f9 !important;
    min-height: calc(100vh - 56px) !important;
}

/* Content Area Styling for Embedded Pages */

/* Ensure proper styling for content loaded in main area */
.content-area {
    flex: 1 !important;
    padding: 24px !important;
    overflow-y: auto !important;
    background: #f1f5f9 !important;
    min-height: calc(100vh - 56px) !important;
}

/* Styling for embedded content containers */
.content-area > div {
    background: white !important;
    border-radius: 12px !important;
    padding: 2rem !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05) !important;
    border: 1px solid #e2e8f0 !important;
    margin-bottom: 1.5rem !important;
}

/* User Permissions specific styling */
.user-permissions-container {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    max-width: 100% !important;
    line-height: 1.6 !important;
}

/* Form sections styling */
.form-section {
    margin-bottom: 25px !important;
    padding: 20px !important;
    background: #f8fafc !important;
    border-radius: 8px !important;
    border-left: 4px solid #3b82f6 !important;
}

.form-section h4 {
    margin-top: 0 !important;
    margin-bottom: 15px !important;
    color: #1e293b !important;
    font-size: 1.2rem !important;
    font-weight: 600 !important;
}

.form-group {
    margin-bottom: 15px !important;
}

.form-control {
    width: 100% !important;
    padding: 10px !important;
    border: 1px solid #cbd5e1 !important;
    border-radius: 6px !important;
    font-size: 1rem !important;
    transition: border-color 0.2s ease !important;
}

.form-control:focus {
    outline: none !important;
    border-color: #3b82f6 !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1) !important;
}

/* Menu tree styling */
.menu-tree {
    margin: 15px 0 !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    max-height: 400px !important;
    overflow-y: auto !important;
    background: white !important;
}

.menu-item {
    display: flex !important;
    align-items: center !important;
    padding: 12px 15px !important;
    border-bottom: 1px solid #f1f5f9 !important;
    transition: background-color 0.2s ease !important;
}

.menu-item:last-child {
    border-bottom: none !important;
}

.menu-item:hover {
    background-color: #f8fafc !important;
}

.menu-item.parent {
    background-color: #eff6ff !important;
    font-weight: 600 !important;
    border-left: 3px solid #3b82f6 !important;
}

.menu-item.child {
    padding-left: 40px !important;
    background: white !important;
}

.menu-title {
    flex: 1 !important;
    margin: 0 15px !important;
    font-size: 0.95rem !important;
    color: #1e293b !important;
}

/* Toggle switch styling */
.toggle-switch {
    position: relative !important;
    display: inline-block !important;
    width: 50px !important;
    height: 24px !important;
}

.toggle-switch input {
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
}

.slider {
    position: absolute !important;
    cursor: pointer !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background-color: #cbd5e1 !important;
    transition: .4s !important;
    border-radius: 24px !important;
}

.slider:before {
    position: absolute !important;
    content: "" !important;
    height: 16px !important;
    width: 16px !important;
    left: 4px !important;
    bottom: 4px !important;
    background-color: white !important;
    transition: .4s !important;
    border-radius: 50% !important;
}

input:checked + .slider {
    background-color: #3b82f6 !important;
}

input:checked + .slider:before {
    transform: translateX(26px) !important;
}

/* Menu type badges */
.menu-type {
    padding: 0.25rem 0.5rem !important;
    border-radius: 4px !important;
    font-size: 0.75rem !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
}

.menu-type.basic {
    background: #dbeafe !important;
    color: #1d4ed8 !important;
}

.menu-type.premium {
    background: #d9f99d !important;
    color: #365314 !important;
}

.menu-type.admin {
    background: #ffe4e6 !important;
    color: #991b1b !important;
}

/* Action buttons */
.actions {
    display: flex !important;
    gap: 1rem !important;
    margin-top: 1.5rem !important;
    padding-top: 1.5rem !important;
    border-top: 1px solid #e2e8f0 !important;
}

.btn {
    padding: 0.75rem 1.5rem !important;
    border: none !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-weight: 500 !important;
    transition: all 0.2s ease !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.btn-primary {
    background: #3b82f6 !important;
    color: white !important;
}

.btn-primary:hover {
    background: #2563eb !important;
    transform: translateY(-1px) !important;
}

.btn-secondary {
    background: #64748b !important;
    color: white !important;
}

.btn-secondary:hover {
    background: #475569 !important;
}

/* Notifications */
.notification {
    padding: 1rem !important;
    margin-bottom: 1rem !important;
    border-radius: 6px !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.notification.success {
    background: #dcfce7 !important;
    color: #166534 !important;
    border: 1px solid #bbf7d0 !important;
}

.notification.error {
    background: #fee2e2 !important;
    color: #991b1b !important;
    border: 1px solid #fecaca !important;
}

.notification.info {
    background: #dbeafe !important;
    color: #1e40af !important;
    border: 1px solid #bfdbfe !important;
}

/* Current permissions display */
.current-permissions {
    margin-top: 2rem !important;
    padding: 1.5rem !important;
    background: #f8fafc !important;
    border-radius: 8px !important;
    border: 1px solid #e2e8f0 !important;
}

.current-permissions h4 {
    margin-top: 0 !important;
    margin-bottom: 1rem !important;
    color: #1e293b !important;
    font-size: 1.1rem !important;
}

.permission-list {
    background: white !important;
    border-radius: 6px !important;
    border: 1px solid #e2e8f0 !important;
    max-height: 300px !important;
    overflow-y: auto !important;
}

.permission-item {
    display: flex !important;
    align-items: center !important;
    padding: 0.75rem !important;
    border-bottom: 1px solid #f1f5f9 !important;
}

.permission-item:last-child {
    border-bottom: none !important;
}

/* Ensure responsive behavior */
@media (max-width: 768px) {
    .content-area {
        padding: 1rem !important;
    }
    
    .content-area > div {
        padding: 1rem !important;
    }
    
    .form-section {
        padding: 1rem !important;
    }
    
    .menu-item.child {
        padding-left: 20px !important;
    }
    
    .actions {
        flex-direction: column !important;
    }
    
    .btn {
        width: 100% !important;
        justify-content: center !important;
    }
}

/* SIDEBAR COLLAPSE FUNCTIONALITY */

/* Base sidebar styling */
.sidebar {
    width: 220px !important;
    background: white !important;
    border-right: 1px solid #e2e8f0 !important;
    display: flex !important;
    flex-direction: column !important;
    box-shadow: 2px 0 10px rgba(0, 0, 0, 0.03) !important;
    position: relative !important;
    z-index: 100 !important;
    min-height: 100vh !important;
    transition: all 0.3s ease !important;
}

/* Collapsed sidebar state */
.sidebar.collapsed {
    width: 70px !important;
}

.sidebar.collapsed .logo span {
    display: none !important;
}

.sidebar.collapsed .nav-item span {
    display: none !important;
}

.sidebar.collapsed .sidebar-footer {
    display: none !important;
}

/* SIDEBAR HEADER WITH COLLAPSE BUTTON */
.sidebar-header {
    padding: 20px 16px !important;
    border-bottom: 1px solid #e2e8f0 !important;
    background: linear-gradient(to right, #2563eb, #7c3aed) !important;
    color: white !important;
    min-height: 60px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
}

.logo {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: white !important;
    flex: 1 !important;
    min-width: 0 !important; /* Allow shrinking */
}

.logo i {
    font-size: 24px !important;
    flex-shrink: 0 !important;
}

.logo span {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

/* Collapse Toggle Button */
.collapse-btn {
    background: rgba(255, 255, 255, 0.2) !important;
    border: none !important;
    color: white !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s ease !important;
    flex-shrink: 0 !important;
    margin-left: 12px !important;
}

.collapse-btn:hover {
    background: rgba(255, 255, 255, 0.3) !important;
    transform: scale(1.05) !important;
}

.collapse-btn i {
    font-size: 16px !important;
    transition: transform 0.3s ease !important;
}

.sidebar.collapsed .collapse-btn i {
    transform: rotate(180deg) !important;
}

/* Sidebar Content */
.sidebar-content {
    flex: 1 !important;
    overflow-y: auto !important;
    padding: 12px 0 !important;
    background: white !important;
}

/* Navigation - Using Actual sidebar-nav and nav-item */
.sidebar-nav {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
}

.nav-item {
    display: flex !important;
    align-items: center !important;
    padding: 12px 20px !important;
    color: #64748b !important;
    text-decoration: none !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border-left: 3px solid transparent !important;
    transition: all 0.2s ease !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    position: relative !important;
    min-height: 44px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.nav-item:hover {
    background: #f1f5f9 !important;
    color: #2563eb !important;
    border-left-color: #2563eb !important;
    transform: translateX(3px) !important;
    text-decoration: none !important;
}

.nav-item.active {
    background: rgba(37, 99, 235, 0.08) !important;
    color: #2563eb !important;
    border-left-color: #2563eb !important;
    font-weight: 600 !important;
}

.nav-item i {
    width: 20px !important;
    margin-right: 12px !important;
    font-size: 16px !important;
    text-align: center !important;
    display: inline-block !important;
    min-width: 20px !important;
    flex-shrink: 0 !important;
}

.nav-item span {
    display: inline-block !important;
    flex: 1 !important;
    text-align: left !important;
    transition: opacity 0.2s ease !important;
}

.sidebar.collapsed .nav-item span {
    opacity: 0 !important;
}

/* Sidebar Footer */
.sidebar-footer {
    padding: 16px !important;
    border-top: 1px solid #e2e8f0 !important;
    background: #f8fafc !important;
    transition: all 0.3s ease !important;
}

.logout-btn {
    width: 100% !important;
    padding: 10px 16px !important;
    background: #ef4444 !important;
    color: white !important;
    border: none !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    font-weight: 500 !important;
    font-size: 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    transition: all 0.2s ease !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.logout-btn:hover {
    background: #dc2626 !important;
    transform: translateY(-1px) !important;
}

.sidebar.collapsed .logout-btn {
    justify-content: center !important;
    padding: 10px !important;
}

.sidebar.collapsed .logout-btn span {
    display: none !important;
}

/* Main Content Adjustment */
.main-content {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    min-width: 0 !important;
    background: #f1f5f9 !important;
    min-height: 100vh !important;
    transition: margin-left 0.3s ease !important;
}

.dashboard-layout {
    display: flex !important;
    flex: 1 !important;
    min-height: 100vh !important;
    background: #f1f5f9 !important;
    transition: all 0.3s ease !important;
}

/* Responsive behavior */
@media (max-width: 768px) {
    .sidebar {
        width: 70px !important;
    }
    
    .sidebar:not(.collapsed) .logo span,
    .sidebar:not(.collapsed) .nav-item span,
    .sidebar:not(.collapsed) .sidebar-footer {
        display: none !important;
    }
}

/* MENU GROUP COLLAPSE FUNCTIONALITY */

/* Menu group container */
.menu-group {
    position: relative !important;
    width: 100% !important;
}

/* Parent menu item styling */
.nav-item {
    display: flex !important;
    align-items: center !important;
    padding: 12px 20px !important;
    color: #64748b !important;
    text-decoration: none !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border-left: 3px solid transparent !important;
    transition: all 0.2s ease !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    position: relative !important;
    min-height: 44px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.nav-item:hover {
    background: #f1f5f9 !important;
    color: #2563eb !important;
    border-left-color: #2563eb !important;
    transform: translateX(3px) !important;
    text-decoration: none !important;
}

.nav-item.active {
    background: rgba(37, 99, 235, 0.08) !important;
    color: #2563eb !important;
    border-left-color: #2563eb !important;
    font-weight: 600 !important;
}

/* Parent menu item with children */
.nav-item.has-children {
    font-weight: 600 !important;
    background: rgba(37, 99, 235, 0.03) !important;
    border-left: 3px solid #2563eb !important;
}

.nav-item.has-children:hover {
    background: rgba(37, 99, 235, 0.08) !important;
}

/* Expand/Collapse icon */
.menu-expand-icon {
    margin-left: auto !important;
    font-size: 12px !important;
    transition: transform 0.3s ease !important;
    opacity: 0.6 !important;
    width: 16px !important;
    text-align: center !important;
}

.menu-expand-icon.expanded {
    transform: rotate(180deg) !important;
}

/* Child menu items container */
.menu-children {
    max-height: 1000px !important;
    overflow: hidden !important;
    transition: all 0.3s ease !important;
    background: rgba(241, 245, 249, 0.5) !important;
}

.menu-children.collapsed {
    max-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Child menu items */
.nav-item-child {
    display: flex !important;
    align-items: center !important;
    padding: 10px 20px 10px 36px !important;
    color: #64748b !important;
    text-decoration: none !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    border-left: 3px solid transparent !important;
    transition: all 0.2s ease !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    position: relative !important;
    min-height: 36px !important;
}

.nav-item-child:hover {
    background: #e2e8f0 !important;
    color: #2563eb !important;
    border-left-color: #2563eb !important;
    text-decoration: none !important;
}

.nav-item-child.active {
    background: rgba(37, 99, 235, 0.1) !important;
    color: #2563eb !important;
    border-left-color: #2563eb !important;
    font-weight: 500 !important;
}

/* Menu item icons */
.nav-item i, .nav-item-child i {
    width: 20px !important;
    margin-right: 12px !important;
    font-size: 16px !important;
    text-align: center !important;
    display: inline-block !important;
    min-width: 20px !important;
    flex-shrink: 0 !important;
}

/* Menu item text */
.nav-item span, .nav-item-child span {
    display: inline-block !important;
    flex: 1 !important;
    text-align: left !important;
}

/* Visual separators between groups */
.menu-group:not(:first-child) {
    border-top: 1px solid #e2e8f0 !important;
    margin-top: 0.75rem !important;
    padding-top: 0.75rem !important;
}

/* Ensure proper styling when collapsed */
.sidebar.collapsed .menu-expand-icon {
    display: none !important;
}

.sidebar.collapsed .menu-children {
    display: none !important;
}

.sidebar.collapsed .nav-item-child {
    display: none !important;
}

/* Smooth transitions for all menu elements */
.nav-item, .nav-item-child, .menu-children {
    transition: all 0.3s ease !important;
}

/* Global styling for embedded content to ensure User Permissions works properly */

/* Ensure proper box-sizing for all embedded content */
.embedded-content-wrapper,
.embedded-content-wrapper * {
    box-sizing: border-box !important;
}

/* Override any conflicting global styles */
.embedded-content-wrapper {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    line-height: 1.6 !important;
    color: #1e293b !important;
}

/* Ensure form elements work properly */
.embedded-content-wrapper input,
.embedded-content-wrapper select,
.embedded-content-wrapper button {
    font-family: inherit !important;
    font-size: inherit !important;
}

/* Fix for potential CSS conflicts */
.embedded-content-wrapper .form-control {
    width: 100% !important;
    padding: 10px !important;
    border: 1px solid #cbd5e1 !important;
    border-radius: 6px !important;
    font-size: 1rem !important;
    transition: border-color 0.2s ease !important;
    box-sizing: border-box !important;
}

.embedded-content-wrapper .form-control:focus {
    outline: none !important;
    border-color: #3b82f6 !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1) !important;
}

/* Ensure menu tree styling */
.embedded-content-wrapper .menu-tree {
    margin: 15px 0 !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    max-height: 400px !important;
    overflow-y: auto !important;
    background: white !important;
}

.embedded-content-wrapper .menu-item {
    display: flex !important;
    align-items: center !important;
    padding: 12px 15px !important;
    border-bottom: 1px solid #f1f5f9 !important;
    transition: background-color 0.2s ease !important;
}

.embedded-content-wrapper .menu-item:last-child {
    border-bottom: none !important;
}

.embedded-content-wrapper .menu-item:hover {
    background-color: #f8fafc !important;
}

.embedded-content-wrapper .menu-item.parent {
    background-color: #eff6ff !important;
    font-weight: 600 !important;
    border-left: 3px solid #3b82f6 !important;
}

.embedded-content-wrapper .menu-item.child {
    padding-left: 40px !important;
    background: white !important;
}

/* Toggle switch fixes */
.embedded-content-wrapper .toggle-switch {
    position: relative !important;
    display: inline-block !important;
    width: 50px !important;
    height: 24px !important;
}

.embedded-content-wrapper .toggle-switch input {
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
}

.embedded-content-wrapper .slider {
    position: absolute !important;
    cursor: pointer !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background-color: #cbd5e1 !important;
    transition: .4s !important;
    border-radius: 24px !important;
}

.embedded-content-wrapper .slider:before {
    position: absolute !important;
    content: "" !important;
    height: 16px !important;
    width: 16px !important;
    left: 4px !important;
    bottom: 4px !important;
    background-color: white !important;
    transition: .4s !important;
    border-radius: 50% !important;
}

.embedded-content-wrapper input:checked + .slider {
    background-color: #3b82f6 !important;
}

.embedded-content-wrapper input:checked + .slider:before {
    transform: translateX(26px) !important;
}

/* Button styling fixes */
.embedded-content-wrapper .btn {
    padding: 0.75rem 1.5rem !important;
    border: none !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-weight: 500 !important;
    transition: all 0.2s ease !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.embedded-content-wrapper .btn-primary {
    background: #3b82f6 !important;
    color: white !important;
}

.embedded-content-wrapper .btn-primary:hover {
    background: #2563eb !important;
    transform: translateY(-1px) !important;
}

.embedded-content-wrapper .btn-secondary {
    background: #64748b !important;
    color: white !important;
}

.embedded-content-wrapper .btn-secondary:hover {
    background: #475569 !important;
}

/* Notification styling */
.embedded-content-wrapper .notification {
    padding: 1rem !important;
    margin-bottom: 1rem !important;
    border-radius: 6px !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.embedded-content-wrapper .notification.success {
    background: #dcfce7 !important;
    color: #166534 !important;
    border: 1px solid #bbf7d0 !important;
}

.embedded-content-wrapper .notification.error {
    background: #fee2e2 !important;
    color: #991b1b !important;
    border: 1px solid #fecaca !important;
}

/* Ensure proper z-index and positioning */
.embedded-content-wrapper {
    position: relative !important;
    z-index: 1 !important;
}

/* Fix for any potential overflow issues */
.content-area {
    overflow-x: hidden !important;
}

/* Sidebar menu styling to ensure it continues to work */
.sidebar-nav {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.25rem !important;
    padding: 0.75rem 0 !important;
    min-height: 100% !important;
    overflow-y: auto !important;
}

/* Ensure menu items are visible */
.no-menu-message {
    padding: 1rem !important;
    color: #64748b !important;
    font-style: italic !important;
    text-align: center !important;
}

/* Main nav item styling */
.nav-item, .nav-item-child {
    display: flex !important;
    align-items: center !important;
    padding: 0.75rem 1.25rem !important;
    color: #64748b !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    border-left: 3px solid transparent !important;
    cursor: pointer !important;
    font-size: 0.95rem !important;
    opacity: 1 !important;  /* Ensure visibility */
    visibility: visible !important;  /* Ensure visibility */
}

.nav-item {
    padding: 0.75rem 1.25rem !important;
}

.nav-item-child {
    padding: 0.6rem 1.25rem 0.6rem 3rem !important;
}

.nav-item:hover {
    background: #f1f5f9 !important;
    color: #3b82f6 !important;
    border-left-color: #3b82f6 !important;
}

.nav-item.active {
    background: #dbeafe !important;
    color: #2565c4 !important;
    border-left-color: #3b82f6 !important;
    font-weight: 500 !important;
}

.nav-item i {
    margin-right: 0.75rem !important;
    width: 20px !important;
    text-align: center !important;
}

.nav-item span {
    flex: 1 !important;
}

/* Child menu item styling */
.nav-item-child {
    display: flex !important;
    align-items: center !important;
    padding: 0.6rem 1.25rem 0.6rem 3rem !important;
    color: #64748b !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    border-left: 3px solid transparent !important;
    cursor: pointer !important;
    font-size: 0.9rem !important;
}

.nav-item-child:hover {
    background: #f1f5f9 !important;
    color: #3b82f6 !important;
    border-left-color: #93c5fd !important;
}

.nav-item-child.active {
    background: #dbeafe !important;
    color: #2565c4 !important;
    border-left-color: #93c5fd !important;
}

.nav-item-child i {
    margin-right: 0.75rem !important;
    width: 20px !important;
    text-align: center !important;
}

.nav-item-child span {
    flex: 1 !important;
}

/* Menu group styling */
.menu-group {
    position: relative !important;
}

.menu-children {
    display: none !important;
    padding-left: 0 !important;
}

/* Has children styling */
.nav-item.has-children, .nav-item.has-submenu {
    font-weight: 600 !important;
    background: rgba(37, 99, 235, 0.03) !important;
    border-left: 3px solid #2563eb !important;
}

.nav-item.has-children:hover, .nav-item.has-submenu:hover {
    background: rgba(37, 99, 235, 0.06) !important;
}

.nav-item.has-children.active, .nav-item.has-submenu.active {
    background: #eff6ff !important;
    border-left-color: #2563eb !important;
}

/* Submenu arrow styling */
.submenu-arrow {
    margin-left: auto !important;
    transition: transform 0.2s ease !important;
    font-size: 14px !important;
    color: #5f6368 !important;
}

.nav-item.has-submenu:hover .submenu-arrow {
    color: #1a73e8 !important;
}

.nav-item.has-submenu.active .submenu-arrow {
    transform: rotate(180deg) !important;
    color: #1a73e8 !important;
}

/* Submenu container - ensure it displays properly when active */
.submenu {
    display: none !important;
    background: #f8f9fa !important;
    border-radius: 0 0 4px 4px !important;
    overflow: hidden !important;
    max-height: 300px !important;
    overflow-y: auto !important;
    margin: 0 4px 4px 4px !important;
    padding: 2px 0 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.nav-item.has-submenu.active .submenu {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Alternative submenu display for direct child containers */
.nav-item.has-submenu.active + .submenu,
.nav-item.has-submenu.active .submenu {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    max-height: none !important;
}

/* Ensure submenu items are visible */
.submenu .submenu-item {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Submenu item styling */
.submenu-item {
    display: flex !important;
    align-items: center !important;
    padding: 4px 10px 4px 25px !important;
    color: #333333 !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    font-size: 12px !important;
    border-left: 2px solid transparent !important;
    border-radius: 3px !important;
    margin: 0px 2px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.submenu-item:hover {
    background: #f0f7ff !important;
    color: #1a73e8 !important;
    border-left-color: #1a73e8 !important;
}

.submenu-item.active {
    background: #e8f0fe !important;
    color: #1a73e8 !important;
    border-left-color: #1a73e8 !important;
}

/* Change Password Page Styles */
.password-change-container {
    max-width: 800px !important;
    margin: 0 auto !important;
    background: white !important;
    border-radius: 12px !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05) !important;
    border: 1px solid #e2e8f0 !important;
}

.password-change-container .header {
    padding: 2rem !important;
    border-bottom: 1px solid #e2e8f0 !important;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
    color: white !important;
    border-radius: 12px 12px 0 0 !important;
}

.password-change-container .header h1 {
    margin: 0 !important;
    font-size: 1.75rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.password-change-container .content {
    padding: 2rem !important;
}

.password-form .form-section {
    margin-bottom: 2rem !important;
}

.password-form .form-section h2 {
    font-size: 1.25rem !important;
    color: #1e293b !important;
    margin: 0 0 1rem 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.user-info-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
    gap: 1rem !important;
    background: #f8fafc !important;
    padding: 1.5rem !important;
    border-radius: 8px !important;
    border: 1px solid #e2e8f0 !important;
}

.info-item label {
    display: block !important;
    font-size: 0.875rem !important;
    color: #64748b !important;
    margin-bottom: 0.25rem !important;
    font-weight: 500 !important;
}

.info-value {
    font-size: 1rem !important;
    color: #1e293b !important;
    font-weight: 600 !important;
}

.password-form .form-group {
    margin-bottom: 1.5rem !important;
}

.password-form .form-group label {
    display: block !important;
    font-size: 0.95rem !important;
    color: #374151 !important;
    margin-bottom: 0.5rem !important;
    font-weight: 600 !important;
}

.required {
    color: #ef4444 !important;
    margin-left: 0.25rem !important;
}

.form-control {
    width: 100% !important;
    padding: 0.75rem 1rem !important;
    border: 1px solid #d1d5db !important;
    border-radius: 6px !important;
    font-size: 1rem !important;
    transition: all 0.3s ease !important;
}

.form-control:focus {
    outline: none !important;
    border-color: #667eea !important;
    box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1) !important;
}

.text-muted {
    color: #6b7280 !important;
    font-size: 0.875rem !important;
}

.password-input-wrapper {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
}

.password-input-wrapper input {
    flex: 1 !important;
    padding-right: 3rem !important;
}

.toggle-password {
    position: absolute !important;
    right: 0.75rem !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    color: #6b7280 !important;
    padding: 0.25rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.toggle-password:hover {
    color: #374151 !important;
}

.password-strength-meter {
    height: 4px !important;
    background: #e5e7eb !important;
    border-radius: 2px !important;
    margin-top: 0.5rem !important;
    overflow: hidden !important;
}

.strength-bar {
    height: 100% !important;
    width: 0% !important;
    transition: all 0.3s ease !important;
    background: #ef4444 !important;
}

.strength-bar.weak {
    width: 33% !important;
    background: #ef4444 !important;
}

.strength-bar.medium {
    width: 66% !important;
    background: #f59e0b !important;
}

.strength-bar.strong {
    width: 100% !important;
    background: #10b981 !important;
}

.password-hint {
    display: block !important;
    margin-top: 0.5rem !important;
    color: #6b7280 !important;
    font-size: 0.875rem !important;
}

.form-actions {
    display: flex !important;
    gap: 1rem !important;
    padding-top: 1.5rem !important;
    border-top: 1px solid #e2e8f0 !important;
}

.password-form .btn {
    padding: 0.75rem 1.5rem !important;
    border: none !important;
    border-radius: 6px !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    transition: all 0.3s ease !important;
}

.password-form .btn-primary {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
    color: white !important;
}

.password-form .btn-primary:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4) !important;
}

.password-form .btn-secondary {
    background: #6b7280 !important;
    color: white !important;
}

.password-form .btn-secondary:hover {
    background: #4b5563 !important;
}

.password-form .btn-default {
    background: #e5e7eb !important;
    color: #374151 !important;
}

.password-form .btn-default:hover {
    background: #d1d5db !important;
}

.password-form .alert {
    padding: 1rem 1.5rem !important;
    border-radius: 6px !important;
    margin-bottom: 1.5rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.password-form .alert-success {
    background: #d1fae5 !important;
    color: #065f46 !important;
    border: 1px solid #a7f3d0 !important;
}

.password-form .alert-danger {
    background: #fee2e2 !important;
    color: #991b1b !important;
    border: 1px solid #fecaca !important;
}

.password-form .alert-warning {
    background: #fef3c7 !important;
    color: #92400e !important;
    border: 1px solid #fde68a !important;
}

@media (max-width: 768px) {
    .password-change-container .header {
        padding: 1.5rem !important;
    }
    
    .password-change-container .content {
        padding: 1.5rem !important;
    }
    
    .user-info-grid {
        grid-template-columns: 1fr !important;
    }
    
    .form-actions {
        flex-direction: column !important;
    }
    
    .password-form .btn {
        width: 100% !important;
        justify-content: center !important;
    }
}

/* Branch Permissions Page Styles */
.branch-permissions-container {
    max-width: 1200px !important;
    margin: 0 auto !important;
    background: white !important;
    border-radius: 12px !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05) !important;
    border: 1px solid #e2e8f0 !important;
}

.branch-permissions-container .header {
    padding: 2rem !important;
    border-bottom: 1px solid #e2e8f0 !important;
    background: linear-gradient(135deg, #059669 0%, #047857 100%) !important;
    color: white !important;
    border-radius: 12px 12px 0 0 !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.branch-permissions-container .header h1 {
    margin: 0 !important;
    font-size: 1.75rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.branch-permissions-container .content {
    padding: 2rem !important;
}

.branch-permission-form .form-section {
    margin-bottom: 2rem !important;
}

.branch-permission-form .form-section h2 {
    font-size: 1.25rem !important;
    color: #1e293b !important;
    margin: 0 0 1rem 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.branch-permission-form .form-section p {
    color: #64748b !important;
    margin-bottom: 1.5rem !important;
}

.branch-list-container {
    display: flex !important;
    flex-direction: column !important;
    gap: 1rem !important;
}

.branch-item-row {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1.25rem !important;
    background: #f8fafc !important;
    border: 2px solid #e2e8f0 !important;
    border-radius: 8px !important;
    transition: all 0.3s ease !important;
}

.branch-item-row:hover {
    background: #f1f5f9 !important;
    border-color: #059669 !important;
    transform: translateX(3px) !important;
    box-shadow: 0 4px 12px rgba(5, 150, 105, 0.15) !important;
}

.toggle-switch {
    position: relative !important;
    display: inline-block !important;
    width: 50px !important;
    height: 24px !important;
    flex-shrink: 0 !important;
}

.toggle-switch input {
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
}

.slider {
    position: absolute !important;
    cursor: pointer !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background-color: #cbd5e1 !important;
    transition: .4s !important;
    border-radius: 24px !important;
}

.slider:before {
    position: absolute !important;
    content: "" !important;
    height: 16px !important;
    width: 16px !important;
    left: 4px !important;
    bottom: 4px !important;
    background-color: white !important;
    transition: .4s !important;
    border-radius: 50% !important;
}

input:checked + .slider {
    background-color: #059669 !important;
}

input:checked + .slider:before {
    transform: translateX(26px) !important;
}

.branch-details-card {
    flex: 1 !important;
    min-width: 0 !important;
}

.branch-name {
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: #1e293b !important;
    margin-bottom: 0.5rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.branch-name i {
    color: #059669 !important;
}

.branch-meta {
    display: flex !important;
    gap: 1.5rem !important;
    flex-wrap: wrap !important;
}

.branch-code {
    font-size: 0.875rem !important;
    color: #64748b !important;
}

.branch-location {
    font-size: 0.875rem !important;
    color: #64748b !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.25rem !important;
}

.branch-location i {
    color: #3b82f6 !important;
}

.no-branches-message {
    text-align: center !important;
    padding: 3rem 2rem !important;
    background: #f8fafc !important;
    border: 2px dashed #cbd5e1 !important;
    border-radius: 8px !important;
}

.no-branches-message i {
    font-size: 3rem !important;
    color: #cbd5e1 !important;
    margin-bottom: 1rem !important;
    display: block !important;
}

.no-branches-message p {
    color: #64748b !important;
    font-size: 1rem !important;
    margin: 0 !important;
}

.current-permissions {
    margin-top: 2rem !important;
    padding: 1.5rem !important;
    background: #f8fafc !important;
    border-radius: 8px !important;
    border: 1px solid #e2e8f0 !important;
}

.current-permissions h3 {
    margin: 0 0 1rem 0 !important;
    font-size: 1.1rem !important;
    color: #1e293b !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.permission-list {
    min-height: 60px !important;
}

.permission-tags {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.75rem !important;
}

.permission-tag {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 0.5rem 1rem !important;
    background: white !important;
    border: 1px solid #059669 !important;
    border-radius: 20px !important;
    color: #059669 !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
}

.permission-tag i {
    font-size: 0.75rem !important;
}

.permission-tag small {
    color: #64748b !important;
    margin-left: 0.25rem !important;
    padding-left: 0.5rem !important;
    border-left: 1px solid #e2e8f0 !important;
}

.no-permissions {
    text-align: center !important;
    padding: 2rem !important;
    color: #9ca3af !important;
}

.no-permissions i {
    font-size: 2rem !important;
    display: block !important;
    margin-bottom: 0.5rem !important;
}

.no-permissions p {
    margin: 0 !important;
    font-size: 0.875rem !important;
}

.branch-permission-form .alert {
    padding: 1rem 1.5rem !important;
    border-radius: 6px !important;
    margin-bottom: 1.5rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.branch-permission-form .alert-success {
    background: #d1fae5 !important;
    color: #065f46 !important;
    border: 1px solid #a7f3d0 !important;
}

.branch-permission-form .alert-danger {
    background: #fee2e2 !important;
    color: #991b1b !important;
    border: 1px solid #fecaca !important;
}

.branch-permission-form .alert-warning {
    background: #fef3c7 !important;
    color: #92400e !important;
    border: 1px solid #fde68a !important;
}

@media (max-width: 768px) {
    .branch-permissions-container .header {
        padding: 1.5rem !important;
        flex-direction: column !important;
        gap: 1rem !important;
    }
    
    .branch-permissions-container .content {
        padding: 1.5rem !important;
    }
    
    .branch-item-row {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 1rem !important;
    }
    
    .toggle-switch {
        width: 100% !important;
        display: block !important;
        margin-bottom: 1rem !important;
    }
    
    .branch-meta {
        flex-direction: column !important;
        gap: 0.5rem !important;
    }
    
    .permission-tags {
        justify-content: center !important;
    }
}
