/* ============================================
   Dashboard - Modales (Detalle/Comentarios/EJE/Escritos)
   ============================================ */

body.modal-open {
    overflow: hidden !important;
    position: fixed !important;
    width: 100% !important;
}

.modal-fullscreen {
    width: 90vw !important;
    max-width: 90vw !important;
    height: 90vh !important;
    max-height: 90vh !important;
    margin: 5vh auto !important;
    padding: 0 !important;
}
.modal-fullscreen .modal-content {
    height: 90vh !important;
    max-height: 90vh !important;
    border: 0 !important;
    border-radius: 0 !important;
    display: flex !important;
    flex-direction: column !important;
}
.modal-fullscreen .modal-body {
    flex: 1 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    min-height: 600px !important;
    height: auto !important;
}

#panel-movimientos.show.active,
#panel-comentarios.show.active,
#panel-formularios.show.active,
#panel-adjuntos.show.active {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
}

#modalDetalleExpedienteCompleto .container-fluid { word-wrap: break-word; overflow-wrap: break-word; }
#panel-movimientos table td { word-wrap: break-word; overflow-wrap: break-word; white-space: normal; max-width: 100%; }
#panel-movimientos table th { word-wrap: break-word; overflow-wrap: break-word; white-space: normal; }
#modalDetalleExpedienteCompleto .col-lg-4 { word-wrap: break-word; overflow-wrap: break-word; }
#modalDetalleExpedienteCompleto .col-lg-4 p,
#modalDetalleExpedienteCompleto .col-lg-4 label { word-wrap: break-word; overflow-wrap: break-word; white-space: normal; }

#panel-movimientos { display: block !important; position: relative !important; overflow: visible !important; min-height: 0 !important; z-index: 1000 !important; }
#panel-movimientos.show { display: block !important; visibility: visible !important; position: relative !important; }
#panel-movimientos.show.active {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
    min-height: 500px !important;
    height: auto !important;
    overflow: visible !important;
    z-index: 1000 !important;
    background-color: white !important;
}

#modalDetalleExpedienteCompleto .col-lg-8 { word-wrap: break-word; overflow-wrap: break-word; }
#detalle-expediente-tab-content { display: block !important; visibility: visible !important; flex: 0 0 auto !important; height: auto !important; min-height: 0 !important; }
#detalle-expediente-tab-content .tab-pane:not(.show) { display: none !important; }
#detalle-expediente-tab-content .tab-pane.show { display: block !important; }

#modalDetalleExpedienteCompleto .modal-dialog {
    max-width: 95vw;
    width: 95vw;
    margin: 0.5rem auto;
    max-height: calc(100vh - 1rem);
    display: flex !important;
    flex-direction: column !important;
    height: calc(100vh - 1rem) !important;
}
#modalDetalleExpedienteCompleto .modal-content {
    max-height: calc(100vh - 1rem) !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    border-radius: 0.5rem;
}
#modalDetalleExpedienteCompleto .modal-body {
    overflow-y: auto !important;
    overflow-x: visible !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    padding: 1rem 1.25rem;
    padding-bottom: 0.5rem;
    max-height: calc(100vh - 200px) !important;
    position: relative !important;
}
#modalDetalleExpedienteCompleto .modal-header { flex-shrink: 0 !important; border-bottom: 1px solid rgba(0,0,0,0.125); min-height: 60px; }
#modalDetalleExpedienteCompleto .modal-footer {
    flex-shrink: 0 !important;
    border-top: 1px solid rgba(0,0,0,0.125);
    background-color: #f8f9fa !important;
    padding: 1rem !important;
    position: relative !important;
    z-index: 10 !important;
    min-height: 70px !important;
    margin-top: auto !important;
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 0.5rem !important;
    position: sticky !important;
    bottom: 0 !important;
    width: 100% !important;
    box-shadow: 0 -2px 10px rgba(0,0,0,0.1) !important;
}

#panel-movimientos .table-responsive { display: block !important; visibility: visible !important; min-height: 0 !important; }
#panel-movimientos table { display: table !important; visibility: visible !important; width: 100% !important; position: relative !important; z-index: 1002 !important; }
#panel-movimientos tbody { display: table-row-group !important; visibility: visible !important; }
#panel-movimientos tbody tr { display: table-row !important; visibility: visible !important; opacity: 1 !important; height: auto !important; min-height: 30px !important; }
#panel-movimientos tbody td {
    padding: 0.5rem !important;
    border: 1px solid #dee2e6 !important;
    display: table-cell !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    min-height: 30px !important;
    line-height: 1.5 !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    white-space: normal !important;
    max-width: 100% !important;
}

#modalDetalleExpedienteCompleto #panel-movimientos thead th {
    vertical-align: middle;
}
#modalDetalleExpedienteCompleto .mov-sort-btn {
    white-space: normal;
    text-decoration: none !important;
    line-height: 1.25;
}
#modalDetalleExpedienteCompleto .mov-sort-btn:hover {
    color: #0d6efd !important;
}
#modalDetalleExpedienteCompleto .mov-sort-btn .mov-sort-icon {
    font-size: 0.9em;
    margin-left: 0.15rem;
    vertical-align: -0.1em;
}
#modalDetalleExpedienteCompleto .mov-sort-btn.mov-sort-active .mov-sort-icon {
    opacity: 1;
}

