body {
    font-family: 'Roboto', sans-serif;
    margin: 0;
    background-color: #f9f9f9;
    color: #333;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

@media (max-width: 768px) {
    .botonEliWhaPDF {
        display: inline-block;
        padding: 5px 5px !important;
        width: 80px !important;
        height: 80px !important;
    }

    .producto-detalles,
    .formulario-edicion {
        width: 100% !important;
    }

    .tabla-scroll.producto {
        overflow-x: auto;
    }

    .tabla-productos th,
    .tabla-productos td {
        font-size: 12px;
        padding: 6px;
    }

    #guardar-btn {
        width: 100%;
        padding: 12px;
        font-size: 16px;
    }

    .contenedor-tasa-incremento {
        flex-direction: column !important;
        width: 100% !important;
        flex-wrap: wrap !important;
    }

    .contenedor-tasa-incremento>div {
        width: 100% !important;
        flex: unset !important;
        max-width: 100% !important;
    }

    .contenedor-interno.izquierdo {
        flex-direction: column !important;
        width: 100% !important;
        flex: 0 0 100% !important;
    }

    .contenedor-interno.izquierdo>div {
        width: 100% !important;
    }

    .contenedor-interno.derecho {
        width: 100% !important;
    }

    /* Grupos internos del contenedor izquierdo en móvil */
    .contenedor-interno.izquierdo>div[style*="flex: 0 0 95%"],
    .contenedor-interno.izquierdo>div[style*="flex: 0 0 5%"] {
        flex: 0 0 100% !important;
        width: 100% !important;
    }

    #contenedor-tasa-paralela {
        flex: 0 0 100% !important;
        width: 100% !important;
        justify-content: center !important;
    }

    #contenedor-contenedor-tablas {
        width: 100% !important;
        overflow-x: auto !important;
    }

    #contenedor-multiplicadores-inferior {
        width: 100% !important;
    }

    .producto-detalles label,
    .producto-detalles h3 {
        font-size: 16px !important;
        line-height: 1.4 !important;
    }

    .producto-detalles {
        gap: 14px;
    }

    .producto-info {
        width: 100%;
    }

    .producto,
    .contenedor-principal,
    .bloque {
        width: 100% !important;
        max-width: 1440PX !important;
        /*box-sizing: border-box;*/
    }

    .tabla-productos {
        display: table !important;
        overflow-x: auto;
        white-space: nowrap;
        min-width: 900px;
        /* Para forzar scroll horizontal en móviles */
    }

    /**Area de ingreso de nuevo producto**/
    .form-group {
        display: flex;
        flex-direction: column;
        align-items: flex-start !important;
        /* asegura que todo esté alineado a la izquierda */
        margin-bottom: 16px;
        width: 100% !important;
    }

    .form-group label {
        font-weight: bold;
        margin-bottom: 5px;
        text-align: left !important;
        width: 100% !important;
    }

    .form-group input,
    .form-group select,
    .form-group textarea {
        padding: 8px;
        font-size: 14px;
        width: 100% !important;
        box-sizing: border-box;
    }

    .tabla-scroll {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .tabla-productos img {
        max-width: 70px;
        height: auto;
    }

    .resumen-precios,
    .resumen-subtotal {
        font-size: 13px;
    }

    .cantidad input {
        width: 60px;
    }

    seelct #rif {
        width: 100% !important;
    }

    /* Area para el encabezado del presupueso - Datos del cliente y del Asesor */
    #select-rif-container {
        flex-direction: row;
        /* mantiene select + input en una fila */
        width: 100% !important;
    }

    #rif-row label {
        display: inline;
        margin-bottom: 5px;
        font-weight: 500;
    }

    #select-rif-container select,
    #select-rif-container input {
        flex: 1;
        padding: 8px;
        font-size: 14px;
    }

    input[type="text"],
    input[type="tel"],
    textarea {
        max-width: 100%;
    }


    #informacionPresupuesto input[type="text"],
    #informacionPresupuesto input[type="tel"],
    #informacionPresupuesto select,
    #informacionPresupuesto textarea {
        padding: 4px 8px;
        font-size: 14px;
        border: 1px solid #ccc;
        border-radius: 6px;
        width: 100% !important;
        max-width: 300px;
        display: inline-block;
        vertical-align: middle;
    }

    #informacionPresupuesto select {
        width: 300px !important;
        max-width: 300px !important;
    }

    #informacionPresupuesto {
        flex-direction: column;
    }

    #columna-izquierda,
    #columna-derecha {
        width: 100%;
    }

    .form-row,
    .form-row.full {
        flex-direction: column;
        align-items: flex-start;
    }

    label {
        width: 100%;
        margin-bottom: 4px;
    }

    input,
    select,
    textarea {
        width: 100%;
    }

    #select-rif-container {
        flex-direction: column;
        width: 100%;
    }

    #select-rif-container select,
    #select-rif-container input {
        width: 100%;
    }



}

