@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

:root {
    --color-primero: #001A4D;
    --color-amarillo: #3cad1a;
    --color-segundo: #002D72;
    --color-tercero: #1e2d8b;
    --color-cabecera: #003399;
    --color-texto: #003399;

    /*nuevo*/
    --blanco: #ffff;
    --negro: #000;
    --fondo: #F5F5F5;
    --tamanio-texto: 16px;
    --tamanio-pequenio: 14px;
    --tamanio-grande: 20px;
    --tamanio-titulos: 25px;
}

/*GENERAL*/

body {
    font-family: 'Poppins';

}

form {
    background: var(--blanco);
    padding-top: 40px;
    width: 90%;
    margin: 0 auto;
    border-radius: 12px;
}

input.caja-texto,
select.caja-texto,
textarea.caja-texto {
    font-family: 'Poppins';
    width: 100%;
    padding: 10px 0;
    padding-left: 12px;
    font-size: var(--tamanio-texto);
    border: 1px solid #ccc;
    border-radius: 6px;
    background-color: var(--blanco);
    color: #333;
}

select.caja-multiple {
    font-family: 'Poppins';
    width: 100%;
    padding: 10px 14px;
    font-size: var(--tamanio-texto);
    border: 1px solid #ccc;
    border-radius: 6px;
    background-color: var(--blanco);
    color: #333;

}

input.caja-texto:focus,
select.caja-texto:focus,
textarea.caja-texto:focus,
.choices.is-focused .choices__inner {
    outline: 1px solid var(--color-primero) !important;
}



input[type="checkbox"] {
    margin-right: 10px;
    cursor: pointer;
    accent-color: var(--color-primero);
}

textarea {
    height: 69px !important;
    resize: none;
}



/*BOTON CON ICONO EDITAR*/
.btn-edit {
    width: 38px;
    height: 38px;
    min-width: 38px;
    /* 👈 evita que se encoja */
    min-height: 38px;
    /* 👈 evita que se encoja */
    flex-shrink: 0;
    /* 👈 NO permite que el botón se estreche */
    background: var(--color-texto);
    border-radius: 50%;
    border: none;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    color: var(--blanco);
    font-size: 15px;
    transition: 0.2s ease;
    text-decoration: none;
    margin-right: 20px;
}

.btn-edit:hover {
    background: var(--color-primero);
}

.btn-edit i {
    pointer-events: none;
}



/* ====== ESTILOS PARA CHOICES.JS ====== */

/* La caja visible que reemplaza al select */
.choices__inner {
    background-color: var(--blanco) !important;
    border-radius: 5px !important;
    font-size: var(--tamanio-texto) !important;
    padding: 0px !important;
    height: 0px !important;
    display: flex !important;
    align-items: center !important;
    border: 1px solid #ccc !important;
    color: #333 !important;
    width: auto !important;
}

.choices__list--single {
    padding-left: 16px !important;
}

/*
/* El contenedor principal de Choices */
.choices {
    width: 100%;
    /* para que ocupe igual que el input original */
}

/****/


.boton-primero {
    font-family: 'Poppins';
    background-color: var(--color-primero);
    color: var(--blanco);
    width: 100%;
    height: 80px;
    font-size: var(--tamanio-grande);
    border-radius: 0 0 10px 10px;
    cursor: pointer;
    border: 0;
}

.boton-segundo {
    padding: 10px 20px;
    font-size: var(--tamanio-texto);
    border-radius: 8px;
    font-family: 'Poppins';
    text-align: center;
    border: 0;
    cursor: pointer;
    background: var(--blanco);
    color: var(--color-segundo);
    border: 1.5px solid var(--color-segundo);
}

.boton-tercero {
    padding: 10px 20px;
    font-size: var(--tamanio-texto);
    border-radius: 8px;
    font-family: 'Poppins';
    text-align: center;
    border: 0;
    cursor: pointer;
    background: var(--color-tercero);
    color: var(--blanco);
}

.boton-primero:hover {
    background-color: #050585;
}

.boton-segundo:hover {
    background-color: #cdcdcd;
}

.boton-tercero:hover {
    background-color: #cdcdcd;
}