#btn-nuevo-movimiento-detalle {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
    min-width: 120px !important;
    min-height: 32px !important;
    z-index: 1000 !important;
}
#botones-movimientos-container,
#botones-movimientos-footer,
#modalDetalleExpedienteCompleto #botones-movimientos-footer {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    gap: 0.5rem !important;
    align-items: center !important;
    overflow: visible !important;
    position: relative !important;
}
#panel-movimientos .d-flex.justify-content-between { overflow: visible !important; position: relative !important; z-index: 100 !important; background-color: white !important; }
#modalDetalleExpedienteCompleto .modal-footer button { visibility: visible !important; opacity: 1 !important; display: inline-block !important; }
#detalle-movimientos-body { display: table-row-group !important; visibility: visible !important; opacity: 1 !important; position: relative !important; z-index: 1003 !important; }
#movimientos-total-count {
    display: inline-block !important; visibility: visible !important; opacity: 1 !important;
    position: relative !important; z-index: 2000 !important; font-size: 1rem !important; padding: 0.6rem 1rem !important;
    font-weight: bold !important; background-color: #0d6efd !important; color: white !important;
}

#modalDetalleExpedienteCompleto { z-index: 1055 !important; }
#modalDetalleExpedienteCompleto.modal.show { z-index: 1055 !important; display: block !important; }

#modalDetalleExpedienteCompleto .modal-content.modal-exp-content,
#modalDetalleEJECompleto .modal-content.modal-exp-content {
    border: none; border-radius: 1rem; box-shadow: 0 24px 64px rgba(0,0,0,0.18), 0 0 1px rgba(0,0,0,0.08); overflow: hidden;
}
#modalDetalleExpedienteCompleto .modal-header.modal-exp-header,
#modalDetalleEJECompleto .modal-header.modal-exp-header {
    background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 40%, #1e40af 100%);
    color: #fff; border-bottom: none; padding: 1rem 1.5rem; min-height: 60px; box-shadow: 0 4px 14px rgba(37,99,235,0.35);
}
#modalDetalleExpedienteCompleto .modal-header.modal-exp-header .modal-title,
#modalDetalleEJECompleto .modal-header.modal-exp-header .modal-title {
    font-size: 1.2rem; font-weight: 600; display: flex; align-items: center; gap: 0.5rem; text-shadow: 0 1px 2px rgba(0,0,0,0.1);
}
#modalDetalleExpedienteCompleto .modal-body.modal-exp-body,
#modalDetalleEJECompleto .modal-body.modal-exp-body { background: linear-gradient(180deg, #eef2ff 0%, #f0f9ff 50%, #f8fafc 100%); }

/* (Mantener estilos modernos de detalle y EJE ya migrados) */
#modalDetalleExpedienteCompleto .modal-exp-numero-badge { display: inline-block; font-size: 1.25rem; font-weight: 700; color: #1d4ed8; background: linear-gradient(135deg, rgba(37,99,235,0.18) 0%, rgba(59,130,246,0.1) 100%); padding: 0.5rem 1.1rem; border-radius: 0.6rem; border: 1px solid rgba(37,99,235,0.35); letter-spacing: 0.03em; margin-bottom: 1rem; box-shadow: 0 2px 12px rgba(37,99,235,0.2); }
#modalDetalleExpedienteCompleto .modal-exp-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem 1.5rem; margin-bottom: 1rem; }
@media (max-width: 992px) { #modalDetalleExpedienteCompleto .modal-exp-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 576px) { #modalDetalleExpedienteCompleto .modal-exp-grid { grid-template-columns: 1fr; gap: 0.75rem 1rem; } }

#modalDetalleExpedienteCompleto #detalle-expediente-tabs { flex-wrap: nowrap; overflow-x: auto; overflow-y: hidden; }
#modalDetalleExpedienteCompleto .nav-tabs-exp,
#modalDetalleEJECompleto .nav-tabs-exp { border-bottom: 2px solid #e2e8f0; gap: 0.35rem; }
#modalDetalleExpedienteCompleto .nav-tabs-exp .nav-link,
#modalDetalleEJECompleto .nav-tabs-exp .nav-link {
    color: #475569; border: none; border-radius: 0.5rem; padding: 0.5rem 0.9rem; font-size: 0.85rem; font-weight: 600; transition: all 0.2s ease;
}
#modalDetalleExpedienteCompleto .nav-tabs-exp .nav-link.active,
#modalDetalleEJECompleto .nav-tabs-exp .nav-link.active {
    color: #fff; background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%); border: none; box-shadow: 0 2px 8px rgba(59,130,246,0.4);
}

#modalDetalleEJECompleto #eje-ficha-content,
#modalDetalleEJECompleto #eje-actuaciones-content,
#modalDetalleEJECompleto #eje-escritos-content,
#modalDetalleEJECompleto #eje-cedulas-content,
#modalDetalleEJECompleto #eje-oficios-content,
#modalDetalleEJECompleto #eje-notas-content,
#modalDetalleEJECompleto #eje-sujetos-content,
#modalDetalleEJECompleto #eje-causas-relacionadas-content { font-size: 1.05rem; }