/*********Fin de la media query***************/
.contenedor-tasa-incremento>div {
    align-items: center;
    width: 100%;
    flex: unset;
}

.tabla-scroll {
    overflow-x: auto;
    width: 100%;
}

.tabla-productos {
    width: 100%;
    min-width: 800px;
    /* O ajusta según tus columnas */
    border-collapse: separate;
    margin-top: 20px;
    font-size: 12px;
    font-family: 'Roboto', sans-serif;
    background: #fcfdff;
    border: 1px solid #cce1f5;
    border-radius: 8px;
    table-layout: auto;
}

.tabla-productos th,
.tabla-productos td {
    text-align: left;
    padding: 8px;
    font-size: 14px;
    border: 1px solid #ccc;
    vertical-align: top;
}

.contenedor-principal {
    width: 100%;
    max-width: 1440px;
    margin: 30px auto;
    padding: 5px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    overflow-x: auto
}

.bloque {
    margin-bottom: 40px;
}

.producto-info {
    position: relative;
}

/*
.producto-info button {
    background: none;
    border: none;
    cursor: pointer;
    margin-left: 10px;
}

.producto-info button img {
    width: 36px;
    height: 36px;
}
*/
.producto-titulo {
    font-size: 24px;
    font-weight: bold;
    margin: 20px 0;
}

.producto-detalles {
    background: #f3f3f3;
    padding: 15px;
    border-radius: 8px;
    flex: 1;
}

.producto-detalles h3 {
    margin-top: 0;
    font-size: 18px;
    border-bottom: 1px solid #ccc;
    padding-bottom: 6px;
}

.formulario-edicion {
    background: #fefefe;
    padding: 15px 20px;
    border: 1px solid #ddd;
    border-radius: 8px;
}

.formulario-edicion h3 {
    margin-top: 0;
}

.form-group {
    margin-bottom: 12px;
}

.form-group label {
    display: block;
    font-weight: 500;
    margin-bottom: 5px;
}

.form-group input {
    width: 40%;
    padding: 8px;
    border-radius: 5px;
    border: 1px solid #ccc;
    box-sizing: border-box;
}

.form-group #nuevo_sku {
    width: 100px !important;
    /* más pequeño */
}

.form-group select {
    width: 30%;
    padding: 8px;
    border-radius: 5px;
    border: 1px solid #ccc;
    box-sizing: border-box;
}

input[type="submit"] {
    background-color: #0073aa;
    color: #fff;
    padding: 10px 20px;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    margin-top: 10px;
}

input[type="submit"]:hover {
    background-color: #005f8d;
}

#modal-config {
    display: none;
    position: fixed;
    top: 10%;
    left: 50%;
    transform: translateX(-50%);
    background: white;
    padding: 20px;
    border-radius: 12px;
    border: 2px solid #ccc;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
    z-index: 1000;
    max-height: 90vh;
    overflow-y: auto;
    width: 90%;
    max-width: 1000px;
}

#modal-config h3 {
    margin-top: 0;
    font-size: 20px;
    border-bottom: 1px solid #ccc;
    padding-bottom: 6px;
}

#overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    z-index: 999;
}

.contenedor-tasa-incremento {
    display: flex;
    flex-wrap: nowrap;
    gap: 20px;
    width: 100%;
    background: #f3f9ff;
    padding: 15px;
    border-radius: 8px;
    border: 1px solid #cce1f5;
}

.contenedor-interno {
    flex: 1 1 30%;
    min-width: 250px;
}

/* Contenedor izquierdo con layout horizontal flexible - 80% de ancho */
.contenedor-interno.izquierdo {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    align-items: flex-start;
    flex: 0 0 80%;
}

/* Grupo interno del 80% con elementos flexibles */
.contenedor-interno.izquierdo>div[style*="flex: 0 0 80%"] {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    width: 100%;
}

.contenedor-interno.izquierdo>div[style*="flex: 0 0 80%"]>div {
    flex: 1 1 auto;
    min-width: fit-content;
}

/* Contenedor derecho mantiene layout vertical */
.contenedor-interno.derecho {
    display: flex;
    flex-direction: row;
    gap: 10px;
}

/* Contenedor de tasa paralela - 20% de ancho */
#contenedor-tasa-paralela {
    flex: 0 0 20%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

