/*
 * Style.css
 * Este archivo contiene los estilos personalizados para tu aplicación Impactus_Web.
 * Se carga después de Bootstrap y site.css para aplicar las personalizaciones.
 */

/* ==========================================================================
   Estilos Generales y del Contenedor Principal
   ========================================================================== */

body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background-color: #87bfe8; /* Fondo azul de la página */
}

/* ==========================================================================
   Estilos del Formulario de Proveedores
   ========================================================================== */

/* Contenedor principal de la tarjeta del formulario */
.mi-form-proveedores-recuadro {
    background-color: #e3bc32; /* Color amarillo de la tarjeta */
    padding: 15px; /* Espaciado interno */
    border-radius: 8px; /* Bordes redondeados */
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.2); /* Sombra para efecto 3D */
    border: none;
    margin-top: -40px; /* ¡AQUÍ ESTÁ EL CAMBIO! La tarjeta sube -30px. Ajusta si necesitas más o menos. */
    margin-bottom: 20px;
}

/* Estilo para el título principal del formulario (PROVEEDORES) */
.titulo-formulario-proveedores {
    font-size: 3.0rem; /* ¡MÁS GRANDE! Ajusta este valor si quieres un tamaño diferente. */
    font-weight: bold;
    color: #333;
    text-align: center; /* Centrar el título */
    padding-bottom: 10px;
    margin-bottom: 5px;

    /* ¡EFECTO 3D MÁS PRONUNCIADO! */
    
    text-shadow:
        2px 2px 0px rgba(0,0,0,0.2),  /* Sombra base */
        4px 4px 0px rgba(0,0,0,0.15), /* Sombra intermedia */
        6px 6px 0px rgba(0,0,0,0.1);  /* Sombra más lejana */
        
}

/* Fila de controles en la cabecera (RUC/Buscar y Registro N°/ID) */
.form-header-controls {
    /* Utiliza los márgenes negativos para compensar el padding del .card-body y alinear */
    margin-left: -15px; /* Compensa el padding-left del card-body */
    margin-right: -15px; /* Compensa el padding-right del card-body */
    margin-top: 0px; /* Asegura que esta fila no se desplace hacia arriba más de lo necesario */
    padding: 0 15px; /* Añade un padding interno para alinear los contenidos con el resto del card */
    display: flex; /* Asegura que las columnas internas se comporten como flex */
    align-items: center; /* Alinea los elementos verticalmente */
}

/* Columna que contiene el RUC y el botón Buscar */
.ruc-search-column {
    /* Elimina el padding predeterminado de col-md-auto para un control preciso */
    padding-left: 0;
    padding-right: 0;
    flex-grow: 0; /* No crece */
    flex-shrink: 0;
}

/* Contenedor del campo RUC y el botón Buscar */
.form-group.d-flex.align-items-end {
    margin-bottom: 0 !important; /* Elimina el margen inferior si no es necesario */
}

/* Campo RUC */
.ruc-input-custom {
    width: 150px; /* Ancho ajustado para 12-15 caracteres */
    flex-shrink: 0;
    margin-right: 30px; /* Espacio ampliado entre RUC y el botón Buscar */
}


.ruc-group {
    margin-top: 50px; /* Ajusta este valor en píxeles según necesites */
}
/* Botón Buscar */
.btn-search-ruc {
    flex-shrink: 0;
}

/* Contenedor para "Registro N°:" y el ID */
.id-display-group {
    /* Utiliza flexbox para alinear la etiqueta y el ID */
    display: flex;
    align-items: center;
    /* Ajusta el margen superior si necesitas que suba un poco y no choque con la línea RUC/Buscar */
    margin-top: 0px; /* Podría necesitar ajuste si quieres que suba más */
}