#modalDetalleEJECompleto .table { font-size: 0.98rem !important; }
#modalDetalleEJECompleto .table th { background: #f1f5f9; font-weight: 600; white-space: nowrap; color: #475569; font-size: 0.92rem !important; padding: 0.6rem 0.65rem !important; text-transform: uppercase; letter-spacing: 0.02em; vertical-align: top; }
#modalDetalleEJECompleto .table td { padding: 0.55rem 0.65rem !important; font-size: 0.95rem !important; }
/* Tablas de solapas: lectura natural (sin cortar palabras en vertical) */
#modalDetalleEJECompleto .eje-tabla-wrap.table-responsive {
    overflow-x: hidden !important;
}
#modalDetalleEJECompleto .eje-tabla-wrap {
    max-height: min(60vh, calc(100vh - 16rem));
    overflow-x: hidden;
    overflow-y: auto;
    border-radius: 0.5rem;
    border: 1px solid #e2e8f0;
    width: 100%;
    max-width: 100%;
}
#modalDetalleEJECompleto .eje-tabla-datos {
    table-layout: auto;
    width: 100%;
    margin-bottom: 0;
}
#modalDetalleEJECompleto .eje-tabla-datos th,
#modalDetalleEJECompleto .eje-tabla-datos td {
    white-space: normal !important;
    word-break: normal;
    overflow-wrap: normal;
    hyphens: none;
    vertical-align: top;
}
#modalDetalleEJECompleto .eje-tabla-datos .btn-group { flex-wrap: nowrap; }

/* Toggle visual "Exponer por WhatsApp" (detalle general + EJE) */
.exp-whatsapp-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.55rem 0.75rem;
    border: 1px solid rgba(37, 99, 235, 0.22);
    border-radius: 0.6rem;
    background: linear-gradient(180deg, rgba(59,130,246,0.06), rgba(16,185,129,0.06));
}
.exp-whatsapp-toggle__text {
    display: flex;
    flex-direction: column;
    min-width: 0;
}
.exp-whatsapp-toggle .form-check-input {
    width: 2.4rem;
    height: 1.3rem;
    cursor: pointer;
}
.exp-whatsapp-toggle .form-check-input:checked {
    background-color: #16a34a;
    border-color: #16a34a;
}

#modalDetalleEJECompleto #eje-actuaciones-content .table tbody tr,
#modalDetalleEJECompleto #eje-actuaciones-content .table tbody td { white-space: normal !important; }
#modalDetalleEJECompleto #eje-actuaciones-content .table tbody td { overflow: visible !important; text-overflow: initial !important; word-break: normal !important; overflow-wrap: normal !important; }

/* Calculadora: por encima de "Nuevo movimiento" (~1100). data-bs-backdrop="false" evita 2.º backdrop (pantalla gris al cerrar) */
body.modal-open #modalCalculadoraPlazos.modal.show {
    z-index: 1130 !important;
    display: block !important;
}
body.modal-open #modalCalculadoraPlazos .modal-dialog {
    z-index: 1131 !important;
    position: relative;
    max-width: min(96vw, 900px);
}
#modalCalculadoraPlazos .modal-content { font-size: 1.05rem; }
#modalCalculadoraPlazos .modal-title { font-size: 1.35rem; }
#modalCalculadoraPlazos .form-label { font-size: 1.05rem; font-weight: 600; }
#modalCalculadoraPlazos .form-control,
#modalCalculadoraPlazos .form-select { font-size: 1.05rem; padding: 0.55rem 0.85rem; min-height: 2.65rem; }
#modalCalculadoraPlazos #plazo-resultado-bloque { font-size: 1.05rem; }
#modalCalculadoraPlazos #plazo-fecha-resultante { font-size: 1.35rem !important; }
#modalCalculadoraPlazos #plazo-feriados-lista { max-height: 40vh; overflow-y: auto; }
#modalCalculadoraPlazos #plazo-feriados-lista .plazo-feriado-item {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    padding: 0.5rem 0.65rem 0.5rem 0.85rem;
    margin-bottom: 0.35rem;
    border-left: 4px solid #0d6efd;
    background: #f8fafc;
    border-radius: 0 6px 6px 0;
    font-size: 0.95rem;
}
#modalCalculadoraPlazos #plazo-feriados-lista .plazo-feriado-nombre {
    font-weight: 600;
    color: #212529;
    flex: 1;
    min-width: 0;
    padding-right: 0.5rem;
}
#modalCalculadoraPlazos #plazo-feriados-lista .plazo-feriado-fecha {
    flex-shrink: 0;
    color: #6c757d;
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

/* Z-index modales secundarios */
/* Por encima del detalle (1055) y por encima del 2.º backdrop (~1095); sin regla global en sibling backdrops */
#modalNuevoMovimiento.modal.show { z-index: 1100 !important; display: block !important; }
/* Errores/validación al crear movimiento: por encima de #modalNuevoMovimiento */
#modalMensajeError.modal.show { z-index: 12050 !important; display: block !important; }
#modalMensajeError.modal.show .modal-dialog { z-index: 12051 !important; pointer-events: auto !important; }

body.modal-open #agendarSelectorModal.modal.show,
body.modal-open #modalTurno.modal.show,
body.modal-open #modalEvento.modal.show { z-index: 1055 !important; }
#agendarSelectorModal.modal.show .modal-dialog,
#modalTurno.modal.show .modal-dialog,
#modalEvento.modal.show .modal-dialog { z-index: 1056 !important; pointer-events: auto !important; }
#modalDetalleEJECompleto.modal.show { z-index: 1055 !important; }