/* Contenedor de tablas - 100% ancho con scroll horizontal */
#contenedor-contenedor-tablas {
    width: 100%;
    overflow-x: auto;
    margin: 20px 0;
}

/* Contenedor multiplicadores inferior - 100% ancho, elementos apilados */
#contenedor-multiplicadores-inferior {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* Contenedor principal de info tasas - elementos apilados verticalmente */
#infoTasasContenido {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: 100%;
}


small {
    display: block;
    margin-top: 4px;
    color: #666;
}

.formulario-edicion .form-group {
    display: flex;
    align-items: center;
    margin-bottom: 12px;
    gap: 12px;
}

.formulario-edicion .form-group label {
    width: 200;
    text-align: right;
    margin-bottom: 0;
    font-weight: 500;
    font-size: 14px;
}

.formulario-edicion .form-group input {
    flex: 1;
    padding: 8px 10px;
    border-radius: 5px;
    border: 1px solid #ccc;
    font-size: 14px;
}

.btn-enviar-whatsapp {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background-color: #25D366;
    /* color WhatsApp */
    color: #fff;
    font-size: 16px;
    font-weight: bold;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    text-decoration: none;
}

.btn-enviar-whatsapp:hover {
    background-color: #1ebe5d;
    transform: scale(1.03);
}

.btn-enviar-whatsapp:active {
    transform: scale(0.97);
}

/* Opcional: agregar un icono de WhatsApp al botón */
.btn-enviar-whatsapp::before {
    content: "";
    display: inline-block;
    width: 20px;
    height: 20px;
    background-image: url('https://upload.wikimedia.org/wikipedia/commons/6/6b/WhatsApp.svg');
    background-size: contain;
    background-repeat: no-repeat;
}


.tabla-productos thead {
    background-color: #e8f1fc;
    color: #333;

}

.tabla-productos th,
.tabla-productos td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid #e0e0e0;
}


.tabla-productos th {
    font-weight: 600;
    font-size: 11px;
}

.tabla-productos td {
    font-size: 12px;
}

.tabla-productos tr:hover {
    background-color: #f3f9ff;
}

.multiplicador-container {
    background: #e6f7ff;
    border: 2px solid #91d5ff;
    border-radius: 12px;
    padding: 20px;
    margin-top: 40px;
    margin-bottom: 40px;
    box-shadow: 0 2px 8px rgba(0, 123, 255, 0.08);
    position: relative;
    font-family: 'Roboto', sans-serif;
}

.multiplicador-container::before {
    position: absolute;
    top: -14px;
    left: 20px;
    background: #e6f7ff;
    color: #096dd9;
    font-weight: bold;
    padding: 0 8px;
    font-size: 24px;
}

input.cantidad[type=number] {
    width: 70px;
    height: 25px;
    padding: 6px 8px;
    font-size: 18px;
    border: 1px solid #333;
    /* borde más oscuro */
    border-radius: 6px;
    text-align: right;
    color: #222;
    /* texto más oscuro */
    background-color: #f9f9f9;
}

/* Para Webkit browsers (Chrome, Safari, Edge) */
input.cantidad[type=number]::-webkit-inner-spin-button,
input.cantidad[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: inner-spin-button;
    appearance: inner-spin-button;
    background-color: #555;
    /* fondo oscuro del spinner */
    opacity: 1;
    /* asegúrate que esté visible */
    filter: brightness(0.7);
    width: 18px;
    height: 30px;
}

/* Firefox */
input.cantidad[type=number] {
    -moz-appearance: textfield;
    /* elimina spinner predeterminado */
}

.spanPrecio {
    display: none;
}

/**************************************/
/**************************************/
/**************************************/
/**************************************/
/**************************************/
/**************************************/
/**************************************/
label.opcionesPrecios input[type="checkbox"] {
    display: none;
}


.opcionesPrecios {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 6px;
    padding: 10px 14px;
    border: 2px solid #cbd5e1;
    border-radius: 10px;
    background-color: #f8fafc;
    cursor: pointer;
    font-size: 15px;
    transition: all 0.25s ease;
    font-weight: 500;
    color: #334155;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
    max-width: 165px;
}

/* Cuando el input está seleccionado */
.opcionesPrecios input:checked+span,
.opcionesPrecios input:checked~span {
    color: #2563eb;
    font-weight: 600;
}

/* Si quieres que el borde y fondo cambien al seleccionar */
.opcionesPrecios input:checked~.spanPrecio {
    color: #1d4ed8;
}

.opcionesPrecios input:checked~.spanTitulo {
    color: #1d4ed8;
}

