#body_login {
    font-family: Arial, sans-serif;
    background: linear-gradient(to bottom, #f4f4f4, #a3a3a3); /* Degradado azul oscuro a gris claro */
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    margin: 0;
}

.login-container {
    background: linear-gradient(to bottom, #ffffff, #f4f4f4); /* Blanco a gris claro */
    padding: 30px 20px;
    border-radius: 10px; /* Bordes redondeados */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1); /* Sombra para darle profundidad */
    max-width: 350px;
    width: 100%;
    text-align: center; /* Centra el texto */
}

.login-container h2 {
    color: #2d4360; /* Azul oscuro */
    font-size: 24px;
    margin-bottom: 20px; /* Espacio debajo del título */
    font-weight: bold;
}

.login-container input {
    width: 94%;
    padding: 10px;
    margin: 10px 0; /* Espacio entre los campos */
    border: 1px solid #f4f4f4; /* Borde claro */
    border-radius: 5px;
    background: linear-gradient(to right, #f4f4f4, #ffffff); /* Gris claro a blanco */
    font-size: 16px;
    color: #2d4360; /* Azul oscuro para el texto */
}

.login-container input:focus {
    outline: none; /* Quita el contorno predeterminado */
    border: 1px solid #2d4360; /* Resalta el campo seleccionado */
    background-color: #ffffff; /* Fondo blanco al enfocar */
}

.login-container button {
    width: 100%;
    padding: 10px;
    background-color: #2d4360; /* Azul oscuro */
    color: #ffffff; /* Texto blanco */
    border: none;
    border-radius: 5px;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    transition: background-color 0.3s ease; /* Transición suave en el color */
}

.login-container button:hover {
    background-color: #58bfe7; /* Cambia a un azul más claro al pasar el cursor */
}

@media (max-width: 768px) {
    .login-container {
        padding: 20px 15px;
    }
}

.contenedorimagen {
    position: relative;
    left: 22px; /* Ajusta la posición para ignorar el padding del sidebar */
    width: calc(100% + 40px);
     /* Compensa el padding del sidebar */
    height: 325px;
    margin-bottom: 5px;
    margin-top: -50px;
}

.contenedorimagen img {
    width: 70%; /* Ajusta la imagen al ancho del div */
    height: 80%; /* Ajusta la imagen al alto del div */
    object-fit: fill; /* Fuerza a que la imagen se adapte completamente */
}

input {
    width: 90%;
    padding: 10px;
    margin: 10px 0;
    border: 1px solid #ddd;
    border-radius: 5px;
}

button {
    background-color: #2d4360;
    color: white;
    border: none;
    padding: 10px;
    border-radius: 5px;
    cursor: pointer;
    width: 100%;
}

button:hover {
    background-color: #1f3046;
}
/* Estructura general */
body {
    margin: 0;
    font-family: Arial, sans-serif;
}

.dashboard {
    display: flex;
    flex-wrap: wrap; /* 🔹 Permite que los elementos se acomoden en pantallas pequeñas */
    height: auto; /* 🔹 Evita que la altura sea fija */
}



/* DISEÑO DEL SIDEBAR DONDE DICE NAVEGACION O PANEL DE GESTIONES*/
#dashboard-title {
    background: linear-gradient(to right, #58bfe7, #2d4360); /* Degradado azul */
    color: #ffffff; /* Texto blanco */
    padding: 10px;
    border-radius: 8px;
    text-align: center;
    font-size: 18px;
    font-weight: bold;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Sombra ligera */
}

#dashboard-title:hover {
    transform: scale(1.05); /* Zoom suave */
    background-color: #58bfe7; /* Cambia el color */
    transition: all 0.3s ease; /* Suaviza el cambio */
}

#dashboard-separator {
    margin-top: 10px;
    height: 2px;
    background: linear-gradient(to right, #58bfe7, #2d4360);
}

#dashboard-title {
    font-family: 'Roboto', sans-serif; /* Cambia la fuente */
    letter-spacing: 1px; /* Espaciado del texto */
    text-transform: uppercase; /* Mayúsculas estilizadas */
}