/* Modal detalle EJE: grande pero equilibrado en escritorio */
@media (min-width: 992px) {
    #modalDetalleEJECompleto .modal-dialog-eje-completo {
        max-width: min(94vw, 1560px);
        width: 94vw;
        margin: 1rem auto;
        height: calc(100vh - 2rem);
        max-height: calc(100vh - 2rem);
    }
    #modalDetalleEJECompleto .modal-dialog-eje-completo .modal-content {
        max-height: 100%;
        display: flex;
        flex-direction: column;
    }
    #modalDetalleEJECompleto .modal-dialog-eje-completo .modal-body {
        flex: 1 1 auto;
        min-height: 0;
        overflow-x: hidden;
        overflow-y: auto;
    }
}
@media (max-width: 991.98px) {
    #modalDetalleEJECompleto .modal-dialog-eje-completo {
        max-width: 100%;
        width: 100%;
        height: 100%;
        margin: 0;
        max-height: none;
    }
    #modalDetalleEJECompleto .modal-dialog-eje-completo .modal-content {
        min-height: 100%;
        max-height: 100%;
        border-radius: 0;
        display: flex;
        flex-direction: column;
    }
    #modalDetalleEJECompleto .modal-dialog-eje-completo .modal-body {
        flex: 1 1 auto;
        min-height: 0;
        overflow-x: hidden;
        overflow-y: auto;
    }
}
#modalDetalleEJECompleto #eje-detalle-tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    row-gap: 0;
    border-bottom: 1px solid #dee2e6;
}
#modalDetalleEJECompleto #eje-detalle-tabs .nav-link { white-space: nowrap; }

#modalComentarios.modal.show {
    z-index: 1065 !important; display: block !important; position: fixed !important;
    top: 0; left: 0; right: 0; bottom: 0; overflow-x: auto !important; overflow-y: auto !important;
}
#modalComentarios .modal-dialog { z-index: 1066 !important; position: relative !important; margin: 1.75rem auto; }
#modal-archivos-actuacion.modal.show { z-index: 1070 !important; display: block !important; }
#modalEscritoForm.modal.show, #modalEscritoPreview.modal.show { z-index: 1060 !important; }

/* ============================================
   Ajustes finales de modales
   ============================================ */

/* Hotfix: tabs Bootstrap dentro del modal detalle */
#modalDetalleExpedienteCompleto .tab-content { display: block !important; opacity: 1 !important; }
#modalDetalleExpedienteCompleto .tab-pane { display: none; }

/* ===== Modal Detalle EJE - Contenido interno (tamaño uniforme y más grande) ===== */
#modalDetalleEJECompleto .form-label,
#modalDetalleEJECompleto .form-label.small,
#modalDetalleEJECompleto label.form-label {
    font-size: 1.05rem !important;
    font-weight: 600;
    color: #475569;
}
#modalDetalleEJECompleto .form-select,
#modalDetalleEJECompleto .form-select-sm,
#modalDetalleEJECompleto .form-control {
    font-size: 1.05rem !important;
    padding: 0.5rem 0.75rem !important;
    min-height: 2.75rem !important;
}
#modalDetalleEJECompleto #eje-ficha-content p,
#modalDetalleEJECompleto #eje-ficha-content .mb-0 { font-size: 1.05rem !important; line-height: 1.5; }
#modalDetalleEJECompleto .form-check-label { font-size: 1.05rem !important; }
#modalDetalleEJECompleto .form-check-input { width: 1.2rem; height: 1.2rem; }
#modalDetalleEJECompleto .btn-sm { font-size: 0.95rem !important; padding: 0.45rem 0.85rem !important; }
#modalDetalleEJECompleto .eje-ficha-content .row { margin: 0 -0.5rem; }
#modalDetalleEJECompleto .eje-ficha-card { background: #fff; border: 1px solid #e2e8f0; box-shadow: 0 1px 3px rgba(0,0,0,0.05); }
#modalDetalleEJECompleto .eje-ficha-field {
    display: flex; flex-direction: column; gap: 0.25rem; padding: 0.85rem 1.1rem; background: #fff;
    border-radius: 0.5rem; border: 1px solid #e2e8f0; min-height: 3.8rem; transition: box-shadow 0.2s;
}
#modalDetalleEJECompleto .eje-ficha-field:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.06); }
#modalDetalleEJECompleto .eje-ficha-label {
    font-size: 1.05rem !important; font-weight: 600; text-transform: uppercase; letter-spacing: 0.03em; color: #64748b;
}
#modalDetalleEJECompleto .eje-ficha-value { font-size: 1.1rem !important; color: #1e293b; line-height: 1.5; word-break: break-word; }
#modalDetalleEJECompleto .eje-ficha-select { font-size: 1.1rem !important; min-height: 2.75rem; padding: 0.55rem 0.8rem; }
#modalDetalleEJECompleto .tab-content { min-height: 400px; background: transparent; }
#modalDetalleEJECompleto .tab-pane { padding: 0; }
#modalDetalleEJECompleto #eje-ficha-content { padding: 0.5rem 0 !important; }