/* Resaltar todo el label cuando esté seleccionado */
.opcionesPrecios input:checked~.spanPrecio,
.opcionesPrecios input:checked+.spanTitulo {
    font-weight: 700;
}

/* Opcional: sombra al pasar el mouse */
.opcionesPrecios:hover {
    background-color: #e0f2fe;
    border-color: #38bdf8;
}

/*********************/
.multiplicadores-grid.cliente-config {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 12px 16px;
    margin: 15px 0;
    background-color: #f4f9ff;
    border: 1px solid #c9d9ee;
    border-radius: 10px;
    font-size: 15px;
    flex-wrap: wrap;
}

.multiplicadores-grid.cliente-config big {
    font-weight: bold;
    font-size: 16px;
    color: #1a3e66;
}

/*
.multiplicador-label {
        display: block;
        margin-bottom: 8px;
        font-weight: 500;
    }
*/
.multiplicador-label {
    display: flex;
    align-items: center;
    gap: 8px;
    background-color: #e9f1fb;
    padding: 6px 10px;
    border-radius: 6px;
    cursor: pointer;
    border: 1px solid #cad3de;
    transition: background-color 0.3s, border 0.3s;
    font-size: 12px;
    max-width: 185px;
}

.multiplicador-label:hover {
    background-color: #d4e7f9;
    border-color: #96b7e3;
}

.multiplicador-label {
    cursor: pointer;
    display: inline-block;
    padding: 5px 10px;
    border-radius: 5px;
    transition: background-color 0.2s ease;
}

.multiplicador-label.selected {
    background-color: #d4edda;
    /* verde claro */
    border: 1px solid #28a745;
}

/* Oculta los checkboxes, pero mantiene clic sobre el label */


/* Estilo para el mensaje */
#mensaje-recargo {
    color: #0076b6;
}


.select-unidad {
    padding: 6px 12px;
    border-radius: 6px;
    border: 1px solid #ccc;
    background-color: #fff;
    font-size: 14px;
    color: #333;
    margin-left: 6px;
    cursor: pointer;
    transition: border 0.3s, box-shadow 0.3s;
}

.select-unidad:focus {
    border-color: #0076b6;
    box-shadow: 0 0 3px rgba(0, 118, 182, 0.5);
}

.espaciador-final {
    height: 40vh;
    /* 20% del alto de la ventana del navegador */
}

/************************** css para el area de busqueda **************************/
#sugerencias {
    list-style: none;
    padding: 0;
    margin: 0;
    border: 1px solid #ccc;
    max-height: 200px;
    overflow-y: auto;
    background: white;
    position: absolute;
    z-index: 1000;
    width: 100%;
}

#sugerencias li {
    padding: 8px;
    cursor: pointer;
}

#sugerencias li:hover {
    background-color: #f0f0f0;
}

/********* Estilo de botones de la tabla de presupuesto **********************/
/* Estilo general para botones */
.botonEliWhaPDF {
    display: inline-block;
    padding: 10px 18px;
    border-radius: 6px;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    margin: 5px;
    width: 120px;
    height: 120px;
}

.guardarPres img {
    width: 20px !important;
    /* Ajusta este porcentaje según prefieras */
    height: 20px !important;
}

.boton {
    display: inline-block;
    padding: 10px 18px;
    font-size: 14px;
    font-weight: bold;
    color: #fff;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    margin: 5px;
    width: 120px;
    height: 40px;
}

/* Hover y efecto clic */
.boton:hover {
    background-color: #00a7e1;
}

.boton:active {
    transform: scale(0.97);
}

/* Botón eliminar específico */
.boton-eliminar {
    background-color: #e74c3c;
    width: 50px;
}

.boton-eliminar:hover {
    background-color: #c0392b;
}

/* Botón WhatsApp */
.boton-whatsapp {
    background-color: #25D366;
}

.boton-whatsapp:hover {
    background-color: #1da851;
}

.only-pdf {
    visibility: hidden;
    height: 0;
    overflow: hidden;
    position: absolute;
    z-index: -1;
}

input[type="number"] {
    -moz-appearance: textfield;
    /* Firefox */
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: auto;
    /* Asegura que aparezcan en Chrome/Safari */
}

/**** Para colocar la primera columna fija a la izquierda y poder desplazarse haciendo scroll en la tabla de la version mobil ************************/
.tabla-scroll-wrapper {
    overflow-x: auto;
    max-width: 100%;
}

.tabla-con-columna-fija {
    border-collapse: separate;
    /* Cambiar a separate para sticky más confiable */
    border-spacing: 0;
    /* Sin espacios entre celdas */
    min-width: 700px;
    width: 100%;
}

