/* General Styles */


/* Menu toggle (hamburguesa) */
.menu-toggle {
    display: none;
    cursor: pointer;
    position: absolute;
    top: 15px;
    right: 20px;
}

.menu-toggle .bar {
    display: block;
    width: 25px;
    height: 3px;
    margin: 5px auto;
    background-color: white;
    transition: all 0.3s ease-in-out;
}

/* ==================== MENÚ PRINCIPAL ==================== */

/* Este es del bloque Menu */
nav {
    width: 100%;
    background-color: #263c53;
    position: relative;
    padding: 10px 0;
}

nav ul {
    display: flex;
    justify-content: center;
    align-items: center;
    list-style: none;
    padding: 0;
    margin: 0;
    gap: 20px;
}

/* Estilos de los enlaces del menú principal */
nav ul li a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    color: #ffffff; /* Blanco para contraste */
    font-size: 16px;
    font-weight: bold;
    text-decoration: none;
    transition: background-color 0.3s ease, color 0.3s ease;
    border-radius: 5px;
}

/* Íconos dentro de los enlaces */
nav ul li a i {
    color: #ffffff; /* Blanco */
    font-size: 20px;
}

/* Efecto al pasar el cursor */
nav ul li a:hover {
    background-color: #3498db; /* Azul claro */
    color: #fff;
}

nav ul li a:hover i {
    color: #ffffff; /* Asegura que los íconos también cambien */
}

/* ==================== SUBMENÚ ==================== */
nav ul li {
    position: relative;
}

/* Estilos base del submenú */
nav ul li ul {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background-color: #3b4d66; /* Azul más claro para mejor contraste */
    width: 220px;
    border-radius: 5px;
    padding: 10px 0;
    z-index: 100;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, transform 0.3s ease;
    transform: translateY(10px);
}

/* Mostrar el submenú al pasar el cursor */
nav ul li:hover > ul {
    display: block;
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Estilos de los enlaces dentro del submenú */
nav ul li ul li a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 15px;
    font-size: 14px;
    color: #ffffff;
    text-decoration: none;
    transition: background-color 0.3s ease, color 0.3s ease;
}

/* Cambiar color de fondo en el submenú al pasar el cursor */
nav ul li ul li a:hover {
    background-color: #1abc9c; /* Verde agua */
    color: #fff;
}

body {
    font-family: Arial, sans-serif;
    background-color: #f9f9f9;
    margin: 0;
    padding: 0;
    padding-left: 10px;
    padding-right: 10px;    
    color: #0b141c;;
}

h1 {
    text-align: center;
    font-size: 24px;
    color: #2c3e50;
    margin-bottom: 15px;
}



.btn_new {
    display: inline-block;
    padding: 10px 15px;
    background-color: #3498db;
    color: white;
    text-decoration: none;
    border-radius: 5px;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
    transition: background-color 0.3s ease, transform 0.2s ease;
    margin-bottom: 15px;
}

.btn_new:hover {
    background-color: #2980b9;
    transform: scale(1.05);
}

/* ===================== FORMULARIO DE BÚSQUEDA ===================== */
.form_search {
    display: flex;
    justify-content: center;
    margin-bottom: 15px;
}

.form_search input {
    padding: 8px;
    border: 1px solid #ccc;
    border-radius: 5px;
    font-size: 16px;
    width: 250px;
    margin-right: 5px;
}

.btn_search {
    background-color: #4CAF50;
    color: white;
    padding: 8px 15px;
    border: none;
    border-radius: 5px;
    font-size: 16px;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.btn_search:hover {
    background-color: #45a049;
}


/* ===================== TABLA ===================== */
table {
    width: 100%;
    border-collapse: collapse;
    background: white;
    text-align: left;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0px 0px 5px rgba(0, 0, 0, 0.1);
}

th, td {
    padding: 12px;
    border-bottom: 1px solid #ddd;
}

th {
    background-color: #3474b3;
    color: white;
    font-weight: bold;
    text-transform: uppercase;
}

tr:hover {
    background-color: #f4f4f4;
}

.header-flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    gap: 10px;
    flex-wrap: wrap;
}


