/* Estilos generales */

/* General Reset */

* {

    margin: 0;

    padding: 0;

    box-sizing: border-box;

}



body {

    font-family: 'Roboto', sans-serif;

    background-color: #f9f9f9;

    color: #333;

    display: flex;

    flex-direction: column;

    align-items: center;

}



/* Títulos */

h1,

h2 {

    text-align: center;

    margin-top: 50px;

    /* Bajamos más los títulos */

    margin-bottom: 20px;

    text-transform: uppercase;

    letter-spacing: 1px;

}



h1 {

    color: #702082;

    /* Morado WOM */

    font-size: 36px;

    font-weight: bold;

    text-shadow: 2px 2px 5px rgba(112, 32, 130, 0.5);

}



h2 {

    font-size: 28px;

    color: #ec008c;

    /* Rosado WOM */

}



/*+++++++++++++++++++++++++++++++++++++++++*/

/* Radio Buttons */

.radio-group {

    display: flex;

    justify-content: space-between;

    grid-column: span 2;

    margin-top: 5px;

}







.radio-group input {

    margin-right: 10px;

}



/*+++++++++++++++++++++++++++++++++++++++++*/





/* Formularios */

form {

    width: 100%;

    max-width: 700px;

    background: white;

    padding: 25px;

    border-radius: 12px;

    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);

    margin-top: 20px;

}



.form-grid {

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: 20px;

}



input,

select {

    padding: 12px;

    font-size: 16px;

    width: 100%;

    background-color: #f9f9f9;

    border: 2px solid #ddd;

    border-radius: 6px;

    box-sizing: border-box;

    transition: border-color 0.3s ease;

}



input:focus,

select:focus {

    border-color: #f23f7a;

    /* Rosado */

    outline: none;

}



button {

    color: #fff;

    background-color: #702082;

    border: none;

    padding: 12px 24px;

    font-size: 1rem;

    font-weight: bold;

    border-radius: 30px;

    cursor: pointer;

    transition: background-color 0.3s ease;

    margin: 0 auto;

    width: 70%;

    /* Centra el botón */

    display: block;

    /* Asegura que el botón se trate como un bloque */

}



button#auto {



    width: 50%;

    /* Asegura que el botón se trate como un bloque */

}



/* Efecto al pasar el cursor sobre el botón "auto" */





button:hover {

    background-color: #e02d66;

    transform: translateY(-2px);

}



button:active {

    background-color: #c21d4d;

    transform: translateY(1px);

}



/*logo*/



.container {

    display: flex;

    align-items: center;

    justify-content: center;

    gap: 20px;

}



.logo {

    width: 70px;

    /* Reducir tamaño */

    height: 70px;

    border-radius: 50%;

    object-fit: cover;

}



h1 {

    display: flex;

    align-items: center;

    gap: 10px;

    font-size: 29px;

    margin: 0;

}



#boton {

    margin-left: 10px;

}







/* Estilo para el botón de recargar */

button#reloadButton {

    background-color: #003f7f;

    /* Azul */

    color: #fff;

    border: none;

    padding: 12px 24px;

    font-size: 1rem;

    font-weight: bold;

    border-radius: 30px;

    cursor: pointer;

    transition: background-color 0.3s ease, transform 0.3s ease;

    margin: 0 auto;

    display: block;

    width: 70%;

}



button#reloadButton:hover {

    background-color: #0056b3;

    /* Azul más oscuro */

    transform: translateY(-2px);

}



button#reloadButton:active {

    background-color: #003f7f;

    /* Azul aún más oscuro */

    transform: translateY(1px);

}



/* Estilos mejorados para el campo de búsqueda */

.search-container {

    display: flex;

    justify-content: center;

    margin: 20px 0;

}



#buscarInput {

    width: 80%;

    max-width: 320px;

    /* Ancho un poco mayor */

    padding: 12px 18px 12px 40px;

    /* Aumentamos el padding */

    font-size: 16px;

    /* Tamaño de fuente ligeramente mayor */

    color: #333;

    border: 2px solid #ddd;

    border-radius: 25px;

    box-sizing: border-box;

    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);

    background-color: #f9f9f9;

    background-image: url('https://upload.wikimedia.org/wikipedia/commons/5/55/Magnifying_glass_icon.svg');

    background-size: 20px;

    /* Icono ligeramente más grande */

    background-position: 12px center;

    background-repeat: no-repeat;

    transition: all 0.3s ease;

}