.tabla-con-columna-fija thead th {
    position: sticky;
    top: 0;
    background-color: #f3f4f6;
    z-index: 30;
    border-bottom: 2px solid #ccc;
    padding: 8px;
    text-align: left;
}

/* Primera columna header */
.tabla-con-columna-fija thead th:first-child {
    left: 0;
    z-index: 40;
    /* Más alto para que esté sobre las otras celdas */
    border-right: 2px solid #ccc;
}

/* Primera columna celdas */
.tabla-con-columna-fija tbody td:first-child {
    position: sticky;
    left: 0;
    background-color: #fff;
    z-index: 20;
    border-right: 2px solid #ccc;
    padding: 8px;
}

/* Opcional: fondo para filas pares para mejorar visibilidad */
.tabla-con-columna-fija tbody tr:nth-child(even) td {
    background-color: #f9fafb;
}

/* Opcional: padding y estilos para celdas */
.tabla-con-columna-fija td,
.tabla-con-columna-fija th {
    padding: 8px;
    white-space: nowrap;
    /* Evita quiebre de texto */
}

/******** Estilos para los resultados del PDF  *******************/
.totales-metodos .monto {
    text-align: right;
    width: 150px;
    /* ancho fijo */
    font-weight: bold;
    display: inline-block;
}

.totales-metodos {
    text-align: right;
    width: 100%;
    /* ancho fijo */
    display: inline-block;
}



.rif-group {
    display: flex;
    width: 100%;
    max-width: 300px;
    border: 1px solid #ccc;
    border-radius: 4px;
    overflow: hidden;
}




.rif-group {
    display: flex;
    width: 100%;
    max-width: 300px;
    gap: 5px;
}

.rif-group select {
    width: 10%;
    padding: 6px;
    font-size: 14px;
}

.rif-group input {
    width: 90%;
    padding: 6px;
    font-size: 14px;
}

#formTasaManual {
    background-color: #f9f9f9;
    padding: 20px;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    max-width: 100%;
    margin: 20px auto;
    font-family: 'Segoe UI', sans-serif;
}

#formTasaManual label {
    display: block;
    margin-bottom: 10px;
    font-weight: bold;
    color: #333;
    font-size: 16px;
}

#formTasaManual input[type="number"] {
    width: 100%;
    max-width: 120px;
    padding: 10px 12px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 15px;
    transition: border-color 0.3s;
}

#formTasaManual input[type="number"]:focus {
    border-color: #0077cc;
    outline: none;
}

#formTasaManual .boton-guardar {
    background-color: #0077cc;
    color: white;
    padding: 10px 16px;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-size: 15px;
    margin-top: 15px;
    transition: background-color 0.3s ease;
}

#formTasaManual .boton-guardar:hover {
    background-color: #005fa3;
}

#mensaje_tasa {
    display: inline-block;
    margin-left: 12px;
    color: #2a8a29;
    font-weight: 500;
    font-size: 14px;
}

.boton-guardar {
    background-color: #00a7e1 !important;
    /* Azul moderno */
    color: white;
    border: none;
    padding: 10px 20px;
    font-size: 16px;
    border-radius: 6px;
    cursor: pointer;

}

.boton-guardar:hover {
    background-color: #77BC1F !important;
    /* Azul más oscuro al pasar el mouse */
}


.select-BCV-DIV {
    width: 80px !important;
    /* suficiente para mostrar 'DIV' */
    padding: 2px 6px;
    font-size: 14px;
}

#precioNeto {
    width: 120px;
    /* suficiente para mostrar 'DIV' */
}

/* Para mostrar los check como inhabilitados ***/
.opcionesPrecios input.bloqueado {
    opacity: 0.5;
    cursor: not-allowed;
}

