
/* Custom styles for the Power BI Portal */

body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}


footer {
    margin-top: auto;
}

/* Card hover effect */
.card {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card:hover {
    transform: translateY(-15px);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
}

/* Report container styling */
#reportContainer {
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    overflow: hidden;
}

/* Make navbar sticky */
.navbar {
    position: sticky;
    top: 0;
    z-index: 1000;
}

/* Improve table readability */
.table th {
    background-color: #f8f9fa;
}

/* Custom button styling */
.btn-primary {
    background-color: #3b5998;
    border-color: #3b5998;
}

.btn-primary:hover {
    background-color: #2d4373;
    border-color: #2d4373;
}

/* Login page styling */
.login-container {
    max-width: 400px;
    margin: 0 auto;
    padding: 20px;
}



/* Chatbot */

/* Chat button styles */

#chatButton {

    position: fixed;

    bottom: 30px;

    right: 30px;

    width: 60px;

    height: 60px;

    border-radius: 50%;

    background-color: #0d6efd;

    color: white;

    border: none;

    box-shadow: 0 4px 8px rgba(0,0,0,0.2);

    display: flex;

    justify-content: center;

    align-items: center;

    cursor: pointer;

    z-index: 1000;

    transition: all 0.3s ease;

}



#chatButton:hover {

    transform: scale(1.05);

    background-color: #0b5ed7;

}



/* Chat dialog styles */

#chatDialog {

    position: fixed;

    bottom: 100px;

    right: 30px;

    width: 350px;

    height: 450px;

    background-color: white;

    border-radius: 10px;

    box-shadow: 0 5px 15px rgba(0,0,0,0.3);

    display: none;

    flex-direction: column;

    z-index: 1000;

    overflow: hidden;

}



#chatHeader {

    padding: 15px;

    border-bottom: 1px solid #f0f0f0;

    display: flex;

    justify-content: space-between;

    align-items: center;

}



#chatMessages {

    flex-grow: 1;

    padding: 15px;

    overflow-y: auto;

    color: #000;

}



.user-message {

    display: flex;

    justify-content: flex-end;

    margin-bottom: 15px;

}



.user-message-content {

    background-color: #0d6efd;

    color: white;

    padding: 10px 15px;

    border-radius: 18px 18px 0 18px;

    max-width: 80%;

}



.bot-message {

    display: flex;

    justify-content: flex-start;

    margin-bottom: 15px;

}



.bot-message-content {

    background-color: #f1f1f1;

    padding: 10px 15px;

    border-radius: 18px 18px 18px 0;

    max-width: 80%;

}



#chatInputArea {

    padding: 15px;

    border-top: 1px solid #f0f0f0;

    display: flex;

}



#chatInput {

    flex-grow: 1;

    border: 1px solid #ddd;

    border-radius: 20px;

    padding: 8px 15px;

    margin-right: 10px;

}



#sendMessage {

    width: 40px;

    height: 40px;

    border-radius: 50%;

    background-color: #0d6efd;

    color: white;

    border: none;

    display: flex;

    justify-content: center;

    align-items: center;

}



.typing-indicator {

    display: flex;

    padding: 10px 15px;

    background-color: #f1f1f1;

    border-radius: 18px 18px 18px 0;

    width: fit-content;

    margin-bottom: 15px;

}



.typing-indicator span {

    height: 8px;

    width: 8px;

    background-color: #666;

    border-radius: 50%;

    display: inline-block;

    margin-right: 5px;

    animation: typing 1.3s ease-in-out infinite;

}



.typing-indicator span:nth-child(2) {

    animation-delay: 0.15s;

}



.typing-indicator span:nth-child(3) {

    animation-delay: 0.3s;

}



@keyframes typing {

    0% { transform: translateY(0); }

    50% { transform: translateY(-5px); }

    100% { transform: translateY(0); }

}


