:root{
    /* Fuentes */
    --fuentePrincipalDash: "Inter", sans-serif;
    --fuenteSecundariaDash: "Inter", sans-serif;
    --fuenteDestacadaDash: "Inter", sans-serif;
}





/* 
    Listado: slide 2 filas 3 columnas 
*/
.dqa-schedule-slider { opacity: 0; visibility: hidden; transition: opacity 1s ease; }
.dqa-schedule-slider.slick-initialized { visibility: visible; opacity: 1; }

/* Aseguramos que el contenedor del slide use Grid, y establecemos 3 columnas por defecto */
.dqa-schedule-slider .dqa-slide-grid { display: grid !important; grid-template-columns: repeat(3, 1fr);  gap: 3rem; width: 100%;  }
/* La tarjeta individual */
.dqa-session-card { width: auto !important; } /* Aseguramos que las tarjetas no tengan estilos de ancho fijo que rompan el Grid */
/* Tablet (768px y abajo) */
@media (max-width: 768px) {
    /* 2 columnas */
    .dqa-schedule-slider .dqa-slide-grid { grid-template-columns: repeat(2, 1fr); gap: 2rem; }
}
/* Móvil (480px y abajo) */
@media (max-width: 480px) {
    /* 1 columna */
    .dqa-schedule-slider .dqa-slide-grid { grid-template-columns: 1fr; gap: 1.3rem; }
}
/*
    Card
*/
.dqa-schedule-slider { font-family: var(--fuentePrincipalDash) !important; }
.dqa-schedule-slider .card-content { background-color: var(--colorVerde); padding:2.2rem 2.7rem; min-height:6rem; border-radius:0.8rem; display:flex; flex-direction: column; align-content:center; }
.dqa-schedule-slider .card-content .card-title { font-family: var(--fuentePrincipalDash) !important; font-size:1.6rem; font-weight:600; color:#000; }
.dqa-schedule-slider .card-content .card-date-time { font-family: var(--fuentePrincipalDash) !important; font-size:1.4rem; font-weight:400; color:#000; }
@media screen and (min-width: 1024px) {
    .dqa-schedule-slider .card-content { min-height:10rem; border-radius:1rem; }
    .dqa-schedule-slider .card-content .card-title { font-size:1.8rem; }
    .dqa-schedule-slider .card-content .card-date-time { font-size:1.6rem; } 
}

    /*
        Slider nav 
    */
    .slider-nav-schedule { display: flex; gap: 1rem; z-index: 10; justify-content:center; margin-top:2rem; }
    .slider-nav-schedule { visibility: hidden; opacity: 0; transition: opacity 0.3s ease; }
    .slider-nav-schedule.ready { visibility: visible; opacity: 1; }
    .slider-nav-schedule .slick-arrow.slick-disabled { opacity:0.5; cursor:default; }
    .slider-nav-schedule .slick-arrow { border:none; width: 3.2rem; height: 3.2rem; border-radius: 50%; padding:0; }
    .slider-nav-schedule .slick-arrow i { font-size:1.4em; }
    .slider-nav-schedule .slick-arrow { background-color:#fff; }
    .slider-nav-schedule .slick-arrow:hover { background-color: #D3D898; }
    .slider-nav-schedule .slick-arrow i { color:#000; }
    .slider-nav-schedule .slick-arrow.prev {  }
    .slider-nav-schedule .slick-arrow.next {  }
    .slider-nav-schedule .slick-arrow.slick-disabled:hover { background-color: #fff; }
    .slider-nav-schedule .slick-arrow:focus { background-color:transparent; }
    @media screen and (min-width: 1024px) {
        .slider-nav-schedule { justify-content:flex-end; }
        .slider-nav-schedule .slick-arrow { width: 4.8rem; height: 4.8rem; }
        .slider-nav-schedule .slick-arrow i { font-size:2em; }
    }







/* 
    Listado Slide de Alumnos (3x3 o N filas de 3) 
*/
.dqa-teacher-students-list .dqa-students-slider { opacity: 0; visibility: hidden; transition: opacity 1s ease; }
.dqa-teacher-students-list .dqa-students-slider.slick-initialized { visibility: visible; opacity: 1; }

.dqa-teacher-students-list .dqa-students-slider .dqa-student-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; }

/* Estilo de la Tarjeta de Alumno */
.dqa-student-card { display: flex; justify-content: space-between; align-items: center; padding: 1.3rem 1.9rem; background-color: var(--colorLavandaClaro); border-radius: 1rem; text-decoration: none; color: #000; transition: background-color 0.2s; height: 6rem; }
.dqa-student-card:hover { background-color: var(--colorLavandaClaro); }
    @media screen and (min-width: 1024px) {
        .dqa-student-card { height: 9rem; }        
    }
.dqa-student-grid.slick-slide .dqa-student-info { display: flex; align-items: center; font-weight: bold; }
.dqa-student-grid.slick-slide .dqa-student-info span { font-family: var(--fuentePrincipalDash) !important; font-size:1.6rem; font-weight:600; }
.dqa-student-grid.slick-slide .dqa-student-avatar { width: 4rem; height: 4rem; border-radius: 50%; object-fit: cover; margin-right: 3.5rem; }
.dqa-student-grid.slick-slide .dqa-arrow-icon { color: #999; }
    @media screen and (min-width: 1024px) {
        .dqa-student-grid.slick-slide .dqa-student-info span { font-size:1.8rem; }   
        .dqa-student-grid.slick-slide .dqa-student-avatar { width: 6.4rem; height: 6.4rem; }     
    }
@media (max-width: 768px) {
    /* Tablet: 2 columnas */ 
    .dqa-teacher-students-list .dqa-students-slider .dqa-student-grid { grid-template-columns: repeat(2, 1fr);  }
}
@media (max-width: 480px) {
    /* Móvil: 1 columna */
    .dqa-teacher-students-list .dqa-students-slider .dqa-student-grid { grid-template-columns: 1fr; }
}
    /*
        Slider nav 
    */
    .slider-nav-students { display: flex; gap: 1rem; z-index: 10; justify-content:center; margin-top:2rem; }
    .slider-nav-students { visibility: hidden; opacity: 0; transition: opacity 0.3s ease; }
    .slider-nav-students.ready { visibility: visible; opacity: 1; }
    .slider-nav-students .slick-arrow.slick-disabled { opacity:0.5; cursor:default; }
    .slider-nav-students .slick-arrow { border:none; width: 3.2rem; height: 3.2rem; border-radius: 50%; padding:0; }
    .slider-nav-students .slick-arrow i { font-size:1.4em; }

    .slider-nav-students .slick-arrow { background-color:#fff; }
    .slider-nav-students .slick-arrow:hover { background-color: var(--colorLavandaClaro); }
    .slider-nav-students .slick-arrow i { color:#000; }
    .slider-nav-students .slick-arrow.prev {  }
    .slider-nav-students .slick-arrow.next {  }
    .slider-nav-students .slick-arrow.slick-disabled:hover { background-color: #fff; }
    .slider-nav-students .slick-arrow:focus { background-color:transparent; }

    @media screen and (min-width: 1024px) {
        .slider-nav-students { justify-content:flex-end; }
        .slider-nav-students .slick-arrow { width: 4.8rem; height: 4.8rem; }
        .slider-nav-students .slick-arrow i { font-size:2em; }
    }







/*
    Filtro de Sesiones
*/


/* Filtro - Select */
.dqa-filtered-sessions-component { margin-bottom: 0; }
.dqa-filters-bar { display: flex; gap: 2rem; margin-bottom: 2.4rem; }
.dqa-filter-select { padding: 1rem 4rem; border-radius: 1rem; border: 1px solid var(--colorLavandaClaro2); font-size: 1.6rem; background-color: var(--colorLavandaClaro2); cursor: pointer; }

    /* custom select - profile page */

    /* Oculta los selectores de filtro originales y Muestra el contenedor de Select2 */
    .dqa-filter-select { display: none;  }
    .select2-container { display: inline-block; }

    .page-id-2438 .select2-container .select2-selection { border-radius:10rem !important; border-color:rgba(0,0,0,0.3) !important; }
    .page-id-2438 .select2-container .select2-selection--single .select2-selection__rendered { padding-left:2rem; }
    .page-id-2438 .select2-container--default .select2-results__option--highlighted[aria-selected], 
    .page-id-2438 .select2-container--default .select2-results__option--highlighted[data-selected] { 
        background-color: var(--colorVerde2); color: #000; }
    .page-id-2438 .select2-container--default .select2-results__option[aria-selected=true], 
    .page-id-2438 .select2-container--default .select2-results__option[data-selected=true] {
        background-color: var(--colorVerde2); color: #000; }
    .page-id-2438 .select2-container--default .select2-search--dropdown .select2-search__field { font-size:2rem; border-radius:2rem; }
    .page-id-2438 .select2-container .select2-dropdown, 
    .page-id-2438 .select2-container .select2-selection { border-color:rgba(0, 0, 0, 0.3) !important; border-top: 1px solid; }
    .page-id-2438 .select2-container.select2-container--open .select2-dropdown--below { border-top:1px solid; }


    /*  
        Data 
    */

    /* Estilo para el contenedor de las sesiones de un alumno */
    .dqa-student-sessions-container { margin-bottom: 5rem; }
    /* El nuevo wrapper que contiene el CARD y el BOTÓN */
    .dqa-session-row-wrapper { display: flex; flex-direction: column; align-items: center; gap: 2rem; margin-bottom: 1rem; }
    @media screen and (min-width: 1024px) {
        .dqa-session-row-wrapper { flex-direction: row; gap: 4rem; }
    }
    /* El Card de la Sesión (Topic | Date) */
    .dqa-session-card-content { flex-direction:column; flex-grow: 1; display: flex; justify-content: space-between; align-items: center; background-color: var(--colorVerde2);  border-radius: 1rem; padding: 2.2rem 4rem; width: 100%; height:auto; }
     @media screen and (min-width: 1024px) {
        .dqa-session-card-content { flex-direction:row; height: 7rem; }
     }
    /* Estilo para el nombre del producto */
    .dqa-row-topic { font-family: var(--fuentePrincipalDash) !important; font-size: 1.6rem; font-weight: 600; color: #000; flex-basis: 60%;  flex-shrink: 0; } /* Eliminar el max-width si lo tenías, ahora flex-grow lo controla */
    /* Estilo para la fecha/hora */
    .dqa-row-date { font-family: var(--fuentePrincipalDash) !important; font-size: 1.4rem; font-weight: 500; color: #000; text-align: right; flex-basis: 40%; flex-shrink: 0; }
    /* Contenedor del Botón 'Go live' (fuera del card) */
    .dqa-row-button { flex-shrink: 0; width: 12rem; }
    /* Estilo del Botón 'Go live' */
    .dqa-go-live-button { font-family: var(--fuentePrincipalDash) !important; background-color: var(--colorVerde); color: #000; padding: 1rem 4rem; border-radius: 1rem; text-decoration: none; font-size: 1.6rem !important; font-weight: bold; white-space: nowrap; display: inline-block; text-align: center; }
    /* Nombre del alumno */
    .dqa-current-session-title { font-family: var(--fuentePrincipalDash) !important; font-size:2rem !important; font-weight:600; margin-bottom:2.5rem; }
    @media screen and (min-width: 1024px) {
        .dqa-row-topic { font-size: 1.8rem; }
        .dqa-row-date { font-size: 1.6rem; }
    }




/*
    Chat
*/
.dqa-chat-header { border-bottom:1px solid #0A0A0A; }
.dqa-chat-header .dqa-recipient-info { display:flex; gap:2rem; align-items:center; padding:0 0 2rem 0; }
.dqa-chat-header .dqa-recipient-info img { width:5.4rem; height:5.4rem; border-radius:50%; object-fit:cover; }
.dqa-chat-header .dqa-recipient-info span { font-family: var(--fuentePrincipalDash); font-size:2rem; font-weight:600; }

.dqa-message-row { display: flex; margin: 2rem 0; }
.dqa-message-left { justify-content: flex-start; }
.dqa-message-right { justify-content: flex-end; }

/* Estilo Base de la Burbuja */
/* ======================================= */
/* 3. Burbuja de Mensaje y Cabecita (Tail) */
/* ======================================= */

/* Estilo Base de la Burbuja */
.dqa-message-bubble {
    position: relative;
    padding: 10px 15px;
    border-radius: 18px; /* Bordes redondeados */
    max-width: 70%; /* Limitar el ancho */
}

/* Burbuja del Mensaje Propio (Derecha) */
.dqa-own-message { background-color: var(--colorVerde4); color: #000; margin-right:1rem; }
/* Burbuja del Mensaje del Otro (Izquierda) */
.dqa-other-message { background-color: var(--colorLavandaClaro); color: #000; margin-left:1rem; }

    /* --- TAIL (La Cabecita) --- */
    /* Cabecita para mensajes de OTROS (Izquierda) */
    .dqa-other-message::before {
        content: "";
        position: absolute;
        /* Ajusta la posición de la 'cabecita' */
        top: 0;
        left: -1rem; /* Debe solaparse con la burbuja */
        /* Forma triangular usando bordes transparentes */
        width: 0;
        height: 0;
        border: 1rem solid transparent;
        border-right-color: var(--colorLavandaClaro);; /* Mismo color que el fondo de la burbuja */
        border-left: 0;
        border-top: 0; /* Asegura un punto agudo */
    }
    /* Cabecita para mensajes PROPIOS (Derecha) */
    .dqa-own-message::before {
        content: "";
        position: absolute;
        /* Ajusta la posición de la 'cabecita' */
        top: 0;
        right: -1rem; /* Debe solaparse con la burbuja */
        
        /* Forma triangular usando bordes transparentes */
        width: 0;
        height: 0;
        border: 1rem solid transparent;
        border-left-color: var(--colorVerde4);; /* Mismo color que el fondo de la burbuja */
        border-right: 0;
        border-top: 0; /* Asegura un punto agudo */
    }

    /* Opcional: Ajustar el borde en el lado de la cabecita para que parezca más natural */
    .dqa-other-message {
        border-top-left-radius: 0; /* Reducir el borde donde sale el tail */
    }
    .dqa-own-message {
        border-top-right-radius: 0; /* Reducir el borde donde sale el tail */
    }

/* Asegurar que la fila del mensaje justifique la burbuja */
.dqa-message-right {
    display: flex;
    justify-content: flex-end; /* Mueve la burbuja a la derecha */
}
.dqa-message-left {
    display: flex;
    justify-content: flex-start; /* Mueve la burbuja a la izquierda */
}

/* El footer (hora y botón) */
.dqa-message-footer {
    display: flex;
    justify-content: flex-end; /* Mueve la hora y el botón a la derecha */
    gap: 8px; /* Espacio entre hora y botón */
    margin-top: 5px;
}

.dqa-message-time {
    font-size: 0.75em;
    color: #666;
}




/*
    Botones de acción
    Borrar
*/
.dqa-message-footer .dqa-delete-btn { background-color: transparent; border: transparent; }
.dqa-message-footer .dqa-delete-btn:hover,
.dqa-message-footer .dqa-delete-btn:focus { background-color:transparent; } 


/* ======================================= */
/* ESTILOS DEL ESTADO DE LECTURA (VISTO) */
/* ======================================= */

.dqa-message-footer {
    /* Asegurar que el icono de estado esté alineado correctamente */
    display: flex;
    align-items: center; /* Alineación vertical */
    justify-content: flex-end; 
    gap: 8px; 
    margin-top: 5px;
}

.dqa-read-status {
    font-size: 0.7em; /* Pequeño, tamaño apropiado */
    margin-left: 5px; /* Separación de la hora */
}

/* Icono para mensajes enviados o recibidos (no leídos por el receptor) */
.dqa-read-status.dqa-sent {
    color: #A0A0A0; /* Gris (Enviado/Recibido) */
}

/* Icono para mensajes leídos por el receptor (el "visto" azul) */
.dqa-read-status.dqa-read {
    color: #4CAF50; /* Verde o Azul: Usa un color que destaque, WhatsApp usa verde */
}




/******
    Área de mensajes
*******/
#dqa-messages-area {
    /* Altura fija o máxima que fuerce el desbordamiento */
    /*height: 200px; /* o max-height: ... */
    max-height: 80rem;
    /* Propiedad clave para habilitar el scroll interno */
    overflow-y: auto; 
}




/* ======================================= */
/* ÁREA DE ENTRADA DEL CHAT (DISEÑO FINAL) */
/* ======================================= */

    /* Contenedor principal: actúa como el área que aloja el campo completo */
    .dqa-chat-input-area {
        /* Usamos position: relative para anclar el botón absolutamente dentro de esta área */
        position: relative; 
        display: flex; 
        padding: 10px 15px; /* Relleno general del área */
        background-color: #f7f7f7; /* Fondo sutil */
        border-top: 1px solid #eee;
    }

    /* Estilo del Textarea (El cuerpo principal de la burbuja) */
    #dqa-chat-message-input {
        flex-grow: 1;
        width: 100%;
        
        /* Diseño de la burbuja (fondo blanco y redondeado) */
        border: none; /* Quitamos el borde para que solo se vea el box-shadow */
        border-radius: 25px; 
        background-color: white; 
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05); /* Sombra suave para profundidad */
        
        /* Altura más corta y espacio para el botón: */
        /* El relleno derecho (60px) crea el espacio donde se posicionará el botón */
        padding: 10px 60px 10px 20px; 
        min-height: 40px; 
        max-height: 100px; /* Límite de crecimiento vertical */
        
        font-size: 14px;
        line-height: 1.4;
        resize: none; 
    }

    /* Quitar el borde al hacer foco */
    #dqa-chat-message-input:focus {
        outline: none;
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1); 
    }

    /* Estilo del Botón de Envío (Dentro de la burbuja) */
    .dqa-send-message-btn {
        /* CLAVE: Posicionamiento absoluto dentro de .dqa-chat-input-area */
        position: absolute;
        right: 25px; /* 25px de distancia del borde derecho del contenedor */
        
        /* CLAVE: Alineación vertical al centro */
        top: 50%;
        transform: translateY(-50%); 
        
        /* Diseño del botón (más pequeño y circular) */
        width: 30px;
        height: 30px;
        min-width: 30px; 
        min-height: 30px;
        border: none;
        border-radius: 50%; 
        background-color: #6a6ad4; /* Púrpura/Lavanda */
        
        /* Centrado y control */
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        cursor: pointer;
        transition: background-color 0.2s ease;
        z-index: 10; /* Asegura que esté sobre el textarea */
    }

    .dqa-send-message-btn:hover {
        background-color: #5858c4;
    }

    .dqa-send-message-btn:disabled {
        background-color: #b0b0b0; /* Gris cuando está deshabilitado */
        cursor: not-allowed;
    }

    /* Estilo del Icono SVG */
    .dqa-send-message-btn svg {
        width: 18px; 
        height: 18px;
        /*transform: rotate(45deg);*/
        fill: white;
    }






/* ========================================================== */
/* ESTILOS DE NOTIFICACIONES (HEADER) */
/* ========================================================== */

    .dqa-notifications-container {
        position: relative;
        /* Ajusta el z-index para que el panel se muestre sobre otros elementos */
        z-index: 1000; 
    }

    .dqa-notification-bell {
        cursor: pointer;
        font-size: 1.5em; /* Tamaño del ícono de campana */
        padding: 5px;
        position: relative;
        display: inline-block;
    }

    /* Badge (Globo Rojo de Conteo) */
    .dqa-notification-count {
        position: absolute;
        top: 0;
        right: 0;
        background-color: #f00; /* Rojo vibrante */
        color: white;
        font-size: 0.7em;
        font-weight: bold;
        border-radius: 50%;
        padding: 2px 6px;
        line-height: 1;
        min-width: 15px; /* Para que se vea bien incluso con un solo dígito */
        text-align: center;
    }

    .dqa-hidden {
        display: none !important;
    }

    /* Panel Desplegable */
    .dqa-notification-panel {
        position: absolute;
        /* Ajusta 'right' o 'left' según dónde esté la campana en el header */
        right: 0; 
        top: 100%;
        width: 350px; /* Ancho del panel */
        background-color: white;
        border: 1px solid #ddd;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
        border-radius: 8px;
        margin-top: 10px;
        overflow: hidden;
    }

    .dqa-panel-header, .dqa-panel-footer {
        padding: 10px 15px;
        font-weight: bold;
        border-bottom: 1px solid #eee;
    }

    .dqa-panel-footer {
        border-bottom: none;
        border-top: 1px solid #eee;
        text-align: center;
        color: #0073aa;
        cursor: pointer;
    }

    /* Items individuales de Notificación */
    .dqa-notification-list {
        max-height: 400px; /* Limitar la altura y permitir scroll */
        overflow-y: auto;
    }

    .dqa-notification-item {
        display: flex;
        align-items: flex-start;
        padding: 12px 15px;
        border-bottom: 1px solid #eee;
        cursor: pointer;
        background-color: #f7f7f7; /* Fondo para indicar que es nuevo */
    }

    .dqa-notification-item:hover {
        background-color: #e9e9e9;
    }

    .dqa-notification-avatar img {
        width: 40px;
        height: 40px;
        border-radius: 50%;
        margin-right: 10px;
    }

    .dqa-notification-content {
        flex-grow: 1;
        position: relative;
    }

    .dqa-notification-text {
        margin: 0;
        font-size: 0.9em;
        line-height: 1.4;
        color: #333;
    }

    .dqa-notification-time {
        display: block;
        font-size: 0.75em;
        color: #666;
        margin-top: 2px;
    }

    .dqa-notification-dot {
        /* El punto azul de Facebook */
        position: absolute;
        top: 5px;
        right: 0;
        width: 8px;
        height: 8px;
        background-color: #0073aa;
        border-radius: 50%;
    }

    .dqa-notification-empty {
        text-align: center;
        padding: 20px;
        font-style: italic;
        color: #999;
    }







/*
    DRIVE DOCUMENTOS
*/


    /* ========================================= */
    /* 1. Estilos del Contenedor de Documentos */
    /* ========================================= */

    .dqa-documents-list-container {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); /* Ejemplo de rejilla */
        gap: 20px;
        padding: 20px 0;
    }

    .dqa-document-card {
        /* Estilo del "cuadrado morado" */
        background-color: var(--colorLavandaClaro); /* Morado base */
        color: white;
        padding: 2rem 2.5rem;
        border-radius: 1rem;
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        position: relative; /* Importante para posicionar el botón de menú */
        cursor: default;
        /*box-shadow: 0 4px 6px rgba(0,0,0,0.1);*/
    }

    .dqa-doc-icon-wrapper {
        font-size: 40px;
        margin-bottom: 10px;
        display: none; /* icono del documento */
    }

    .dqa-doc-icon {
        /* Color de los iconos de Font Awesome */
        color: #fff;
    }

    .dqa-doc-title {
        font-size: 0.9em;
        font-weight: 500;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        width: 100%;
        color: #000;
        font-family: var(--fuentePrincipalDash);
    }

    .dqa-doc-menu-trigger {
        background-color: transparent !important;
        border: none;
        color: #000 !important;
        font-size: 1.1em;
        padding: 5px;
        cursor: pointer;
        position: absolute;
        top: 5px;
        right: 5px;
        opacity: 0.8;
        transition: opacity 0.2s;
    }

    .dqa-doc-menu-trigger:hover {
        opacity: 1;
    }


    /* ========================================= */
    /* 2. Estilos del Menú Contextual (CRUCIALES) */
    /* ========================================= */

    #dqa-context-menu {
        /* 🚨 CLAVE 1: Oculto por defecto (la clase .dqa-hidden lo hace) */
        display: none; 
        
        /* 🚨 CLAVE 2: Posicionamiento absoluto para flotar sobre el contenido */
        position: fixed;
        
        /* 🚨 CLAVE 3: Asegura que esté por encima de todos los elementos */
        z-index: 1000; 
        
        background-color: #fff;
        border: 1px solid #ddd;
        border-radius: 4px;
        box-shadow: 0 6px 12px rgba(0,0,0,0.175);
        min-width: 150px;
        padding: 5px 0;
    }

    /* La clase que usa JavaScript para mostrar/ocultar */
    .dqa-hidden { 
        display: none !important; 
    }

    /* Estilos de los ítems del menú */
    .dqa-menu-item {
        padding: 8px 15px;
        cursor: pointer;
        font-size: 0.9em;
        color: #333;
        display: flex;
        align-items: center;
    }

    .dqa-menu-item i {
        margin-right: 8px;
        width: 15px; /* Para alinear mejor los textos */
    }

    .dqa-menu-item:hover {
        background-color: #f5f5f5;
    }

    .dqa-menu-item-delete {
        color: #dc3545; /* Color de peligro para Eliminar */
    }


    /* ========================================= */
    /* 3. Estilos del Área de Subida (Upload Area) */
    /* ========================================= */

    .dqa-upload-area {
        /* 1. Dimensionamiento y Layout */
        width: 100%; /* Ocupa todo el ancho */
        min-height: 250px; /* Altura más grande */
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        text-align: center;
        padding: 30px;
        margin-top: 20px;

        /* 2. Apariencia Base */
        border: 2px dashed #ccc; /* Borde punteado para indicar zona de drop */
        border-radius: 10px;
        background-color: #f9f9f9;
        transition: all 0.3s ease; /* Transición suave para el efecto hover */
        cursor: pointer;
    }

    .dqa-upload-icon-container {
        font-size: 3em;
        color: #555;
        margin-bottom: 15px;
    }

    .dqa-upload-title {
        font-size: 1.2em;
        font-weight: 600;
        color: #333;
    }

    /* 🚨 CLAVE: Estilo para el estado de arrastre (drag-hover) 🚨 */
    .dqa-upload-area.drag-hover {
        /* 1. Usar el morado oscuro para que el borde sea evidente */
        border-color: var(--colorMoradoOscuro); 
        
        /* 2. Usar el lavanda más claro para el fondo */
        background-color: var(--colorLavandaClaro2); 
        
        /* 3. Sombra basada en el morado oscuro, con opacidad alta (0.6) */
        box-shadow: 0 0 15px rgba(168, 162, 208, 0.6); 
    }

    /* Estilo mientras está subiendo */
    .dqa-upload-area.is-uploading {
        opacity: 0.7;
        pointer-events: none; /* Deshabilita clics mientras sube */
    }



    .dqa-upload-area .dqa-btn { border-color:transparent; font-size:2rem; padding:1rem 2rem; }



















/* --- Estilos para Skeleton Loading --- */
.dqa-skeleton-message {
    background-color: #e0e0e0; /* Color gris claro */
    border-radius: 10px;
    height: 15px; /* Altura de la línea de texto */
    margin-bottom: 8px;
    animation: pulse-bg 1.5s infinite; /* Animación de pulso */
    -webkit-animation: pulse-bg 1.5s infinite;
}

.dqa-skeleton-row {
    display: flex;
    margin-bottom: 20px; /* Espacio entre filas simuladas */
}

.dqa-skeleton-row.left {
    justify-content: flex-start;
}

.dqa-skeleton-row.right {
    justify-content: flex-end;
}

.dqa-skeleton-row .dqa-skeleton-avatar {
    width: 30px; /* Tamaño del avatar simulado */
    height: 30px;
    border-radius: 50%;
    background-color: #cfcfcf;
    margin-right: 10px;
    margin-left: 10px;
    animation: pulse-bg 1.5s infinite;
    -webkit-animation: pulse-bg 1.5s infinite;
}

.dqa-skeleton-bubble {
    display: flex;
    flex-direction: column;
    padding: 10px;
    min-width: 150px; /* Ancho mínimo de la burbuja simulada */
    max-width: 60%; /* Ancho máximo para simular burbujas variadas */
    background-color: #f0f0f0; /* Color un poco más claro para la burbuja */
    border-radius: 10px;
    position: relative;
}

.dqa-skeleton-bubble.left {
    margin-right: auto;
}

.dqa-skeleton-bubble.right {
    margin-left: auto;
}

/* Animación de pulso */
@keyframes pulse-bg {
    0% { background-color: #e0e0e0; }
    50% { background-color: #f0f0f0; }
    100% { background-color: #e0e0e0; }
}
@-webkit-keyframes pulse-bg {
    0% { background-color: #e0e0e0; }
    50% { background-color: #f0f0f0; }
    100% { background-color: #e0e0e0; }
}

/* Animación del fondo de la burbuja */
.dqa-skeleton-bubble {
    animation: pulse-bubble-bg 1.5s infinite;
    -webkit-animation: pulse-bubble-bg 1.5s infinite;
}
@keyframes pulse-bubble-bg {
    0% { background-color: #f0f0f0; }
    50% { background-color: #e8e8e8; }
    100% { background-color: #f0f0f0; }
}
@-webkit-keyframes pulse-bubble-bg {
    0% { background-color: #f0f0f0; }
    50% { background-color: #e8e8e8; }
    100% { background-color: #f0f0f0; }
}



/* ... (continúa con el resto de las reglas, anteponiendo #dqa-chat-container al selector si es necesario) ... */