#buscarInput:focus {

    border-color: #f23f7a;

    background-color: #fff;

    outline: none;

    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);

}



/*  botones  editar*/

.button-container {

    display: flex;

    gap: 10px;

    /* Espacio entre botones */

}



.button-container button {

    padding: 10px 20px;

    border: none;

    border-radius: 30px;

    font-size: 16px;

    cursor: pointer;

}



/* Estilo específico para el botón de regresar */

.btn-back {

    background-color: #007BFF;

    color: white;

}



.btn-back:hover {

    background-color: #0056b3;

}



/* Estilo del modal */

#modal {

    display: none;

    /* Está oculto por defecto */

    position: fixed;

    z-index: 1000;

    /* Se coloca sobre el contenido */

    left: 0;

    top: 0;

    width: 100%;

    height: 100%;

    background-color: rgba(0, 0, 0, 0.6);

    /* Fondo oscuro */

    display: flex;

    justify-content: center;

    align-items: center;

    /* Centra el modal vertical y horizontalmente */

    transition: opacity 0.3s ease;

}



/* Contenido del modal */

#modal .modal-content {

    background-color: #FFFFFF;

    border-radius: 12px;

    padding: 25px;

    width: 90%;

    max-width: 500px;

    /* Limita el ancho máximo del modal */

    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);

    /* Sombra más definida */

    transform: scale(0.9);

    /* Efecto de entrada */

    opacity: 0;

    transition: transform 0.3s ease, opacity 0.3s ease;

    text-align: center;

    /* Centra el contenido horizontalmente */

}



/* Cuando el modal está visible */

#modal.show .modal-content {

    transform: scale(1);

    /* Escala al tamaño normal */

    opacity: 1;

}



/* Título del modal */

#modal .modal-content h3 {

    font-family: 'Arial', sans-serif;

    color: #3A3A3A;

    font-size: 1.8rem;

    margin: 0 auto 20px;

    /* Margen inferior para separar del contenido */

    font-weight: bold;

    text-align: center;

    /* Centra el texto horizontalmente */

}



/* Estilo del textarea (campo de texto) */

#modal #contratoModal {

    width: 100%;

    height: 200px;

    padding: 15px;

    font-size: 1rem;

    border-radius: 6px;

    border: 1px solid #DDD;

    background-color: #F9F9F9;

    color: #3A3A3A;

    box-sizing: border-box;

    transition: border-color 0.3s ease;

    margin-bottom: 20px;

    /* Espacio entre el textarea y el botón */

}



/* El campo de texto cuando está en foco */

#modal #contratoModal:focus {

    border-color: #8A4FFF;

    outline: none;

}



/* Botón Aceptar */

#modal button {

    background-color: #8A4FFF;

    color: #fff;

    border: none;

    padding: 12px 24px;

    font-size: 1rem;

    font-weight: bold;

    border-radius: 30px;

    cursor: pointer;

    transition: background-color 0.3s ease;

    margin: 0 auto;

    /* Centra el botón */

    display: block;

    /* Asegura que el botón se trate como un bloque */

}



/* Efecto al pasar el cursor sobre el botón */

#modal button:hover {

    background-color: #6D35C6;

}



/* El botón de cerrar (la "X") */

#modal .close {

    color: #8A4FFF;

    font-size: 1.5rem;

    font-weight: bold;

    position: absolute;

    right: 15px;

    top: 15px;

    cursor: pointer;

    transition: color 0.3s ease;

}



/* Efecto al pasar el cursor sobre el botón de cerrar */

#modal .close:hover,

#modal .close:focus {

    color: #6D35C6;

    text-decoration: none;

}



/* Animación de desvanecimiento */

#modal.show {

    display: flex;

    opacity: 1;

}



/* Modal oculto */

#modal.hide {

    opacity: 0;

    pointer-events: none;

}



/* Ajustes en pantallas pequeñas */