/* Columna Título y Firmantes (actuaciones): prioridad de ancho sin forzar min-width (evitaba scroll horizontal) */
#modalDetalleEJECompleto #eje-actuaciones-content .eje-tabla-datos thead th:nth-child(1),
#modalDetalleEJECompleto #eje-actuaciones-content .eje-tabla-datos tbody td:nth-child(1) { width: 28%; }
#modalDetalleEJECompleto #eje-actuaciones-content .eje-tabla-datos thead th:nth-child(4),
#modalDetalleEJECompleto #eje-actuaciones-content .eje-tabla-datos tbody td:nth-child(4) { width: 16%; }
#modalDetalleEJECompleto #eje-actuaciones-content .eje-actuacion-titulo-cell {
    max-width: none; text-align: left !important; white-space: normal !important; overflow: visible !important;
    text-overflow: initial !important; word-break: normal !important; overflow-wrap: break-word !important; vertical-align: top;
}
#modalDetalleEJECompleto #eje-actuaciones-content .eje-actuacion-firmantes-cell {
    max-width: 20rem; white-space: normal !important; overflow: visible !important; text-overflow: initial !important;
    word-break: normal !important; overflow-wrap: break-word !important; vertical-align: top;
}
#modalDetalleEJECompleto #eje-actuaciones-content .eje-actuacion-truncable { display: inline; max-width: 100%; }
#modalDetalleEJECompleto #eje-actuaciones-content .eje-actuacion-texto-corto { display: inline; }
#modalDetalleEJECompleto #eje-actuaciones-content .eje-actuacion-texto-completo { display: none; white-space: normal; word-break: break-word; }
#modalDetalleEJECompleto #eje-actuaciones-content .eje-actuacion-truncable[data-expanded="true"] .eje-actuacion-texto-corto { display: none; }
#modalDetalleEJECompleto #eje-actuaciones-content .eje-actuacion-truncable[data-expanded="true"] .eje-actuacion-texto-completo { display: inline; }
#modalDetalleEJECompleto #eje-actuaciones-content .eje-actuacion-ver-mas {
    color: var(--bs-primary, #0d6efd); cursor: pointer; font-size: 0.9em; margin-left: 0.2rem; text-decoration: underline;
    text-underline-offset: 2px; background: transparent; border: 0; padding: 0;
}
#modalDetalleEJECompleto #eje-actuaciones-content .eje-actuacion-toggle-btn { display: inline; line-height: 1.1; font: inherit; }
#modalDetalleEJECompleto #eje-actuaciones-content .eje-actuacion-toggle-btn:focus-visible { outline: 2px solid rgba(13, 110, 253, 0.35); outline-offset: 1px; }
#modalDetalleEJECompleto .badge { font-size: 0.9rem !important; padding: 0.4rem 0.7rem; font-weight: 500; }
#modalDetalleEJECompleto .alert { font-size: 1.05rem !important; }
#modalDetalleEJECompleto .nav-tabs-exp .nav-link { font-size: 1.05rem !important; }
#modalDetalleEJECompleto .nav-tabs-exp .nav-link i { font-size: 1.1rem !important; }
#modalDetalleEJECompleto .spin { animation: spin 1s linear infinite; }
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* Modal Nuevo Movimiento */
#modalNuevoMovimiento .modal-title { font-size: 1.25rem; font-weight: 600; }
#modalNuevoMovimiento .form-label,
#modalNuevoMovimiento label.form-label { font-size: 1rem !important; margin-bottom: 0.35rem; }
#modalNuevoMovimiento .form-control,
#modalNuevoMovimiento .form-select,
#modalNuevoMovimiento input:not([type="radio"]):not([type="checkbox"]),
#modalNuevoMovimiento select,
#modalNuevoMovimiento textarea {
    font-size: 1rem !important; padding: 0.5rem 0.75rem !important; min-height: 2.5rem !important;
}
#modalNuevoMovimiento .form-control::placeholder,
#modalNuevoMovimiento textarea::placeholder { font-size: 1rem; opacity: 0.8; }
#modalNuevoMovimiento textarea.form-control { min-height: 4rem; }
#modalNuevoMovimiento small,
#modalNuevoMovimiento .text-muted { font-size: 0.95rem !important; }
#modalNuevoMovimiento .btn { font-size: 1rem; padding: 0.5rem 1rem; }
#modalNuevoMovimiento .tile-option span,
#modalNuevoMovimiento .btn-group .btn { font-size: 1rem; }
#modalNuevoMovimiento .form-check-label { font-size: 1rem; }
body.modal-open .modal.show { z-index: auto; }
body.modal-open #modalNuevoMovimiento.modal.show { z-index: 1100 !important; }
#modalNuevoMovimiento.modal.show .modal-dialog { z-index: 1101 !important; pointer-events: auto !important; }