/* PARTE DEL LOGOTIPO DEL SIDEBAR */
.contenedor-imagen {
    position: relative;
    left: -20px; /* Ajusta la posición para ignorar el padding del sidebar */
    width: calc(100% + 40px); /* Compensa el padding del sidebar */
    height: 26px;
    background-color: #ffffff;
    margin-bottom: 40px;
}

.contenedor-imagen img {
    transition: opacity 0.5s ease; /* Define una transición suave */
    width: 100%; /* Ajusta la imagen al ancho del div */
    height: 100%; /* Ajusta la imagen al alto del div */
    object-fit: fill; /* Fuerza a que la imagen se adapte completamente */
}

/* APARTE DONDE ESTAN LOS ENLACES DE CONTACTO Y AYUDA DEL SIDEBAR */
.sidebar-footer {
    margin-top: auto; /* Coloca el pie de página al final del sidebar */
    text-align: center; /* Centra los elementos */
    padding: 10px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.2); /* Línea divisoria suave */
}

.footer-link {
    display: block; /* Muestra los enlaces en bloques separados */
    color: white; /* Color del texto */
    text-decoration: none; /* Elimina subrayado */
    font-size: 16px;
    margin: 5px 0;
    transition: color 0.3s ease; /* Suave transición en color */
}

.footer-link:hover {
    color: #58bfe7; /* Cambia el color del texto al pasar el cursor */
}

.icon {
    margin-right: 8px; /* Espacio entre el ícono y el texto */
    font-size: 18px; /* Tamaño del ícono */
    vertical-align: middle; /* Alineación con el texto */
}



/* Sidebar */
.sidebar {
    width: 250px;
    background-color: #2d4360;
    color: white;
    padding: 20px;
    box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);
}


.sidebar h2 {
    text-align: center;
    margin-bottom: 20px;
}

.sidebar ul {
    list-style: none;
    padding: 0;
}

#seguridad{
    margin-bottom: 90px;
}

#cerrar{
    margin-bottom: 5px;
}


.sidebar ul li {
    margin: 10px 0;
    
}

.sidebar ul li a {
    text-decoration: none;
    color: white;
    font-size: 20px;
    display: block;
    padding: 10px;
    border-radius: 5px;
    transition: background-color 0.3s;
    margin-bottom: 20px; /* Añade espacio debajo del componente background-color: #1f3046;*/
}

.sidebar ul li a:hover {
    background-color: #ffffff;
    color: #2d4360;
}

/* Main content */
.main-content {
    flex: 1;
    padding: 20px;
    background-color: #f4f4f4;
    overflow-y: auto;
}

/* Secciones dinámicas */
.contenido {
    display: none; /* Ocultar por defecto */
}

.contenido.activo {
    display: block; /* Mostrar la sección activa */
}




/* CONTENEDORES DEL APARTADO DASHBOARD*/
.usuarios {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: #f4f4f4;
    padding: 20px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

.usuarios h1 {
    font-size: 30px;
    margin-bottom: 10px;
    color: #2d4360;
}

.usuarios p {
    font-size: 18px;
    margin-bottom: 20px;
    color: #555;
    text-align: center;
}

/* Contenedor principal */
.certificados {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: #f4f4f4;
    padding: 20px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

.certificados h1 {
    font-size: 30px;
    margin-bottom: 10px;
    color: #2d4360;
}

.certificados p {
    font-size: 18px;
    margin-bottom: 20px;
    color: #555;
    text-align: center;
}

/* Formulario dividido en cuadrícula */
.form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* Dos columnas iguales */
    grid-template-rows: repeat(2, 1fr); /* Dos filas iguales */
    gap: 20px; /* Espaciado entre las secciones */
    width: 100%; /* Ancho completo */
    height: 80%; /* Altura ajustada */
    background-color: white;
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}

/* Estilos para cada sección del formulario de usuarios*/
.form-section {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: #f9f9f9;
    padding: 15px;
    border-radius: 5px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
    width: 100%; /* Ancho completo */
}

.form-section h2 {
    margin-bottom: 10px;
    color: #2d4360;
}

label {
    font-size: 14px;
    margin-bottom: 5px;
    color: #333;
}

input, select, button {
    width: 99%;
    padding: 10px;
    margin-bottom: 10px;
    border: 1px solid #ddd;
    border-radius: 5px;
}

#nombre_certificado{
    width: 96%;
    padding: 10px;
    margin-bottom: 10px;
    border: 1px solid #ddd;
    border-radius: 5px;
}

