/* =============================================================
   NEUMORPHISM.CSS — Dark Mode Profesional + Soni Widget
   Efectos 3D, degradados suaves, sombras precisas
   Compatible con Bootstrap 5
   ============================================================= */

:root {
    --neu-bg: #1e1f29;
    --neu-surface: #252836;
    --neu-surface-light: #2a2e3d;
    --neu-text: #e0e5ec;
    --neu-text-muted: #a0a7b8;
    --neu-border: rgba(255, 255, 255, 0.08);
    --neu-shadow-light: rgba(255, 255, 255, 0.07);
    --neu-shadow-dark: rgba(0, 0, 0, 0.5);
    --neu-accent: #6a5af9;
    --neu-accent-gradient: linear-gradient(135deg, #6a5af9, #5271ff);
}

/* --- FONDO GENERAL --- */
body.bg-neumorphic {
    background-color: var(--neu-bg) !important;
    color: var(--neu-text) !important;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* --- TEXTOS --- */
.text-neumorphic {
    color: var(--neu-text) !important;
}

.text-neumorphic-muted {
    color: var(--neu-text-muted) !important;
}

.neu-accent-text {
    color: var(--neu-accent) !important;
}

/* --- FOOTER --- */
.neumorphic-footer {
    background-color: transparent !important;
    border-top: 1px solid var(--neu-border) !important;
    color: var(--neu-text-muted) !important;
}

/* --- CONTENEDOR PRINCIPAL --- */
.main-content {
    padding: 24px 0;
    flex: 1;
}

/* --- NAVBAR --- */
.navbar.bg-neumorphic {
    background: var(--neu-surface) !important;
    box-shadow: 
        6px 6px 12px var(--neu-shadow-dark),
        -6px -6px 12px var(--neu-shadow-light) !important;
    border-radius: 0 0 16px 16px;
    padding: 12px 0;
}

.navbar-brand,
.navbar-nav .nav-link {
    color: var(--neu-text) !important;
    font-weight: 600;
}

.navbar-brand:hover,
.navbar-nav .nav-link:hover {
    color: var(--neu-accent) !important;
}

/* --- BOTONES NEUMÓRFICOS OSCUROS --- */
.btn-neumorphic {
    background: var(--neu-surface);
    color: var(--neu-text);
    border: none;
    border-radius: 12px;
    padding: 10px 20px;
    font-weight: 600;
    box-shadow: 
        5px 5px 10px var(--neu-shadow-dark),
        -5px -5px 10px var(--neu-shadow-light);
    transition: all 0.25s ease;
}

.btn-neumorphic:hover {
    background: var(--neu-surface-light);
    color: var(--neu-text);
    box-shadow: 
        3px 3px 6px var(--neu-shadow-dark),
        -3px -3px 6px var(--neu-shadow-light);
}

.btn-neumorphic:active {
    box-shadow: 
        inset 4px 4px 8px var(--neu-shadow-dark),
        inset -4px -4px 8px var(--neu-shadow-light);
    transform: translateY(1px);
}

/* --- BOTONES DE MÓDULOS (CLAROS, NEUMÓRFICOS) --- */
.btn-module {
    background: #e0e5ec;
    color: #2d3748;
    border: none;
    border-radius: 8px;
    padding: 8px 16px;
    font-weight: 600;
    box-shadow: 
        4px 4px 8px #bebec0,
        -4px -4px 8px #ffffff;
    transition: all 0.2s ease;
}

.btn-module:hover {
    background: #f0f2f5;
    box-shadow: 
        3px 3px 6px #bebec0,
        -3px -3px 6px #ffffff;
}

.btn-module:active {
    box-shadow: 
        inset 3px 3px 6px #bebec0,
        inset -3px -3px 6px #ffffff;
    transform: translateY(1px);
}

.btn-module-disabled {
    background: #e0e5ec;
    color: #718096;
    opacity: 0.5;
    filter: grayscale(1);
    cursor: not-allowed;
}

/* --- BOTÓN DE ACCENTO (GRADIENTE) --- */
.btn-neumorphic-accent {
    background: var(--neu-accent-gradient);
    color: white;
    border: none;
    border-radius: 12px;
    padding: 10px 20px;
    font-weight: 600;
    box-shadow: 
        0 4px 12px rgba(106, 90, 249, 0.3),
        5px 5px 10px var(--neu-shadow-dark),
        -5px -5px 10px var(--neu-shadow-light);
    transition: all 0.25s ease;
}

.btn-neumorphic-accent:hover {
    box-shadow: 
        0 6px 16px rgba(106, 90, 249, 0.4),
        3px 3px 6px var(--neu-shadow-dark),
        -3px -3px 6px var(--neu-shadow-light);
    transform: translateY(-2px);
}

.btn-neumorphic-accent:active {
    box-shadow: 
        inset 4px 4px 10px var(--neu-shadow-dark),
        inset -4px -4px 10px var(--neu-shadow-light),
        0 2px 6px rgba(106, 90, 249, 0.2);
    transform: translateY(1px);
}

/* --- INPUTS --- */
.form-control-neumorphic,
.form-control {
    background: var(--neu-surface);
    border: none;
    color: var(--neu-text);
    border-radius: 10px;
    padding: 12px 16px;
    box-shadow: 
        inset 4px 4px 8px var(--neu-shadow-dark),
        inset -4px -4px 8px var(--neu-shadow-light);
    transition: all 0.2s;
}
/* --- FIX ICONOS DE FECHA (Blanquear el calendario) --- */
input[type="date"]::-webkit-calendar-picker-indicator {
    filter: invert(1); /* Invierte el color negro a blanco */
    opacity: 0.6;      /* Lo hace un poco sutil */
    cursor: pointer;
}
input[type="date"]::-webkit-calendar-picker-indicator:hover {
    opacity: 1;        /* Brilla más al pasar el ratón */
}

.form-control-neumorphic:focus,
.form-control:focus {
    outline: none;
    box-shadow: 
        inset 2px 2px 4px var(--neu-shadow-dark),
        inset -2px -2px 4px var(--neu-shadow-light),
        0 0 0 2px var(--neu-accent);
    color: white;
}

.form-control::placeholder {
    color: #7a8199;
    opacity: 1;
}

/* === CORRECCIÓN PARA LISTAS DESPLEGABLES (SELECT) === */
select option, 
.form-control-neumorphic option {
    background-color: var(--neu-surface) !important;
    color: var(--neu-text) !important;
}

/* --- TARJETAS --- */
.card-neumorphic {
    background: var(--neu-surface);
    border: none;
    border-radius: 16px;
    box-shadow: 
        6px 6px 12px var(--neu-shadow-dark),
        -6px -6px 12px var(--neu-shadow-light);
    padding: 24px;
    transition: transform 0.2s, box-shadow 0.2s;
}

.card-neumorphic:hover {
    transform: translateY(-5px);
    box-shadow: 
        0 10px 25px rgba(0,0,0,0.25),
        6px 6px 12px var(--neu-shadow-dark),
        -6px -6px 12px var(--neu-shadow-light);
    border: 1px solid rgba(106, 90, 249, 0.2);
}

/* --- ALERTAS --- */
.alert-neumorphic {
    background: var(--neu-surface);
    border: none;
    border-radius: 12px;
    color: var(--neu-text);
    padding: 14px 20px;
    box-shadow: 
        inset 3px 3px 6px var(--neu-shadow-dark),
        inset -3px -3px 6px var(--neu-shadow-light);
}

/* --- UTILIDADES --- */
.neu-border {
    border: 1px solid var(--neu-border) !important;
}

.opacity-50 {
    opacity: 0.5 !important;
    filter: grayscale(1) !important;
}

/* --- SCROLLBARS MODERNOS --- */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
::-webkit-scrollbar-track {
    background: var(--neu-bg);
}
::-webkit-scrollbar-thumb {
    background: var(--neu-surface);
    border-radius: 4px;
    border: 2px solid var(--neu-bg);
}
::-webkit-scrollbar-thumb:hover {
    background: var(--neu-accent);
}

/* ===================================================================
   CLASES PERSONALIZADAS PARA SONI WIDGET
   =================================================================== */

/* Botón flotante de Soni (esquina inferior derecha) */
.btn-soni-float {
    width: 65px !important;
    height: 65px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    background: #6a5af9 !important;
    box-shadow: 
        0 4px 12px rgba(106, 90, 249, 0.3),
        4px 4px 8px var(--neu-shadow-dark),
        -4px -4px 8px var(--neu-shadow-light) !important;
    transition: transform 0.2s ease;
}

.btn-soni-float:hover {
    transform: scale(1.1);
}

/* Botones de micrófono y enviar en el chat */
.btn-soni-action {
    width: 44px !important;
    height: 40px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    background: #6a5af9 !important;
    color: white !important;
    font-size: 18px !important;
    box-shadow: 
        0 4px 12px rgba(106, 90, 249, 0.3),
        3px 3px 6px var(--neu-shadow-dark),
        -3px -3px 6px var(--neu-shadow-light) !important;
    border: none !important;
}

/* Ventana de chat (fondo sólido oscuro, no neumórfico) */
.soni-chat-window {
    background: #0d1b2a !important;
    border: 1px solid rgba(255,255,255,0.05) !important;
    box-shadow: 
        8px 8px 16px rgba(0,0,0,0.5),
        -8px -8px 16px rgba(255,255,255,0.05) !important;
}

.soni-chat-header {
    background: #0f172a !important;
    border-bottom: 1px solid rgba(255,255,255,0.05) !important;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1) !important;
    color: #e0e5ec !important;
}

.soni-chat-history,
.soni-chat-input-area {
    background: #0d1b2a !important;
}
/* =============================================================
   FIX: VISIBILIDAD DE INPUTS DE SOLO LECTURA
   Poner esto al final de neumorphism.css
   ============================================================= */

/* Forzar que los inputs deshabilitados o de solo lectura sean legibles */
.form-control:disabled, 
.form-control[readonly],
.form-control-neumorphic:disabled,
.form-control-neumorphic[readonly] {
    background-color: #2c3035 !important; /* Un poco más claro que el fondo */
    color: #ffffff !important;            /* Texto blanco brillante */
    opacity: 1 !important;                /* Quitar transparencia */
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    cursor: not-allowed;
}

/* Arreglar el color de las etiquetas en los modales para que destaquen más */
.modal-body label {
    color: #a0a7b8 !important;
    font-weight: 600;
}
/* Efecto para el QR clickable en el modal */
.modal-body a img:hover {
    transform: scale(1.05); /* Crece un poquito */
    opacity: 0.9;
}