/* Dark mode styles */
        :root {
            --body-bg: #fff;
            --body-color: #212529;
            --sidebar-bg: #f8f9fa;
            --sidebar-color: #495057;
            --sidebar-hover: #e9ecef;
            --sidebar-active-bg: #212529;
            --sidebar-active-color: #fff;
            --navbar-bg: #212529;
            --navbar-color: #fff;
            --card-bg: #fff;
            --card-border: rgba(0, 0, 0, 0.125);
        }

        [data-theme="dark"] {
            --body-bg: #212529;
            --body-color: #f8f9fa;
            --sidebar-bg: #343a40;
            --sidebar-color: #e9ecef;
            --sidebar-hover: #495057;
            --sidebar-active-bg: #0d6efd;
            --sidebar-active-color: #fff;
            --navbar-bg: #111315;
            --navbar-color: #fff;
            --card-bg: #343a40;
            --card-border: rgba(255, 255, 255, 0.125);
        }

        body {
            overflow-x: hidden;
            background-color: var(--body-bg);
            color: var(--body-color);
            transition: background-color 0.3s ease, color 0.3s ease;
        }

        .card {
            background-color: var(--card-bg);
            border-color: var(--card-border);
        }

        #sidebar-wrapper {
            min-height: 100vh;
            width: 250px;
            margin-left: -250px;
            transition: margin 0.25s ease-out;
            background-color: var(--sidebar-bg);
        }

        #sidebar-wrapper .sidebar-heading {
            padding: 0.875rem 1.25rem;
            font-size: 1.2rem;
        }

        #sidebar-wrapper .list-group {
            width: 250px;
        }

        #page-content-wrapper {
            min-width: 100vw;
        }

        body.sb-sidenav-toggled #sidebar-wrapper {
            margin-left: 0;
        }

        @media (min-width: 768px) {
            #sidebar-wrapper {
                margin-left: 0;
            }

            #page-content-wrapper {
                min-width: 0;
                width: 100%;
            }

            body.sb-sidenav-toggled #sidebar-wrapper {
                margin-left: -250px;
            }

            .main-content {
                margin-left: 250px;
                transition: margin 0.25s ease-out;
            }

            body.sb-sidenav-toggled .main-content {
                margin-left: 0;
            }
        }

        /* Sidebar menu styles */
        .sidebar-menu .list-group-item {
            border: none;
            border-radius: 0;
            background-color: var(--sidebar-bg);
            color: var(--sidebar-color);
        }

        .sidebar-menu .list-group-item-action:hover {
            background-color: var(--sidebar-hover);
        }

        .sidebar-menu .list-group-item-action.active {
            background-color: var(--sidebar-active-bg);
            color: var(--sidebar-active-color);
        }

        .sidebar-menu .submenu {
            padding-left: 1.5rem;
        }

        /* Navbar styles */
        .navbar-dark {
            background-color: var(--navbar-bg) !important;
            color: var(--navbar-color);
        }

        /* Footer adjustments */
        footer {
            transition: margin 0.25s ease-out;
            background-color: var(--sidebar-bg) !important;
            color: var(--sidebar-color);
        }

        @media (min-width: 768px) {
            footer {
                margin-left: 250px;
            }

            body.sb-sidenav-toggled footer {
                margin-left: 0;
            }
        }
        
        /* Theme toggle button */
        .theme-toggle-btn {
            cursor: pointer;
            padding: 5px 10px;
            border-radius: 20px;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.3s ease;
        }
        
        .theme-toggle-btn:hover {
            opacity: 0.8;
        }

        /* Add these variables to your :root CSS selector */
        :root {
            /* Existing variables */
            --body-bg: #fff;
            --body-color: #212529;
            
            /* Table-specific variables */
            --table-bg: #fff;
            --table-color: #212529;
            --table-border-color: #dee2e6;
            --table-striped-odd-bg: rgba(0, 0, 0, 0.05);
            --table-striped-even-bg: #fff;
            --table-hover-bg: rgba(0, 0, 0, 0.075);
        }

        /* Add these to your [data-theme="dark"] CSS selector */
        [data-theme="dark"] {
            /* Existing variables */
            --body-bg: #212529;
            --body-color: #f8f9fa;
            
            /* Table-specific variables for dark mode */
            --table-bg: #343a40;
            --table-color: #f8f9fa;
            --table-border-color: #495057;
            --table-striped-odd-bg: rgba(255, 255, 255, 0.05);
            --table-striped-even-bg: #343a40;
            --table-hover-bg: rgba(255, 255, 255, 0.075);
        }

        /* Basic table styles */
        table {
            background-color: var(--table-bg);
            color: var(--table-color) !important;
            border-color: var(--table-border-color);
        }

        /* Force all table cells to use the theme color */
        table th, 
        table td {
            color: var(--table-color) !important;
            border-color: var(--table-border-color) !important;
        }

        /* Handle alternating row colors for all tables */
        table tr:nth-child(odd) {
            background-color: var(--table-striped-odd-bg) !important;
        }

        table tr:nth-child(even) {
            background-color: var(--table-striped-even-bg) !important;
        }

        /* Hover effect for any table */
        table tr:hover {
            background-color: var(--table-hover-bg) !important;
        }

        /* Target Bootstrap-specific table classes */
        .table {
            color: var(--table-color) !important;
            background-color: var(--table-bg);
            border-color: var(--table-border-color);
        }

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

        .table-striped tbody tr:nth-of-type(even) {
            background-color: var(--table-striped-even-bg) !important;
        }

        /* Force consistent colors for badges and special elements inside tables */
        [data-theme="dark"] table .badge,
        [data-theme="dark"] .table .badge {
            border: 1px solid rgba(255, 255, 255, 0.2);
        }

        /* Fix for any badges shown in the table */
        [data-theme="dark"] .badge-primary,
        [data-theme="dark"] .badge-secondary,
        [data-theme="dark"] .badge-info,
        [data-theme="dark"] .badge-light {
            color: var(--table-color);
        }

        /* Fix buttons in table to ensure visibility */
        [data-theme="dark"] table .btn-outline-primary,
        [data-theme="dark"] table .btn-outline-secondary,
        [data-theme="dark"] table .btn-outline-info {
            color: #fff;
            border-color: #fff;
        }

        /* Style the admin/user/new_member badges */
        [data-theme="dark"] .admin,
        [data-theme="dark"] .user,
        [data-theme="dark"] .new_member {
            color: white !important;
        }

        [data-theme="dark"] .message.user{
            color: black !important;
        }

        /* Ensure that the "Edit" and "Delete" buttons are visible */
        [data-theme="dark"] .btn-outline-primary {
            color: #007bff;
            border-color: #007bff;
        }

        [data-theme="dark"] .btn-outline-danger {
            color: #dc3545;
            border-color: #dc3545;
        }

        [data-theme="dark"] .btn-outline-primary:hover {
            color: #fff;
            background-color: #007bff;
        }

        [data-theme="dark"] .btn-outline-danger:hover {
            color: #fff;
            background-color: #dc3545;
        }