/* Cobros / liquidación societaria: la regla global z-index:auto deja el modal detrás del backdrop (pantalla oscura, no clickeable) */
body.modal-open #modalSocAddPartner.modal.show,
body.modal-open #modalSocLedger.modal.show,
body.modal-open #modalSocLedgerHistory.modal.show {
    z-index: 12000 !important;
    pointer-events: auto !important;
}
#modalSocAddPartner.modal.show .modal-dialog,
#modalSocLedger.modal.show .modal-dialog,
#modalSocLedgerHistory.modal.show .modal-dialog {
    z-index: 12001 !important;
    pointer-events: auto !important;
}
#modalSocAddPartner .modal-content,
#modalSocLedger .modal-content {
    pointer-events: auto !important;
    font-size: 1rem !important;
}
#modalSocLedgerHistory .modal-content {
    pointer-events: auto !important;
}
#modalSocAddPartner.modal.show .modal-dialog {
    max-width: min(40rem, 96vw) !important;
    width: 100% !important;
}
#modalSocAddPartner .modal-header .modal-title {
    font-size: 1.5rem !important;
    font-weight: 600 !important;
}
#modalSocAddPartner .modal-body {
    padding: 1.5rem 1.75rem !important;
    font-size: 1.15rem !important;
}
#modalSocAddPartner .modal-body .form-label {
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    margin-bottom: 0.5rem !important;
}
#modalSocAddPartner .modal-body .form-control {
    font-size: 1.15rem !important;
    padding: 0.75rem 1rem !important;
    min-height: 3.25rem !important;
}
#modalSocAddPartner .modal-footer .btn {
    font-size: 1.05rem !important;
    padding: 0.55rem 1.35rem !important;
}
/* Libro societario (nuevo movimiento): ancho amplio en pantallas grandes */
#modalSocLedger.modal.show .modal-dialog {
    max-width: min(80rem, 98vw) !important;
    width: 100% !important;
}
#modalSocLedger .modal-header {
    padding: 1.25rem 1.75rem !important;
}
#modalSocLedger .modal-body {
    padding: 1.5rem 1.75rem 1.75rem !important;
    font-size: 1.1rem !important;
}
#modalSocLedger .modal-footer {
    padding: 1rem 1.75rem 1.35rem !important;
}
#modalSocLedger .modal-body .form-label,
#modalSocLedger .modal-header .modal-title {
    font-size: 1.2rem !important;
    font-weight: 600 !important;
}
#modalSocLedger .modal-header .modal-title {
    font-size: 1.45rem !important;
}
#modalSocLedger .modal-body .form-control,
#modalSocLedger .modal-body .form-select {
    font-size: 1.12rem !important;
    min-height: 3.1rem !important;
    padding: 0.65rem 1rem !important;
}
#modalSocLedger .modal-footer .btn {
    font-size: 1.05rem !important;
    padding: 0.6rem 1.35rem !important;
}

/* Historial movimientos: ~75% del viewport (25% menos que pantalla completa), centrado */
#modalSocLedgerHistory.modal.show .modal-dialog.soc-ledger-history-dialog {
    width: 75vw !important;
    max-width: 75vw !important;
    height: 75vh !important;
    max-height: 75vh !important;
    margin: auto !important;
}
#modalSocLedgerHistory .modal-content {
    height: 75vh !important;
    max-height: 75vh !important;
    display: flex !important;
    flex-direction: column !important;
    border-radius: 0.375rem !important;
    font-size: 1.5rem !important;
}
#modalSocLedgerHistory .modal-header {
    flex-shrink: 0 !important;
    padding: 1rem 1.5rem !important;
}
#modalSocLedgerHistory .modal-header .modal-title {
    font-size: 2.175rem !important;
    font-weight: 600 !important;
}
#modalSocLedgerHistory .modal-header .btn-close {
    width: 1.75rem !important;
    height: 1.75rem !important;
    padding: 0.5rem !important;
}
#modalSocLedgerHistory .modal-body {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 1.25rem 1.5rem !important;
    font-size: 1.65rem !important;
    overflow: hidden !important;
}
#modalSocLedgerHistory .modal-body > p.text-muted {
    font-size: 1.2375rem !important;
    flex-shrink: 0 !important;
}
#modalSocLedgerHistory .modal-body > .d-flex {
    flex-shrink: 0 !important;
}
#modalSocLedgerHistory .modal-body > .d-flex .btn {
    font-size: 1.35rem !important;
    padding: 0.5rem 1rem !important;
}
#modalSocLedgerHistory .soc-ledger-history-table-wrap {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: auto !important;
}
/* Tabla historial: tamaño de texto actual; una sola línea por fila; columnas acorde a contenido */
#modalSocLedgerHistory .table.soc-ledger-history-table {
    font-size: 1.5rem !important;
    table-layout: fixed !important;
    width: 100% !important;
}
#modalSocLedgerHistory .table.soc-ledger-history-table col.soc-hist-col-fecha {
    width: 10.5rem;
}
#modalSocLedgerHistory .table.soc-ledger-history-table col.soc-hist-col-socio {
    width: 22%;
}
#modalSocLedgerHistory .table.soc-ledger-history-table col.soc-hist-col-tipo {
    width: 7.5rem;
}
#modalSocLedgerHistory .table.soc-ledger-history-table col.soc-hist-col-importe {
    width: 11rem;
}
#modalSocLedgerHistory .table.soc-ledger-history-table col.soc-hist-col-concepto {
    width: 32%;
}
#modalSocLedgerHistory .table.soc-ledger-history-table col.soc-hist-col-acciones {
    width: 10.5rem;
}
#modalSocLedgerHistory .table.soc-ledger-history-table tbody tr {
    white-space: nowrap !important;
}
#modalSocLedgerHistory .table.soc-ledger-history-table thead th,
#modalSocLedgerHistory .table.soc-ledger-history-table tbody td {
    padding: 0.75rem 0.85rem !important;
    vertical-align: middle !important;
    font-size: 1.5rem !important;
    line-height: 1.25 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}