/* Estilo para la etiqueta "Registro N°:" */
.custom-label-registro {
    font-weight: bold;
    color: white; /* Texto en color blanco */
    font-size: 1.0em; /* ¡CAMBIO AQUÍ! Reducido a 1.0em (tamaño estándar) */
    white-space: nowrap; /* Evita que el texto se rompa */
    margin-right: 5px; /* Espacio entre la etiqueta y el número */
}

/* Estilo para el display del ID de la base de datos */
#ProveedorIdDisplay {
    font-weight: bold;
    color: white; /* Texto en color blanco */
    font-size: 1.2em; /* ¡CAMBIO AQUÍ! Reducido a 1.2em */
    white-space: nowrap; /* Evita que el texto se rompa */
}


/* Estilos para los campos de formulario (input, select, textarea) */
.form-control {
    border-radius: 5px;
    border: 1px solid #ccc;
    padding: 8px 10px;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.075);
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.form-control:focus {
    border-color: #80bdff;
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(0, 123, 255, 0.25);
}

/* Ajuste de márgenes para los grupos de formulario para ahorrar espacio vertical */
.form-group.mb-3 {
    margin-bottom: 0.75rem !important; /* Aproximadamente 12px de margen inferior */
}

/* Estilo específico para el campo Rubro para limitar su ancho a 50 caracteres */
#RubroFKInput {
    max-width: 400px; /* Un valor en píxeles que debería acomodar unos 50 caracteres, puedes ajustar */
    width: 100%; /* Asegura que no se desborde en pantallas pequeñas */
}

/* Estilo para los botones principales (Crear, Guardar Modificación, Eliminar, Cancelar/Nuevo) */
.btn {
    padding: 8px 15px; /* Espaciado interno de los botones */
    border-radius: 5px; /* Bordes redondeados */
    font-weight: 500;
    transition: background-color 0.2s ease, transform 0.1s ease; /* Transición suave al hover */
}

.btn:hover {
    transform: translateY(-1px); /* Ligero efecto de levantamiento al pasar el ratón */
}

/* Margen superior para el grupo de botones del formulario */
.form-group.mt-4 {
    margin-top: 1rem !important; /* Un poco más de margen para separar los botones de los campos */
    text-align: right; /* Alinea los botones a la derecha */
}

/* Estilo para los mensajes de estado (RUC encontrado/no encontrado) */
small#rucStatus {
    font-size: 0.85em;
    margin-top: 5px;
    min-height: 25px; /* Aumentado a 25px: Reserva de espacio para el mensaje y evitar saltos */
    display: block; /* Para que ocupe su propia línea */
}

/* Estilos para las etiquetas (labels) de campos individuales (los que no son Registro N°) */
label:not(.custom-label-registro) { /* Excluimos la etiqueta de registro */
    font-weight: 600;
    color: #444;
    font-size: 0.85em; /* REDUCCIÓN DE TAMAÑO: Hace la fuente un poco más pequeña */
    margin-bottom: 3px; /* REDUCCIÓN DE ESPACIO: Reduce el espacio debajo de la etiqueta */
    display: block; /* Asegura que cada label ocupe su propia línea si es necesario */
}

/* Estilos para los mensajes de validación */
.text-danger {
    font-size: 0.85em;
    margin-top: 3px;
    min-height: 20px; /* RESERVA DE ESPACIO para los mensajes de validación */
    display: block;
}

/* Nuevas reglas para ocultar mensajes de validación vacíos sin colapsar el espacio */
.validation-message-hidden:empty,
.validation-summary-hidden:empty {
    visibility: hidden; /* Mantiene el espacio, pero lo hace invisible */
}

/* ==========================================================================
   Estilos de Encabezado y Pie de página
   ========================================================================== */

.navbar {
    box-shadow: 0 2px 4px rgba(0,0,0,0.05); /* Sombra ligera para el navbar */
}

footer.border-top {
    padding-top: 1rem;
    padding-bottom: 1rem;
    background-color: #e9ecef; /* Un color de fondo suave para el pie de página */
}