@media (max-width: 768px) {

    #buscarInput {

        width: 80%;

        /* Mayor flexibilidad en pantallas pequeñas */

        max-width: none;

    }

}





/* General table styling */

table {

    width: 97%;

    /* Tabla más pequeña */

    margin: 5px auto;

    /* Centrada */

    border-collapse: collapse;

    font-size: 15px;

    /* Letra ligeramente más pequeña */

    text-align: left;

    background-color: #f9f9f9;

    border-radius: 20px;

    overflow: hidden;

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

}



table th,

table td {

    padding: 10px 12px;

    border-bottom: 1px solid #ddd;

    text-align: center;

    /* Centra el texto horizontalmente */

    vertical-align: middle;

    /* Centra el texto verticalmente */

}



table th {

    background-color: #702082;

    /* Morado WOM */

    color: #fff;

    font-weight: bold;

    text-transform: uppercase;

}



table tr:hover {

    background-color: #fce4f7;

    /* Rosa claro WOM */

}



table tr:last-child td {

    border-bottom: none;

}



table td {

    color: #333;

    /* Color de texto neutro */

}



table a {

    text-decoration: none;

    color: #ec008c;

    /* Rosado WOM */

    font-weight: bold;

}



table a:hover {

    color: #702082;

    /* Cambia a morado WOM */

    text-decoration: underline;

}





/* Botones de acciones en la tabla */

table td a {

    display: inline-block;

    padding: 8px 12px;

    margin: 2px;

    /* Espacio entre botones */

    font-size: 14px;

    color: #fff;

    /* Texto blanco */

    background-color: #702082;

    /* Morado WOM */

    border-radius: 5px;

    /* Bordes redondeados */

    text-decoration: none;

    transition: all 0.3s ease;

}



table td a:hover {

    background-color: #ec008c;

    /* Cambia a rosado WOM */

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

    /* Sombra al pasar el cursor */

    transform: translateY(-2px);

    /* Efecto de elevación */

}



table td a:active {

    background-color: #502063;

    /* Morado más oscuro para clic */

    transform: translateY(0);

    /* Vuelve a su lugar al clic */

}





/* Estilos del contenedor */

.label-input-container {

    display: flex;

    justify-content: center;

    align-items: center;

    gap: 10px;

    /* Espaciado entre los rangos de fecha */

    margin: 20px 0;

}



.date-input {

    width: 120px;

    /* Hacemos los inputs más pequeños */

    font-size: 14px;

}



/* Contenedor para el botón y fechas */

.export-container {

    display: flex;

    justify-content: center;

    align-items: center;

    gap: 10px;

    flex-wrap: wrap;

    margin-bottom: 15px;

}



.download-btn {

    padding: 5px 10px;

    font-size: 16px;

    background-color: #702082;

    color: white;

    border: none;

    border-radius: 20px;

    cursor: pointer;

    transition: background-color 0.3s ease;

    height: 36px;

}



.download-btn:hover {

    background-color: #c21d4d;

}



/* Contenedor para hacer la tabla responsiva */

.table-responsive {

    width: 100%;

    overflow-x: auto;

    -webkit-overflow-scrolling: touch;

    /* Suaviza el desplazamiento en dispositivos móviles */

    margin: 20px auto;

    border-radius: 8px;

    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);

}



table {

    width: 100%;

    border-collapse: collapse;

    font-size: 15px;

    text-align: left;

    background-color: #f9f9f9;

}



table th,

table td {

    padding: 10px 12px;

    border-bottom: 1px solid #ddd;

    white-space: nowrap;

    /* Evita que el contenido se divida en varias líneas */

}



table th {

    background-color: #702082;

    color: #fff;

    font-weight: bold;

    text-transform: uppercase;

}



table tr:hover {

    background-color: #fce4f7;

}



table td {

    color: #333;

}



/* Oculta ciertas columnas o ajusta el estilo en pantallas pequeñas */

@media (max-width: 768px) {



    table th,

    table td {

        font-size: 14px;

        padding: 8px 10px;

    }



    .table-responsive {

        box-shadow: none;

    }

}



/* Responsive design */

@media (max-width: 768px) {

    table {

        width: 95%;

        /* Tabla más flexible en pantallas pequeñas */

        font-size: 14px;

    }

}