/* ===================== ACCIONES (BOTONES) ===================== */
.link_edit, .link_delete, .link_add, .link_view {
    padding: 6px 10px;
    border-radius: 5px;
    text-decoration: none;
    font-size: 14px;
    font-weight: bold;
    margin: 3px;
    display: inline-block;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.link_edit {
    background-color: #007bff;
    color: white;
}

.link_edit:hover {
    background-color: #0056b3;
    transform: scale(1.05);
}

.link_delete {
    background-color: #e74c3c;
    color: white;
}

.link_delete:hover {
    background-color: #c0392b;
    transform: scale(1.05);
}

.link_add {
    background-color: #27ae60;
    color: white;
}

.link_add:hover {
    background-color: #219150;
    transform: scale(1.05);
}

.link_view {
    background-color: #f39c12;
    color: white;
}

.link_view:hover {
    background-color: #e67e22;
    transform: scale(1.05);
}


/* ===================== PAGINACIÓN ===================== */
.paginador {
    text-align: center;
    margin-top: 20px;
}

.paginador ul {
    display: flex;
    justify-content: center;
    list-style: none;
    padding: 0;
    gap: 5px;
}

.paginador ul li {
    display: inline-block;
}

.paginador ul li a {
    display: block;
    padding: 8px 12px;
    text-decoration: none;
    color: white;
    background-color: #3498db;
    border-radius: 5px;
    font-weight: bold;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.paginador ul li a:hover {
    background-color: #2980b9;
    transform: scale(1.05);
}

.pageSelected {
    background-color: #2c3e50;
    color: white;
    padding: 8px 12px;
    border-radius: 5px;
    font-weight: bold;
}

/* ===================== ESTILOS GENERALES PARA EL CONTENEDOR ===================== */
.container {
    max-width: 1100px; /* Se reduce el ancho para evitar que se expanda demasiado */
    width: 90%;
    margin: 70px auto 20px auto; /* Centrado con espacio arriba */
    padding: 20px;
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    overflow-x: auto; /* Permite scroll en la tabla en dispositivos pequeños */
}

/* General Button Styles */


.btn_action {
    display: inline-block;
    padding: 5px 8px; /* Más compacto */
    font-size: 12px; /* Tamaño pequeño y legible */
    font-weight: bold;
    color: #fff;
    text-decoration: none;
    border-radius: 4px;
    margin: 0 3px; /* Espaciado menor entre botones */
    text-align: center;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease; /* Transiciones para hover */
}

.btn_action.btn_view {
    background-color: #007bff; /* Azul */
    color: #fff;
    text-decoration: none;
    padding: 5px 10px;
    border-radius: 3px;
    margin-right: 5px;
    font-size: 14px;
    transition: background-color 0.3s ease;
}

.btn_action.btn_view:hover {
    background-color: #0056b3; /* Azul más oscuro al pasar el cursor */
    color: #fff;
}


.btn_view {
    background-color: #3498db;
    color: #fff;
    padding: 5px 10px;
    border-radius: 5px;
    text-decoration: none;
    margin-right: 5px;
}

.btn_view:hover {
    background-color: #2980b9;
}

.btn_delete {
    background-color: #e74c3c;
    color: #fff;
    padding: 5px 10px;
    border-radius: 5px;
    text-decoration: none;
}

.btn_delete:hover {
    background-color: #c0392b;
}


        .client-info {
            width: 80%;
            margin: 20px auto;
            border: 1px solid #ddd;
            padding: 20px;
            border-radius: 10px;
            background: #f9f9f9;
        }
        .client-info h2 {
            margin-bottom: 20px;
            text-align: center;
        }
        .client-info table {
            width: 100%;
            border-collapse: collapse;
        }
        .client-info table th, .client-info table td {
            padding: 10px;
            text-align: left;
            border-bottom: 1px solid #ddd;
        }
        .btn-back {
            display: block;
            margin: 20px auto;
            padding: 10px 20px;
            background-color: #428bca;
            color: #fff;
            text-align: center;
            text-decoration: none;
            border-radius: 5px;
            width: 150px;
        }
        .btn-back:hover {
            background-color: #3571a8;
        }
        .documents-section {
            margin-top: 40px;
        }
        .documents-section h2 {
            margin-bottom: 20px;
            text-align: center;
        }
        .documents-table {
            width: 100%;
            border-collapse: collapse;
            margin-top: 20px;
        }
        .documents-table th, .documents-table td {
            padding: 10px;
            text-align: left;
            border: 1px solid #ddd;
        }
        .documents-table th {
            background-color: #428bca;
            color: #fff;
        }
        .documents-table td a {
            color: #428bca;
            text-decoration: none;
        }
        .documents-table td a:hover {
            text-decoration: underline;
        }




/* Edit Button */
.btn_edit {
    background-color: #4CAF50; /* Verde */
}

.btn_edit:hover {
    background-color: #388E3C; /* Verde más oscuro */
    transform: scale(1.05); /* Efecto hover */
}

/* Delete Button */
.btn_delete {
    background-color: #f44336; /* Rojo */
}

.btn_delete:hover {
    background-color: #d32f2f; /* Rojo más oscuro */
    transform: scale(1.05); /* Efecto hover */
}

/* Add Dependent Button */
.btn_add {
    background-color: #2196F3; /* Azul */
}



.btn_add:hover {
    background-color: #1976D2; /* Azul más oscuro */
    transform: scale(1.05); /* Efecto hover */
}


/* Add Document Button */
.btn_addD {
    background-color: #d32f2f; /* Azul */
}


.btn_addD:hover {
    background-color: #f44336; /* Azul más oscuro */
    transform: scale(1.05); /* Efecto hover */
}

/* Header */


.header {
    background-color: #3474b3;
    color: white;
    padding: 8px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}



.header h1 {
    margin: 0;
    font-size: 24px;
    font-weight: bold;
    color: #4CAF50;
}

.optionsBar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 15px;
    flex-grow: 1;
}

.optionsBar p {
    margin: 0;
    font-size: 14px;
    color: #ecf0f1;
}

.optionsBar .photouser {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 2px solid #fff;
    object-fit: cover;
}

.optionsBar .btn-logout {
    background-color: #e74c3c;
    color: #fff;
    padding: 10px 20px;
    border-radius: 5px;
    text-decoration: none;
    font-size: 16px;
    font-weight: bold;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.optionsBar .btn-logout:hover {
    background-color: #c0392b;
    transform: scale(1.05);
}

/* Estilos generales del menú */


.search-bar {
    margin-bottom: 20px;
    text-align: right; /* Alinea todo el contenido de la barra a la derecha */
    padding-right: 20px; /* Agrega un poco de espacio desde el borde derecho */
}

.search-bar form {
    display: inline-block; /* Asegura que el formulario no ocupe todo el ancho */
}

.search-bar input {
    padding: 10px;
    width: 300px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 16px;
    margin-right: 10px; /* Espaciado entre el input y el botón */
}

.search-bar button {
    padding: 10px 20px;
    border: none;
    background-color: #3498db;
    color: white;
    border-radius: 4px;
    cursor: pointer;
    font-size: 16px;
}

.search-bar button:hover {
    background-color: #2980b9;
}

/* Modal Styles */
.modal {
    display: none; /* Hidden by default */
    position: fixed; /* Fixed positioning for overlay */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5); /* Semi-transparent background */
    justify-content: center;
    align-items: center; /* Vertical alignment */
    z-index: 1000; /* Ensure it is above other elements */
}

/* Modal Content */
.modal-content {
    background-color: #fff;
    padding: 30px;
    border-radius: 8px;
    width: 90%; /* Responsive default width */
    max-width: 600px; /* Maximum width for larger devices */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    position: relative; /* Position context for child elements */
    animation: fadeIn 0.3s ease; /* Animation for appearance */
}

/* Close Button */
.close {
    position: absolute; /* Position inside modal */
    top: 15px;
    right: 15px;
    font-size: 20px;
    font-weight: bold;
    color: #333;
    cursor: pointer;
    transition: color 0.3s ease;
}

.close:hover {
    color: #e74c3c; /* Hover color change */
}

/* ==================== TRUCK DRIVERS DEDUCTIONS PAGE ==================== */



/* Estilos para los fieldset (secciones) */
fieldset {
    border: 1px solid #ddd;
    padding: 15px;
    margin-bottom: 20px;
    border-radius: 5px;
    background-color: #f9f9f9;
}

legend {
    font-weight: bold;
    font-size: 16px;
    color: #333;
    padding: 0 10px;
}

/* Estilos para las etiquetas y campos de entrada */
label {
    display: inline-block;
    margin: 5px 10px;
    font-size: 14px;
    color: #555;
}

input[type="number"] {
    width: 100px; /* Ancho fijo para los campos de números */
    padding: 5px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 14px;
    text-align: right; /* Alinea los números a la derecha */
}

input[type="number"]:focus {
    border-color: #3498db;
    outline: none;
}

/* Estilos para los totales */
.total-input {
    width: 100px; /* Ancho fijo para los campos de total */
    padding: 5px;
    margin-top: 10px;
    font-weight: bold;
    text-align: right; /* Alinea los números a la derecha */
    background-color: #eaf1f8;
    border: 1px solid #ccc;
    border-radius: 4px;
}

/* Estilos para los botones */
button[type="submit"] {
    display: block;
    width: 10%;
    padding: 10px;
    background-color: #4CAF50;
    color: white;
    border: none;
    border-radius: 5px;
    font-size: 16px;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

button[type="submit"]:hover {
    background-color: #45a049;
}

/* Estilos para la sección de firma */
#signature, #date {
    width: 200px; /* Ancho fijo para los campos de firma y fecha */
    padding: 5px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 14px;
}

/* Estilos para el gran total */
#grand_total {
    width: 150px; /* Ancho fijo para el gran total */
    padding: 5px;
    font-weight: bold;
    text-align: right;
    background-color: #eaf1f8;
    border: 1px solid #ccc;
    border-radius: 4px;
}