/* Estilos para el contenedor de la grilla de búsqueda */

/* Estilos para el contenedor de la grilla de búsqueda */
#contenedorGrillaBusqueda {
    position: absolute; /* Cambia a absolute o fixed según necesites */
    top: 30%; /* Ajusta la posición vertical - puedes probar diferentes valores */
    left: 50%; /* Ajusta la posición horizontal */
    transform: translate(-50%, -30%); /* Centra la grilla (ajusta el segundo valor si modificaste el top) */
    background-color: white;
    border: 1px solid #ccc;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    padding: 15px;
    width: 60%; /* Ejemplo: Reduce el ancho a 60% */
    max-height: 300px; /* Ejemplo: Reduce la altura máxima */
    overflow-y: auto;
    z-index: 1000; /* Asegura que esté por encima de otros elementos */
}

#contenedorGrillaBusqueda h3 {
    margin-top: 0;
    margin-bottom: 10px;
    font-size: 1.5em;
}

/* Estilos para la tabla */
#contenedorGrillaBusqueda table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 10px;
    font-size: 0.9em; /* Reduce la fuente al 90% */
}

#contenedorGrillaBusqueda th, #contenedorGrillaBusqueda td {
    border: 1px solid #ddd;
    padding: 8px;
    text-align: left;
}

#contenedorGrillaBusqueda th {
    background-color: #f2f2f2;
    font-weight: bold;
}

#contenedorGrillaBusqueda tr:nth-child(even) {
    background-color: #f9f9f9;
}

/* Estilo para la fila seleccionada */
.fila-seleccionada {
    background-color: #d1e7dd !important; /* Verde claro al seleccionar */
}

/* Estilo para el botón Seleccionar */
#contenedorGrillaBusqueda .btnSeleccionarFila {
    padding: 5px 10px;
    border: 1px solid #ccc;
    border-radius: 4px;
    background-color: #f8f9fa;
    cursor: pointer;
    font-size: 0.9em;
}

#contenedorGrillaBusqueda .btnSeleccionarFila:hover {
    background-color: #e2e6ea;
}

/* Estilo para el botón Cancelar */
#contenedorGrillaBusqueda #cancelarBusquedaBtn {
    margin-right: 5px;
    margin-top: 10px;
    padding: 8px 15px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.95em;
    background-color: #6c757d;
    color: white;
    border: 1px solid #6c757d;
}

#contenedorGrillaBusqueda #cancelarBusquedaBtn:hover {
    background-color: #545b62;
}

#contenedorGrillaBusqueda .btnSeleccionarFila {
    padding: 5px 10px;
    border: 1px solid #28a745; /* Un borde verde */
    border-radius: 4px;
    background-color: #28a745; /* Fondo verde */
    color: white; /* Texto blanco para mejor contraste */
    cursor: pointer;
    font-size: 0.9em;
}

#contenedorGrillaBusqueda .btnSeleccionarFila:hover {
    background-color: #218838; /* Un verde más oscuro al pasar el ratón */
    border-color: #1e7e34;
}


.mi-form-clientes-recuadro {
    /* ... otros estilos que ya tengas ... */
    background-color: #F0F0F0; /* Gris claro */
    
    padding-bottom: 20px; /* Agrega un espacio de 20 píxeles en la parte inferior - puedes ajustar este valor */
}

.mi-form-clientes-recuadro .form-group.mb-3 {
    margin-bottom: 0.4rem !important; /* Aproximadamente 8px de margen inferior - puedes ajustar este valor */
}
.titulo-formulario-clientes {
    font-size: 3.0rem;
    font-weight: bold;
    color: #333;
    text-align: center;
    padding-bottom: 10px;
    margin-bottom: 5px;
    text-shadow:
        2px 2px 0px rgba(0,0,0,0.2),
        4px 4px 0px rgba(0,0,0,0.15),
        6px 6px 0px rgba(0,0,0,0.1);
}