#modalSocLedgerHistory .table.soc-ledger-history-table thead th {
    font-weight: 600 !important;
}
/* Acciones: sin ellipsis en botones */
#modalSocLedgerHistory .table.soc-ledger-history-table thead th:nth-child(6),
#modalSocLedgerHistory .table.soc-ledger-history-table tbody td:nth-child(6) {
    overflow: visible !important;
    text-overflow: clip !important;
}
#modalSocLedgerHistory .table.soc-ledger-history-table .text-end {
    font-size: inherit !important;
}
#modalSocLedgerHistory .modal-body .form-label {
    font-size: 1.65rem !important;
    font-weight: 600 !important;
}
#modalSocLedgerHistory .modal-body .form-control,
#modalSocLedgerHistory .modal-body .form-select {
    font-size: 1.65rem !important;
    min-height: 3.6rem !important;
    padding: 0.75rem 1.1rem !important;
}
#modalSocLedgerHistory #soc-ledger-edit-panel h6 {
    font-size: 1.8rem !important;
}
#modalSocLedgerHistory .modal-body .btn-primary,
#modalSocLedgerHistory .modal-body .btn-outline-secondary {
    font-size: 1.35rem !important;
    padding: 0.55rem 1.25rem !important;
}
#modalSocLedgerHistory .modal-footer {
    flex-shrink: 0 !important;
    padding: 1rem 1.5rem !important;
}
#modalSocLedgerHistory .modal-footer .btn {
    font-size: 1.35rem !important;
    padding: 0.55rem 1.5rem !important;
}
#modalSocLedgerHistory .table .btn-sm {
    font-size: 1.35rem !important;
    padding: 0.5rem 0.95rem !important;
}

/* Modal Comentarios refinado */
#modalComentarios .modal-content { background: #fff !important; color: #212529 !important; border-radius: 0.5rem; box-shadow: 0 0.5rem 1rem rgba(0,0,0,0.15); }
#modalComentarios .modal-header,
#modalComentarios .modal-body,
#modalComentarios .modal-footer { background: #fff !important; color: #212529 !important; border-color: #dee2e6; }
#modalComentarios .modal-body .form-control,
#modalComentarios .modal-body .form-label { background: #fff !important; color: #212529 !important; }
#modalComentarios .comentarios-label-nuevo { font-size: 1rem !important; font-weight: 600 !important; }
#modalComentarios #nuevo-comentario-texto,
#modalComentarios .comentarios-textarea-nuevo {
    font-size: 1rem !important; line-height: 1.5 !important; min-height: 8rem !important; padding: 0.75rem 1rem !important; resize: vertical;
}
#modalComentarios .btn-close { filter: none; opacity: 0.8; }

/* Solapa/Modales Escritos */
#tab-escritos .content-header h5 { font-size: 1.35rem; }
#tab-escritos .card-title { font-size: 1.1rem; font-weight: 600; }
#tab-escritos .form-select { font-size: 1rem; padding: 0.5rem 0.75rem; min-height: 2.5rem; }
#tab-escritos #escritos-btn-amparo,
#tab-escritos #escritos-btn-apelacion-srt { font-size: 1.05rem; font-weight: 500; }
#modalEscritoForm .modal-title,
#modalEscritoPreview .modal-title { font-size: 1.25rem; }
#modalEscritoForm .modal-body .form-label { font-size: 1rem; }
#modalEscritoForm .modal-body .form-control { font-size: 1rem; padding: 0.5rem 0.75rem; min-height: 2.5rem; }
#modalEscritoForm .modal-footer .btn,
#modalEscritoPreview .modal-footer .btn { font-size: 1rem; padding: 0.5rem 1rem; }
#modalEscritoPreview #escrito-preview-text { font-size: 0.95rem; line-height: 1.5; padding: 1rem !important; }