/** FIBOSEARCH **/
/* Contenedor principal del buscador */
.algolia-autocomplete {
    position: relative;
    max-width: 500px;
    margin: 40px auto;
    padding: 20px;
    background-color: #f9f9f9;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Estilo del input de búsqueda */
.algolia-autocomplete input[type="search"] {
    width: 100%;
    padding: 12px 16px;
    font-size: 16px;
    border: 1px solid #ccc;
    border-radius: 8px;
    outline: none;
    box-sizing: border-box;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.algolia-autocomplete input[type="search"]:focus {
    border-color: #0073aa;
    box-shadow: 0 0 0 2px rgba(0, 115, 170, 0.2);
}

/* Estilo del contenedor de sugerencias */
.autocomplete-suggestions {
    position: absolute !important;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 99999 !important;
    background: #fff;
    border: 1px solid #ddd;
    border-top: none;
    max-height: 300px;
    overflow-y: auto;
    border-radius: 0 0 8px 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Cada resultado individual */
.autocomplete-suggestion {
    padding: 12px 16px;
    font-size: 15px;
    border-bottom: 1px solid #f1f1f1;
    cursor: pointer;
    transition: background-color 0.2s;
}

.autocomplete-suggestion:last-child {
    border-bottom: none;
}

.autocomplete-suggestion:hover {
    background-color: #f0f8ff;
}

/* Si quieres darle estilo especial al texto dentro de los resultados */
.autocomplete-suggestion strong {
    color: #0073aa;
}

/** Justificar contenedores internos del mensaje de Whatsapp producto simple  **/
.contenedor-mensaje-whatsapp-preview {
    display: inline-flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
    flex-wrap: wrap;
    /* por si se reduce en móvil */
    max-width: 1300px;
    width: 100%;
}

.mensaje-whatsapp-preview {
    flex: 1;
    /*min-width: 200px;
    max-width: 800px;*/
    width: 100%;
}

.botonera-whatsapp {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: center;
    width: 50%;
}

button.whatsappPdf {
    background-color: #1ebe5d;
    color: white;
    font-family: Arial, sans-serif;
    font-size: 14px;
    padding: 10px 16px;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    min-width: 150px;
    /* asegúrate de que ambos tengan el mismo ancho mínimo */
    text-align: center;
}


@media (max-width: 600px) {
    .contenedor-mensaje-whatsapp-preview {
        flex-direction: column;
        align-items: stretch;
    }

    .botonera-whatsapp {
        align-items: stretch;
    }

    .botonera-whatsapp button {
        width: 100%;
    }


    #informacionPresupuesto label {
        font-weight: 500;
        margin-right: 10px;
        min-width: 25px;
        display: inline-block;
        vertical-align: middle;
    }


    .linea-descuento {
        display: flex;
        flex-direction: column;
        gap: 4px;
    }

    .contenedor-descuento {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 8px;
        text-align: left;
    }

    .contenedor-descuento input[type="number"] {
        width: 40px;
    }

    .contenedor-descuento label {
        width: 25px;
    }

    .label-porcentaje {
        font-size: 0.9em;
        white-space: nowrap;
    }

    .resumen-descuento {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .resumen-descuento .monto {
        font-weight: bold;
        min-width: 80px;
        text-align: right;
    }


}

/*** Estilos para el Modal de la Tasa Paralela *****/
.modal-tasa {
    display: none;
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.5);
}

.modal-tasa-contenido {
    background-color: #fff;
    margin: 10% auto;
    padding: 20px;
    border-radius: 8px;
    width: 90%;
    max-width: 400px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.25);
    position: relative;
}

.cerrar-modal {
    position: absolute;
    top: 10px;
    right: 14px;
    font-size: 24px;
    font-weight: bold;
    color: #333;
    cursor: pointer;
}

#formTasaManual input {
    width: 100%;
    padding: 8px;
    margin-bottom: 10px;
    box-sizing: border-box;
}

/* para mejorar el area de Totales de Factura Porforma*/
.fila-proforma {
    display: flex;
    align-items: center;
    padding: 5px 0;
}

.proformaTermino {
    flex: 2;
    /* Más ancho */
    padding-right: 10px;
    text-align: right;
}

.montoProforma {
    flex: 1;
    /* Menor ancho */
    text-align: right;
}

.montoProformaInf {
    flex: 1;
    /* Menor ancho */
    text-align: right;
}