#archivo_pdf{
    width: 96%;
    padding: 10px;
    margin-bottom: 10px;
    border: 1px solid #ddd;
    border-radius: 5px;
}

#permiso{
    width: 99%;
    padding: 10px;
    margin-bottom: 10px;
    border: 1px solid #ddd;
    border-radius: 5px;
}

#archivo{
    width: 99%;
    padding: 10px;
    margin-bottom: 10px;
    border: 1px solid #ddd;
    border-radius: 5px;
}

#usuario{
    width: 99%;
    padding: 10px;
    margin-bottom: 10px;
    border: 1px solid #ddd;
    border-radius: 5px;
}

.form-section .espacio{
    margin-bottom: 30px;
}


button {
    background-color: #2d4360;
    color: white;
    border: none;
    cursor: pointer;
    text-align: center;
}

button:hover {
    background-color: #1f3046;
}


/* Estilos para cada sección del formulario servicios */
.form-container {
    width: 48%;
    background-color: #f0f0f0;
    padding: 20px;
    border: 1px solid #ccc;
    border-radius: 5px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}
.form-container h2 {
    margin-top: 0;
}
.form-container form {
    display: flex;
    flex-direction: column;
}
.form-container form input,
.form-container form select,
.form-container form button {
    margin: 10px 0;
    padding: 10px;
}


/* Estilo para checkboxes */
input[type="checkbox"] {
    accent-color: #58bfe7; /* Cambiar el color del checkbox */
    width: 18px;
    height: 18px;
    cursor: pointer;
    vertical-align: middle;
    margin-right: 5px;
}

/* Estilo para contenedor de checkboxes */
.checkbox-container {
    background-color: #ffffff;
    padding: 20px;
    border: 1px solid #ddd;
    border-radius: 5px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    max-width: 400px;
    margin: auto;
}

/* Estilo para la opción "Otros" y campo de texto */
#campo-otros {
    margin-top: 10px;
    padding: 8px;
    width: calc(100% - 20px);
    border: 1px solid #ccc;
    border-radius: 3px;
    display: none;
}


.checkbox-group {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    align-items: center;
}

.checkbox-item {
    display: flex;
    align-items: center;
    gap: 5px;
}


/* ESTILO DE TABLA SERVICIOS USUARIOS */
.tabla-contenedor {
    max-height: 400px; /* Ajusta la altura máxima según tus necesidades */
    max-width: 100%;
    overflow-y: auto; /* Activa el desplazamiento vertical */
    overflow-x: auto;
    border: 1px solid #ddd; /* Opcional: añade un borde para visualización */
}

.tabla-conten {
    max-height: 685px; /* Ajusta la altura máxima según tus necesidades */
    max-width: 100%;
    overflow-y: auto; /* Activa el desplazamiento vertical */
    overflow-x: auto;
    border: 1px solid #ddd; /* Opcional: añade un borde para visualización */
}

.tabla-servicios {
    width: 100%;
    border-collapse: collapse; /* Unir bordes de celdas */
    margin: 20px 0;
    font-size: 14px;
    font-family: Arial, sans-serif;
}

.tabla-servicios thead tr {
    background-color: #2d4360; /* Color de fondo del encabezado */
    color: white; /* Texto blanco */
    text-align: left;
}

.tabla-servicios thead th {
    position: sticky; /* Hace que la cabecera se quede fija */
    top: 0; /* Fija la posición en la parte superior */
    background-color: #2d4360; /* Color de fondo para distinguir la cabecera */
    z-index: 1; /* Asegura que la cabecera esté por encima del contenido */
    border: 1px solid #ddd; /* Estilo opcional */
    padding: 10px;
}