/* Estilos para las secciones en línea */
.cleaning, .electronics, .tools, .misc_supplies, .transportation, .protective_clothing, .clothing, .office_supplies, .load_expenses {
    display: flex;
    flex-wrap: wrap;
    gap: 10px; /* Espacio entre los elementos */
    margin-bottom: 10px;
}

/* Estilos para los labels dentro de las secciones */
.cleaning label, .electronics label, .tools label, .misc_supplies label, .transportation label, .protective_clothing label, .clothing label, .office_supplies label, .load_expenses label {
    display: flex;
    align-items: center;
    gap: 5px; /* Espacio entre el texto y el input */
}

/* Modal Heading */
.modal-content h2 {
    margin-bottom: 20px;
    font-size: 24px;
    color: #34495e; /* Professional color */
    text-align: center;
}

/* Form Labels */
.modal-content label {
    display: block;
    font-weight: bold;
    margin-bottom: 5px;
    color: #555;
}

/* Input Fields and Select */
.modal-content input,
.modal-content select {
    width: 100%;
    padding: 10px;
    margin-bottom: 15px;
    border: 1px solid #ddd;
    border-radius: 5px;
    font-size: 16px;
    box-sizing: border-box;
}

/* Save Button */
.modal-content button.btn_save {
    width: 100%;
    padding: 12px;
    background-color: #4CAF50;
    color: white;
    border: none;
    border-radius: 5px;
    font-size: 18px;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.modal-content button.btn_save:hover {
    background-color: #45a049;
}

/* Animation for Modal Appearance */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: scale(0.9);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* Dashboard */
.dashboard {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 20px;
    margin: 20px auto;
    width: 90%;
}

.dashboard a {
    flex: 1 1 calc(25% - 20px);
    text-align: center;
    padding: 20px;
    background-color: #ffffff;
    color: #34495e;
    text-decoration: none;
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: background-color 0.3s ease, transform 0.2s;
}

.dashboard a:hover {
    background-color: #ecf0f1;
    transform: translateY(-3px);
}

.dashboard i {
    font-size: 40px;
    margin-bottom: 10px;
    color: #3498db;
}

/* Form */
.form_register {
    background: #ffffff;
    padding: 30px 40px;
    margin: 50px auto;
    width: 50%;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    border: 1px solid #ddd;
}

.form_register input,
.form_register select,
.form_register textarea {
    width: 100%;
    padding: 10px;
    margin-bottom: 15px;
    border: 1px solid #ddd;
    border-radius: 5px;
    font-size: 16px;
}

.form_register textarea {
    height: 100px;
    resize: none;
}

.form_register .btn_save {
    display: block;
    width: 100%;
    padding: 15px;
    background: #4CAF50;
    color: white;
    border: none;
    border-radius: 5px;
    font-size: 18px;
}

/* Alert Messages */
.alert {
    margin: 10px 0;
    padding: 10px;
    border-radius: 5px;
    font-size: 14px;
    text-align: center;
}

.msg_error {
    color: #fff;
    background: #e74c3c;
    border: 1px solid #c0392b;
}

.msg_success {
    color: #fff;
    background: #2ecc71;
    border: 1px solid #27ae60;
}


/* PAGINADOR clients_registed.php */
.pagination {
    padding: 15px;
    list-style: none;
    background: #FFF;
    margin-top: 15px;
    display: flex;
    justify-content: flex-end; /* Alineado a la derecha */
    gap: 8px; /* Espaciado entre los elementos */
}

.pagination a, .pagination .pageSelected {
    color: #428bca;
    border: 1px solid #ddd;
    padding: 8px 12px; /* Más espacio en los botones */
    display: inline-block;
    font-size: 15px;
    text-align: center;
    min-width: 35px; /* Asegura un ancho mínimo uniforme */
    text-decoration: none;
    border-radius: 4px; /* Bordes redondeados */
    transition: all 0.3s ease; /* Suaviza los cambios de estilo */
}

.pagination a:hover {
    background: #ddd;
    color: #333;
    border-color: #bbb; /* Cambia el borde al pasar el cursor */
}

.pagination .pageSelected {
    color: #FFF;
    background: #428bca;
    border: 1px solid #428bca;
    font-weight: bold;
    pointer-events: none; /* Deshabilita clics en la página actual */
}

/* Botones adicionales con iconos */
.pagination .btn {
    display: flex;
    align-items: center;
    gap: 5px; /* Espaciado entre el icono y el texto */
}

/* === CORPORATION STYLES === */

.corp-wrapper {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px; /* Margen a izquierda y derecha */
}

.corp-title {
    font-size: 26px;
    margin-bottom: 20px;
    color: #004080;
}

.corp-section-title {
    margin-top: 40px;
    font-size: 22px;
    color: #2c3e50;
    border-bottom: 2px solid #ccc;
    padding-bottom: 5px;
}

.corp-data-list {
    list-style: none;
    padding: 0;
    margin: 10px 0;
}

.corp-data-list li {
    margin-bottom: 8px;
    font-size: 16px;
}

.corp-form-selector select {
    padding: 5px 10px;
    margin-top: 10px;
    font-size: 16px;
}

.corp-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 15px;
    background-color: #f9f9f9;
}