.contenedor-flex {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.divIzquierdo,
.divDerecho {
    width: 49%;
    border: 1px solid black;
    box-sizing: border-box;
}

.divInferior {
    width: 99%;
    margin-top: 10px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.divInferior .proformaTermino {
    flex: 1 1 60%;
    padding-right: 10px;
}

.proformaTerminoInf {
    flex: 1 1 65%;
    padding-right: 10px;
}

.divInferior .montoProforma {
    flex: 1 1 20%;
    text-align: right;
}

/* 📱 Responsive para móviles */
@media (max-width: 768px) {

    .divIzquierdo,
    .divDerecho {
        width: 100%;
    }

    .divInferior {
        flex-direction: column;
        text-align: left;
    }

    .divInferior .proformaTermino,
    .divInferior .montoProforma {
        flex: 1 1 100%;
        text-align: left;
        padding: 5px 0;
    }
}

/** Ocultar seccion de literatura interna en la calculadora  **/
.pdf-book-cover {
    display: none;
}


.btn-instalada {
    background-color: #28a745;
    /* verde éxito */
    color: white;
    border: none;
}

.btn-no-instalada {
    background-color: #ffc107;
    /* amarillo advertencia */
    color: black;
    border: none;
}

.flecha {
    font-size: 1.2em;
    transition: transform 0.3s;
}

#toggleCustodioTexto.activo {
    background-color: #00a7e1;
    /* azul */
    color: white;
    border-color: #00a7e1;
}

.mensajeTransporte {
    display: inline-block;
    font-weight: 600;
    color: black;
    font-size: 14px;
    /* usa px en lugar de em */
    margin-top: 4px;
}


/* Contenedor principal de tasas */
.contenedor-tasa-incremento {
    display: flex !important;
    flex-wrap: wrap;
    gap: 20px;
}

/* Contenedor izquierdo - layout horizontal de tarjetas */
.contenedor-tasa-incremento1 .contenedor-interno.izquierdo {
    display: flex !important;
    flex-direction: row !important;
    flex: 1 1 100% !important;
    /* Ocupa todo el ancho disponible */
    gap: 10px;
    min-width: 280px;
    max-width: none !important;
    flex-wrap: nowrap !important;
    /* Mantener en una sola fila */
    /*overflow-x: auto;*/
    /* Scroll horizontal si es necesario */
}

/* Cada tarjeta de tasa dentro del contenedor izquierdo */
.contenedor-tasa-incremento1 .contenedor-interno.izquierdo>div {
    flex: 1 1 0 !important;
    /* Distribuir espacio equitativamente */
    min-width: 120px !important;
    max-width: none !important;
    padding: 12px;
    background: #f8f9fa;
    border-radius: 8px;
    border: 1px solid #e0e0e0;
    white-space: normal;
}

/* El último div (botón admin) debe estar separado */
.contenedor-tasa-incremento>div:last-child {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    min-width: 150px;
}

/* Responsive para móvil */
@media (max-width: 768px) {
    .contenedor-tasa-incremento {
        flex-direction: column !important;
    }

    .contenedor-tasa-incremento1 .contenedor-interno.izquierdo {
        flex-direction: column !important;
        flex: 1 1 100% !important;
        flex-wrap: wrap !important;
        overflow-x: visible !important;
    }

    .contenedor-tasa-incremento1 .contenedor-interno.izquierdo>div {
        min-width: 100% !important;
        max-width: 100% !important;
    }

    .contenedor-tasa-incremento1>div:last-child {
        justify-content: flex-start !important;
        width: 100%;
    }
}

/* ========================================== */
/* ESTILOS PARA MULTIPLICADORES - DIVS INTERNOS */
/* ========================================== */

/* Contenedor principal de multiplicadores */
.multiplicadores-grid.cliente-config {
    /*display: flex !important;*/
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding: 15px !important;
    background: #f9fafb !important;
    border-radius: 8px !important;
    border: 1px solid #e5e7eb !important;
    margin: 10px 0 !important;
    width: 100% !important;
}

/* Título del contenedor */
.multiplicadores-grid.cliente-config h2 {
    flex: 1 1 100% !important;
    margin: 0 0 8px 0 !important;
    padding: 0 0 6px 0 !important;
    color: #1f2937 !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    border-bottom: 2px solid #3b82f6 !important;
}

/* Cada div de multiplicador */
.multiplicadores-grid.cliente-config>div:not(:first-child) {
    /*display: flex !important;*/
    justify-content: space-between !important;
    align-items: center !important;
    padding: 8px 12px !important;
    background: white !important;
    border-radius: 4px !important;
    border-left: 3px solid #3b82f6 !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05) !important;
    flex: 0 1 calc(33.333% - 8px) !important;
    /*max-width: calc(33.333% - 8px) !important;*/
    width: 15% !important;
    min-width: 100px !important;
}

/* Estilos para el strong (etiqueta) */
.multiplicadores-grid.cliente-config strong {
    color: #374151 !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    flex: 1 !important;
}

/* Contenedor derecho (configuraciones) */
.contenedor-interno.derecho {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding: 15px !important;
    background: #f3f4f6 !important;
    border-radius: 8px !important;
    border: 1px solid #d1d5db !important;
    margin: 10px 0 !important;
    width: 100% !important;
}

.contenedor-interno.derecho>div {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 8px 12px !important;
    background: white !important;
    border-radius: 4px !important;
    border-left: 3px solid #10b981 !important;
    font-size: 13px !important;
    flex: 0 1 calc(33.333% - 8px) !important;
    max-width: calc(33.333% - 8px) !important;
    min-width: 200px !important;
}

.contenedor-interno.derecho strong {
    color: #374151 !important;
    font-weight: 600 !important;
}

#infoTasasContenidoObt {
    flex: 0 0 95%;
    display: flex;
    flex-wrap: wrap;
    gap: 50px;
}