.tabla-servicios td {
    padding: 10px;
    border: 1px solid #ddd; /* Bordes sutiles */
     /* Permite que el texto se ajuste en varias líneas */
}

.tabla-servicios tr:nth-child(even) {
    background-color: #f2f2f2; /* Color de fondo alternado */
}

.tabla-servicios tr:hover {
    background-color: #e0e0e0; /* Color cuando pasas el cursor */
}


/* Color cuando pasas el cursor https://www.youtube.com/watch?v=NlDuK0Dk0FM */

/* style DE LA PAGINA AYUDA HTML */
#ayudas {
    font-family: Arial, sans-serif;
    margin: 0;
    background-color: #f4f4f4; /* Fondo general de la página */
    color: #2d4360; /* Color del texto general */
}

.faq-container {
    max-width: 800px;
    margin: 50px auto; /* Centra el contenedor */
    padding: 20px;
    background-color: #ffffff; /* Fondo blanco para contraste */
    border-radius: 8px; /* Bordes redondeados */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1); /* Sombra ligera */
}

.faq-title {
    text-align: center;
    font-size: 24px;
    margin-bottom: 20px;
    color: #2d4360; /* Azul oscuro */
}

.faq-item {
    margin-bottom: 20px;
    padding: 15px;
    border: 1px solid #f4f4f4; /* Bordes suaves entre preguntas */
    border-radius: 5px; /* Bordes redondeados para las preguntas */
    background-color: #f4f4f4; /* Fondo claro */
}

.faq-question {
    font-size: 18px;
    margin-bottom: 10px;
    color: #2d4360; /* Azul oscuro */
}

.faq-answer {
    font-size: 16px;
    color: #555; /* Texto en gris medio para las respuestas */
    line-height: 1.5;
}

/* PARTE DEL HTML CONTACTO */
.contacto-container {
    max-width: 600px;
    margin: 50px auto; /* Centrado horizontal */
    padding: 20px;
    background-color: #f4f4f4; /* Fondo blanco */
    border-radius: 8px; /* Bordes redondeados */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1); /* Sombra ligera */
    text-align: center; /* Centrado del texto */
}

.contacto-title {
    font-size: 24px;
    margin-bottom: 20px;
    color: #2d4360; /* Azul oscuro */
}

.contacto-text {
    font-size: 16px;
    margin-bottom: 20px;
    color: #555; /* Gris para el texto de presentación */
}

.contacto-info p {
    font-size: 16px;
    margin: 10px 0;
}

.contacto-info a {
    color: #2d4360; /* Azul oscuro */
    text-decoration: none; /* Sin subrayado */
    font-weight: bold;
}

.contacto-info a:hover {
    text-decoration: underline; /* Subrayado al pasar el cursor */
}

.grafica-contenedor {
    display: none; /* 🔹 Ocultar todas las gráficas inicialmente */
    width: 100%;
    text-align: center;
}
.grafica-contenedor.active {
    display: block; /* 🔹 Solo la gráfica activa será visible */
}

#contenedorGrafica{
    text-align: center !important;
    justify-content: center !important;
    align-items: center !important;
}

/* 🔹 Asegurar que la gráfica se ajuste correctamente */
#graficaPlagas {
    width: 50% !important;
    height: 50% !important;
}

/* 🔹 Diseño general de los botones */
.boton-flecha {
    width: 60px;
    height: 60px;
    border: none;
    background-color: rgba(45, 67, 96, 0.8); /* 🔹 Fondo semi-transparente para no tapar la gráfica */
    cursor: pointer;
    border-radius: 50%;
    position: absolute;
    top: 20px; /* 🔹 Aparece en la parte superior de la gráfica */
    z-index: 1000; /* 🔹 Asegurar que esté encima */
    display: flex;
    justify-content: center;
    align-items: center;
    transition: background-color 0.3s, transform 0.2s;
}