.datos-cliente span,
.datos-obra span,
.tipo-obra span,
.form-ventana .obra-ventana span,
.form-ventana .vivienda-ventana span {
    color: red;
}

/*TABLA CLIENTES, OBRAS, VENTANAS*/
.listado-general {
    align-items: center;
    width: 90%;
    margin: 0 auto 100px auto;
}

.cajas {
    display: flex;
    flex-direction: column;
    gap: 30px;
    margin-top: 38px;
}

.card {
    display: flex;
    background-color: var(--blanco);
    justify-content: space-between;
    padding: 20px 0;
    border-radius: 12px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
    transition: transform 0.5s ease, box-shadow 0.5s ease;

}

.card:hover {
    transform: scale(1.04);
}

.card .card-datos .tipo-obra p {
    background-color: #E7F5EC;
    color: #059669;
    font-weight: 500;
    font-size: 14px;
}

.card .card-datos .tipo-obra {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #E7F5EC;
    border-radius: 15px;
    text-align: center;
    height: 3vh;
    width: 67px;

}

.card .card-datos .tipo-particular {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #DDEBFF;
    border-radius: 15px;
    text-align: center;
    height: 3vh;
    width: 120px;
}

.card .card-datos .tipo-particular p {
    font-size: var(--tamanio-pequenio);
    color: #2563EB;
    font-weight: 500;
}


.card .card-datos {
    margin: 0 30px;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.card .card-datos span {
    font-size: 13px;
    color: #686868;
    font-weight: 500;
}

.card img {
    width: 30px;
}

.card .card-datos .numero-tel {
    margin-right: 10px;
}

.card .card-datos .telefono {
    font-size: 14px;
    text-align: left;
}

.card .card-datos .nombre {
    text-decoration: none;
    color: var(--color-texto);
    text-align: left;
    word-break: break-word;
    overflow-wrap: anywhere;
}

.buscador input {
    padding-left: 0 !important;
    margin-top: 20px;
}

/*LISTADO OBRA*/

.card-datos .datos-portal {
    font-size: 13px;
    color: #818181;
    text-align: left;
}

.card-datos .datos-portal span {
    color: #686868;
    font-weight: 600;
}

/**/


/* Media query para desktop */
@media (min-width: 1024px) {

    .datos-cliente,
    .datos-obra,
    .form-ventana .datos-ventana {
        grid-template-columns: 1fr 1fr !important;
        column-gap: 100px;

    }

    .viviendas-obras {
        grid-template-columns: 1fr 100px;
        padding: 40px 50px;
    }

    .vivienda-principal {
        align-items: center;
    }

    .form-ventana .datos-ventana {
        padding: 20px 50px;

    }

    form {
        width: 70%;
    }

    .listado-general {
        width: 65%;
    }

    .persiana {
        grid-template-columns: 1fr 1fr;
        padding: 30px 40px;
        padding-bottom: 80px;
    }

    .cabecera-app-listados-interno {
        width: 65%;
    }

    .cabecera-app-opciones-interno {
        width: 65%;
    }

    /*obras */
    div#contenedorAcordeones {
        width: 80% !important;
    }

    .form-obra-principal {
        width: auto;
    }

    .fila-vivienda {
        grid-template-columns: 70px 1fr 80px auto;
    }

    .encabezado-viviendas span {
        text-align: center;
    }

    /*administracion*/
    .menu-principal,.menu-principal-administracion {
        padding: 0 134px;
    }

    /* .menu-principal {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 35px;
        padding: 0 20px;
    } */
}

/* ===== LOADER GLOBAL ===== */

#loader {
    align-items: center;
    /* 👈 centrado vertical */
    padding-top: 0;
    /* 👈 elimina empuje */
}


/* Contenedor del loader */
.loader-container {
    width: 100%;
    text-align: center;
    padding-top: 150px;
    /* 👈 baja un poco el loader */

}

/* Imagen del GIF */
.loader-container img {
    width: 100px;
    height: auto;
    margin-bottom: 10px;
}

/* Texto debajo del GIF */
.loader-container p {
    font-weight: 500;
    margin: 0;
}