/* Responsive para móviles */
@media (max-width: 768px) {

    .multiplicadores-grid.cliente-config,
    .contenedor-interno.derecho {
        padding: 12px !important;
        flex-direction: column !important;
    }

    .multiplicadores-grid.cliente-config>div:not(:first-child),
    .contenedor-interno.derecho>div {
        flex: 1 1 100% !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 3px !important;
        min-width: 100% !important;
    }

    .multiplicadores-grid.cliente-config h2 {
        font-size: 16px !important;
    }

    #infoTasasContenidoObt {
        flex-direction: column;
        gap: 5px;
        text-align: left;
    }

    .contenedor-tasa-incremento {
        display: flex;
        flex-direction: column;
        /* apila los div uno debajo del otro */
        align-items: flex-start;
        /* alinea los elementos a la izquierda */
    }

    .contenedor-tasa-incremento div {
        width: 100%;
        /* opcional: que cada div ocupe todo el ancho */
        border-bottom: 1px solid #ccc;
        /* raya debajo de cada elemento */
        padding: 0.5rem 0;
        /* espacio para que la raya se vea mejor */
    }

    /* Opcional: quitar la raya al último elemento */
    .contenedor-tasa-incremento div:last-child {
        border-bottom: none;
    }
}

.contenedor-tasa-incremento1 {
    display: none;
    /* oculto por defecto */
}

.contenedor-tasa-incremento1.abierto {
    display: block;
    /* se muestra al abrir */
}

.header-usuario {
    position: fixed;
    top: 0;
    right: 0;
    width: auto;
    padding: 10px 20px;
    background: #1f2937;
    color: #ffffff;
    font-family: 'Roboto', sans-serif;
    z-index: 10000;
    border-bottom-left-radius: 12px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
}

.header-usuario-nombre {
    font-size: 14px;
    font-weight: 600;
    text-align: right;
}

.header-usuario-rol {
    font-size: 12px;
    opacity: 0.8;
    text-align: right;
}

.contenedor-principal {
    margin-top: 60px;
}

.btn-desinstalar-app {
    background: #b91c1c;
    color: white;
    border: none;
    padding: 10px 16px;
    border-radius: 20px;
    font-size: 13px;
    cursor: pointer;
    margin-left: 8px;
}

.btn-desinstalar-app:hover {
    background: #991b1b;
}

.logout-link {
    display: inline-block;
    padding: 8px 16px;
    color: white;
    text-decoration: none;
    border: 1.5px solid #dc3545;
    border-radius: 6px;
    font-weight: 600;
    font-size: 0.9rem;
    white-space: nowrap;
    /* Evita que el texto se parta en dos líneas */
    transition: all 0.2s ease-in-out;

}

.logout-link:hover {
    background-color: #dc3545;
    color: #ffffff;
    box-shadow: 0 4px 6px rgba(220, 53, 69, 0.2);
}


.input-error {
    border: 1px solid red !important;
    background-color: #fff5f5;
}

.auth-flete-box-twilio {
    background-color: #f8f9fa;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    padding: 20px;
    max-width: 350px;
    margin: 20px auto;
    text-align: center;
}

.terminos-producto {
    width: 100%;
    min-width: 180px;
    /* 👈 ancho mínimo visible */
    max-width: 100%;

    min-height: 80px;
    max-height: 150px;

    resize: both;
    /* 👈 permite agrandar */

    padding: 8px;
    font-size: 14px;

    border: 1px solid #ccc;
    border-radius: 6px;

    overflow: auto;
}

/* 👇 Mejora del handle (visible en desktop) */
.terminos-producto::-webkit-resizer {
    background: #888;
    border-radius: 2px;
}

/* 👇 Mejora experiencia en mobile */
@media (max-width: 768px) {
    .terminos-producto {
        min-width: 100px;
        /* ocupa todo el ancho */
        font-size: 16px;
        /* evita zoom automático en iOS */
        resize: vertical;
        /* 👈 más usable en móvil */
    }
}

.textarea-wrapper {
    position: relative;
}

.textarea-wrapper::after {
    content: "⤡";
    position: absolute;
    right: 8px;
    bottom: 4px;
    font-size: 18px;
    color: #666;
    pointer-events: none;
}