/* Modal Expedientes del Contacto / selector cache */
#modalExpedientesContacto .table-responsive { overflow-x: auto; max-width: 100%; }
#modalExpedientesContacto .table { table-layout: fixed; width: 100%; }
#modalExpedientesContacto .table th:nth-child(1),
#modalExpedientesContacto .table td:nth-child(1) { width: 12%; min-width: 90px; }
#modalExpedientesContacto .table th:nth-child(2),
#modalExpedientesContacto .table td:nth-child(2) { width: 8%; min-width: 60px; }
#modalExpedientesContacto .table th:nth-child(3),
#modalExpedientesContacto .table td:nth-child(3) { width: 28%; word-break: break-word; }
#modalExpedientesContacto .table th:nth-child(4),
#modalExpedientesContacto .table td:nth-child(4) { width: 18%; min-width: 100px; }
#modalExpedientesContacto .table th:nth-child(5),
#modalExpedientesContacto .table td:nth-child(5) { width: 12%; min-width: 80px; }
#modalExpedientesContacto .table th:nth-child(6),
#modalExpedientesContacto .table td:nth-child(6) { width: 12%; min-width: 90px; }
#modalExpedientesContacto .table th:nth-child(7),
#modalExpedientesContacto .table td:nth-child(7) { width: 10%; min-width: 90px; }
.combobox-cliente-wrapper .combobox-cliente-input { font-size: 1rem; color: #212529; min-height: 2.25rem; }
.input-group .combobox-cliente-wrapper { flex: 1; min-width: 0; }
.combobox-cliente-item:hover { background-color: #f1f5f9; }
.combobox-cliente-item:active { background-color: #e2e8f0; }
.selector-exp-cache .alert { font-size: 1rem; }
.selector-exp-cache .form-control,
.selector-exp-cache .form-select { font-size: 1rem; min-height: 2.75rem; }
.selector-exp-cache #select-exp-cache option { font-size: 1rem; padding: 0.35rem 0.5rem; }
.selector-exp-cache .btn { font-size: 1.05rem; }

/* Modales de contacto/abogado/agenda (migración final) */
#modalEditarContacto .modal-dialog { max-width: 90% !important; }
#modalEditarContacto .modal-body { padding: 2rem; font-size: 1.1rem; }
#modalEditarContacto .form-label { font-size: 1.1rem; font-weight: 600; margin-bottom: 0.75rem; color: #495057; }
#modalEditarContacto .form-control,
#modalEditarContacto .form-select,
#modalEditarContacto textarea.form-control { font-size: 1.1rem; padding: 0.75rem 1rem; line-height: 1.5; }
#modalEditarContacto .input-group-text { font-size: 1.1rem; padding: 0.75rem 1rem; }
#modalEditarContacto .modal-header { padding: 1.5rem 2rem; }
#modalEditarContacto .modal-header .modal-title { font-size: 1.5rem; font-weight: 600; }
#modalEditarContacto .modal-footer { padding: 1.5rem 2rem; }
#modalEditarContacto .modal-footer .btn { font-size: 1.1rem; padding: 0.75rem 1.5rem; }
#modalEditarContacto .row.g-3 { --bs-gutter-y: 1.5rem; --bs-gutter-x: 1.5rem; }

#modalNuevoContacto .modal-body,
#modalNuevoExpediente .modal-body { padding: 1.5rem 2rem; font-size: 1.1rem; }
#modalNuevoContacto .form-label,
#modalNuevoExpediente .form-label { font-size: 1.1rem; font-weight: 600; margin-bottom: 0.5rem; color: #495057; }
#modalNuevoContacto .form-control,
#modalNuevoContacto .form-select,
#modalNuevoExpediente .form-control,
#modalNuevoExpediente .form-select,
#modalNuevoContacto textarea.form-control,
#modalNuevoExpediente textarea.form-control { font-size: 1.1rem; padding: 0.65rem 0.9rem; line-height: 1.5; }
#modalNuevoContacto .input-group-text,
#modalNuevoExpediente .input-group-text { font-size: 1.1rem; padding: 0.65rem 0.9rem; }
#modalNuevoContacto .modal-header,
#modalNuevoExpediente .modal-header { padding: 1.25rem 1.5rem; }
#modalNuevoContacto .modal-header .modal-title,
#modalNuevoExpediente .modal-header .modal-title { font-size: 1.4rem; font-weight: 600; }
#modalNuevoContacto .row.g-3,
#modalNuevoExpediente .row.g-3 { --bs-gutter-y: 1rem; --bs-gutter-x: 1rem; }

#modalNuevoAbogado.modal.show { z-index: 1055 !important; display: block !important; pointer-events: auto !important; }
#modalNuevoAbogado .modal-dialog { z-index: 1056 !important; pointer-events: auto !important; }
#modalNuevoAbogado .modal-content,
#modalNuevoAbogado .modal-header,
#modalNuevoAbogado .modal-body { background: #fff !important; color: #212529 !important; border-color: #dee2e6; }
#modalNuevoAbogado .modal-body { padding: 1.5rem 2rem; font-size: 1.1rem; }
#modalNuevoAbogado .form-label { font-size: 1.1rem; font-weight: 600; margin-bottom: 0.5rem; color: #495057; }
#modalNuevoAbogado .form-control { font-size: 1.1rem; padding: 0.65rem 0.9rem; line-height: 1.5; background: #fff !important; color: #212529 !important; }
#modalNuevoAbogado .modal-header { padding: 1.25rem 1.5rem; }
#modalNuevoAbogado .modal-header .modal-title { font-size: 1.4rem; font-weight: 600; }
#modalNuevoAbogado .row.g-3 { --bs-gutter-y: 1rem; --bs-gutter-x: 1rem; }
#modalNuevoAbogado .btn { font-size: 1.05rem; padding: 0.6rem 1.25rem; }

#modalTurno .modal-dialog,
#modalEvento .modal-dialog { max-width: min(900px, 92vw) !important; }
#modalTurno .modal-header,
#modalEvento .modal-header { padding: 1.25rem 1.5rem; }
#modalTurno .modal-title,
#modalEvento .modal-title { font-size: 1.5rem !important; font-weight: 600; }
#modalTurno .modal-body,
#modalEvento .modal-body { padding: 1.5rem 1.5rem; font-size: 1.05rem; }
#modalTurno .row.g-3,
#modalEvento .row.g-3 { --bs-gutter-y: 1.25rem; --bs-gutter-x: 1.25rem; }
#modalTurno .form-label,
#modalEvento .form-label { font-size: 1.05rem !important; font-weight: 600; margin-bottom: 0.5rem; color: #374151; }
#modalTurno .form-control,
#modalTurno .form-select,
#modalEvento .form-control,
#modalEvento .form-select { font-size: 1.05rem !important; padding: 0.65rem 0.85rem; min-height: 2.75rem; line-height: 1.5; }
#modalTurno textarea.form-control,
#modalEvento textarea.form-control { min-height: 4rem; padding: 0.75rem 0.85rem; }
#modalTurno .input-group-text,
#modalEvento .input-group-text { font-size: 1.05rem; padding: 0.65rem 0.85rem; min-height: 2.75rem; }
#modalTurno .modal-footer,
#modalEvento .modal-footer { padding: 1.25rem 1.5rem; }
#modalTurno .modal-footer .btn,
#modalEvento .modal-footer .btn { font-size: 1.05rem !important; padding: 0.6rem 1.25rem; }