.corp-table th,
.corp-table td {
    padding: 10px;
    border: 1px solid #ccc;
    text-align: left;
}

.corp-table th {
    background-color: #e0e0e0;
    color: #333;
}

.btn-add-corp {
    display: inline-block;
    margin-top: 10px;
    padding: 8px 15px;
    background-color: #004080;
    color: #fff;
    text-decoration: none;
    border-radius: 4px;
    font-weight: bold;
    transition: background-color 0.3s ease;
}

.btn-add-corp:hover {
    background-color: #0066cc;
}

.corp-button {
    padding: 10px 18px;
    background-color: #004080;
    color: #fff;
    border: none;
    border-radius: 4px;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    margin-top: 10px;
    transition: background-color 0.3s ease;
}

.corp-button:hover {
    background-color: #0066cc;
}



/* ===================== RESPONSIVE DESIGN ===================== */
@media (max-width: 1024px) {
    .container {
        max-width: 95%;
        width: 95%;
        padding: 15px;
    }
}


/* ===================== MENÚ RESPONSIVO ===================== */
@media (max-width: 768px) {
    /* Ocultar submenús por defecto en móviles */
    nav ul li ul {
        position: static;
        display: none; /* Oculto hasta que se active */
        background-color: #2d3e50;
        width: 100%;
        padding: 0;
    }

    /* Mostrar el submenú cuando tenga la clase .show */
    nav ul li ul.show {
        display: block;
    }

    /* Alinear el menú en columna */
    nav ul {
        flex-direction: column;
        align-items: flex-start;
        padding: 10px;
        display: none; /* Oculto por defecto */
        width: 100%;
    }

    /* Espaciado adecuado entre los elementos */
    nav ul li {
        width: 100%;
    }

    nav ul li a {
        width: 100%;
        padding: 15px;
        border-bottom: 1px solid #34495e;
    }

    /* Mostrar menú hamburguesa */
    .menu-toggle {
        display: block;
        cursor: pointer;
        padding: 10px;
        background-color: #2d3e50;
        text-align: right;
        position: relative;
        z-index: 101;
    }

    .menu-toggle .bar {
        display: block;
        width: 30px;
        height: 3px;
        margin: 5px auto;
        background-color: white;
        transition: all 0.3s ease-in-out;
    }

    /* Clase activa cuando el menú está abierto */
    nav ul.active {
        display: flex;
    }

    .container {
        width: 95%;
        padding: 15px;
    }


    .image {
        width: 100%; /* Hacer que las imágenes ocupen el ancho completo */
    }

    .sidebar {
        display: none; /* Ocultar la barra lateral */


    .modal-content {
        width: 90%; /* Adjust width for smaller devices */
        padding: 20px;
    }

    .modal-content h2 {
        font-size: 20px; /* Smaller font for headings */
    }

    .modal-content button.btn_save {
        font-size: 16px; /* Adjust button size */
    }
    
    .form_register {
        width: 90%;
        padding: 20px;

    .menu-toggle {
        display: block; /* Muestra la hamburguesa */
        cursor: pointer;
        position: absolute;
        top: 15px;
        right: 20px;
    }

    .corp-col {
        flex: 1 1 100%;


    table, .btn {
        font-size: 12px;
    }

    table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }

    .form_search {
        flex-direction: column;
        align-items: center;
    }

    .form_search input {
        width: 100%;
        margin-bottom: 10px;
    }    


    .cleaning, .electronics, .tools, .misc_supplies, .transportation, .protective_clothing, .clothing, .office_supplies, .load_expenses {
        flex-direction: column; /* Cambia a columna en pantallas pequeñas */
    }

    input[type="number"], .total-input, #signature, #date, #grand_total {
        width: 100%; /* Ocupa todo el ancho en pantallas pequeñas */
    }
}