/* 🔹 Establecer contenido de flecha con CSS */


/* 🔹 Flecha izquierda */
.izquierda {
    left: 350px;
}
.izquierda::before {
    transform: rotate(135deg);
}

/* 🔹 Flecha derecha */
.derecha {
    right: 20px;
}
.derecha::before {
    transform: rotate(-45deg);
}

/* 🔹 Efecto al pasar el mouse */
.boton-flecha:hover {
    background-color: rgba(88, 191, 231, 0.9);
    transform: scale(1.1);
}

/* 🔹 Estilos de la tabla */
.certificados-tabla {
    width: 100%;
    border-collapse: collapse;
    margin-top: 20px;
    font-family: Arial, sans-serif;
    text-align: left;
    background-color: #f9f9f9;
    border-radius: 8px;
    overflow: hidden;
}

.certificados-tabla th, .certificados-tabla td {
    padding: 12px;
    border-bottom: 1px solid #ddd;
}

.certificados-tabla th {
    background-color: #2d4360;
    color: white;
    font-weight: bold;
}

/* 🔹 Estilos del botón de descarga */
.boton-descarga {
    display: inline-block;
    padding: 8px 12px;
    background-color: #58bfe7;
    color: white;
    text-decoration: none;
    border-radius: 5px;
    font-weight: bold;
    transition: background-color 0.3s ease;
}

.boton-descarga:hover {
    background-color: #2d4360;
}

/* 🔹 Botón de eliminación */
.boton-eliminar {
    padding: 6px 12px;
    background-color: #58bfe7;
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-weight: bold;
    transition: background-color 0.3s ease;
}

.boton-eliminar:hover {
    background-color: #2d4360;
}

.scroll-container {
    max-height: 300px; /* Altura máxima antes de activar el scroll */
    overflow-y: auto; /* Agregar desplazamiento vertical */
    border: 1px solid #ccc; /* Opcional: borde para diferenciar el área de la tabla */
}


@media (max-width: 1024px) {
    .dashboard {
        flex-direction: column;
        height: auto;
    }

    .sidebar {
        width: 80%;
        padding: 15px;
        text-align: center;
    }

    .main-content {
        padding: 15px;
    }

    .form-grid {
        grid-template-columns: 1fr; /* Cambia a una sola columna */
        grid-template-rows: auto;
    }
}

@media (max-width: 768px) {

    .sidebar {
        width: 100%;
        padding: 10px;
    }

    .sidebar ul li a {
        font-size: 16px;
        padding: 8px;
    }

    .sidebar-footer {
        padding: 5px;
    }

    .main-content {
        display: block; /* 🔹 Asegura que el contenido aparezca */
        width: 100%;
        padding: 15px;
    }

    .form-grid {
        flex-direction: column;
        gap: 15px;
    }

    .form-section {
        width: 100%;
        padding: 10px;
    }

    input, select, button {
        font-size: 14px;
        padding: 8px;
    }

    .tabla-contenedor {
        max-height: 250px;
        overflow-y: auto;
    }
}

@media (max-width: 480px) {
    .sidebar {
        width: 100%;
        padding: 8px;
    }

    .sidebar h2 {
        font-size: 16px;
    }

    .sidebar ul li a {
        font-size: 14px;
        padding: 6px;
    }

    .form-grid {
        flex-direction: column;
        gap: 10px;
    }

    .usuarios h1, .certificados h1 {
        font-size: 20px;
    }

    input, select, button {
        font-size: 12px;
        padding: 6px;
    }

    .tabla-servicios {
        font-size: 12px;
    }

    .boton-flecha {
        width: 35px;
        height: 35px;
    }

    .izquierda {
        left: 120px;
    }

    .derecha {
        right: 5px;
    }
}

#certi label {
    font-weight: bold;
}

/* Evitar negrita en labels de checkbox */
#certi input[type="checkbox"] + label {
    font-weight: normal;
}

#noti label {
    font-weight: bold;
}

/* Evitar negrita en labels de checkbox */
#noti input[type="checkbox"] + label {
    font-weight: normal;
}
