.fab-container {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 1000; /* Ensure it's above other content */
}

.fab-create-consulta {
    width: 56px; /* Standard FAB size */
    height: 56px; /* Standard FAB size */
    border-radius: 50%; /* Make it circular */
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem; /* Size of the plus icon */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Add some shadow for depth */
}

.fab-create-consulta i {
    line-height: 1; /* Adjust icon vertical alignment */
}

/* Estilos para el tema claro */
html[data-theme='light'] {
    /* Colores de fondo */
    --background-color: #f8f9fa;
    --card-background-color: #ffffff;
    --navbar-background-color: #ffffff;
    --sidebar-background-color: #ffffff;
    --footer-background-color: #ffffff;
    --table-header-background-color: #e9ecef;

    /* Colores de texto */
    --text-color: #212529;
    --text-muted-color: #6c757d;
    --heading-color: #343a40;

    /* Colores de borde */
    --border-color: #dee2e6;
    --input-border-color: #ced4da;

    /* Sombras */
    --box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    --card-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

/* Estilos para el tema oscuro */
html[data-theme='dark'] {
    /* Colores de fondo */
    --background-color: #212529;
    --card-background-color: #343a40;
    --navbar-background-color: #343a40;
    --sidebar-background-color: #343a40;
    --footer-background-color: #343a40;
    --table-header-background-color: #495057;

    /* Colores de texto */
    --text-color: #e9ecef;
    --text-muted-color: #adb5bd;
    --heading-color: #f8f9fa;

    /* Colores de borde */
    --border-color: #495057;
    --input-border-color: #6c757d;

    /* Sombras */
    --box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.4);
    --card-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.2);
}

/* Aplicación de variables CSS */
body {
    background-color: var(--background-color);
    color: var(--text-color);
    transition: background-color 0.3s ease, color 0.3s ease;
}

.card, .modal-content, .offcanvas {
    background-color: var(--card-background-color);
    color: var(--text-color);
    border-color: var(--border-color);
    box-shadow: var(--card-shadow);
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.navbar {
    background-color: var(--navbar-background-color) !important;
    border-bottom: 1px solid var(--border-color);
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

.navbar .nav-link, .navbar .navbar-brand, .navbar .dropdown-item {
    color: var(--text-color) !important;
}

.navbar .nav-link:hover, .navbar .dropdown-item:hover {
    color: var(--text-muted-color) !important;
}

.form-control, .form-select {
    background-color: var(--card-background-color);
    color: var(--text-color);
    border-color: var(--input-border-color);
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

.form-control:focus, .form-select:focus {
    background-color: var(--card-background-color);
    color: var(--text-color);
    border-color: var(--primary-color); /* Asumiendo que tienes una variable para el color primario */
}

.table {
    color: var(--text-color);
    transition: color 0.3s ease;
}

.table thead {
    background-color: var(--table-header-background-color);
    color: var(--heading-color);
    transition: background-color 0.3s ease, color 0.3s ease;
}

.modal-header, .offcanvas-header {
    border-bottom-color: var(--border-color);
}

.modal-footer, .offcanvas-footer {
    border-top-color: var(--border-color);
}

.list-group-item {
    background-color: var(--card-background-color);
    color: var(--text-color);
    border-color: var(--border-color);
}

/* Estilos para el calendario en temas */
.calendar-container {
    background-color: var(--card-background-color);
    box-shadow: var(--card-shadow);
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

.calendar-header {
    background-color: var(--navbar-background-color);
    border-bottom-color: var(--border-color);
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

.calendar-header .calendar-title {
    color: var(--heading-color);
    transition: color 0.3s ease;
}

.calendar-day-header {
    background-color: var(--navbar-background-color);
    border-bottom-color: var(--border-color);
    border-left-color: var(--border-color);
    color: var(--heading-color);
    transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}

.time-slot-header {
    background-color: var(--navbar-background-color);
    border-bottom-color: var(--border-color);
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

.time-slot-label {
    color: var(--text-muted-color);
    border-right-color: var(--border-color);
    transition: color 0.3s ease, border-color 0.3s ease;
}

.calendar-day-column {
    border-left-color: var(--border-color);
    transition: border-color 0.3s ease;
}

.hour-line-bg {
    border-top-color: var(--border-color);
    transition: border-color 0.3s ease;
}

/* Estilos para el botón de cambio de tema */
.theme-toggle {
    background: none;
    border: none;
    color: var(--text-color); /* Utiliza la variable de color de texto del tema */
    font-size: 1.5rem; /* Ajusta el tamaño del icono */
    cursor: pointer;
    padding: 0.5rem;
    transition: color 0.3s ease;
}

.theme-toggle:hover {
    color: var(--text-muted-color); /* Un color ligeramente más claro/oscuro al pasar el ratón */
}