/* _content/ValanPlataform.BlazorServerHome/Pages/Asistencias/ConfiguracionAsignaciones.razor.rz.scp.css */
/* CSS para configuracion-asignaciones.razor.css */

/* Estilos de consistencia (Contenedor y Cabecera) */
.page-container[b-q1wxu2cchy] {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1.5rem 2rem;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

.header-info[b-q1wxu2cchy] {
    text-align: center;
    margin-bottom: 2rem;
}

    .header-info h3[b-q1wxu2cchy] {
        font-weight: 600;
    }

    .header-info p[b-q1wxu2cchy] {
        color: #6c757d;
        margin-top: 0.5rem;
    }

.card-table-container[b-q1wxu2cchy] {
    background-color: #fff;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    overflow: hidden;
}

.table-header[b-q1wxu2cchy] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid #dee2e6;
}

.table-title[b-q1wxu2cchy] {
    font-weight: 600;
    font-size: 1.1rem;
}

.editor-actions[b-q1wxu2cchy] {
    margin-bottom: 1.5rem;
    display: flex;
    justify-content: flex-end;
}

/* Formulario principal del editor */
.editor-form[b-q1wxu2cchy] {
    max-width: 900px;
    margin: auto;
    background-color: #fff;
    padding: 2rem 2.5rem;
    border-radius: 12px;
    border: 1px solid #e9ecef;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}

.form-section[b-q1wxu2cchy] {
    margin-bottom: 2.5rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid #f1f1f1;
}

    .form-section:last-of-type[b-q1wxu2cchy] {
        border-bottom: none;
        padding-bottom: 0;
    }

    .form-section h4[b-q1wxu2cchy] {
        margin-bottom: 1.5rem;
        font-weight: 500;
        color: #343a40;
    }


/* --- INICIO: ESTILOS PARA LA DOBLE LISTA --- */
.dual-list-container[b-q1wxu2cchy] {
    display: grid;
    grid-template-columns: 1fr auto 1fr; /* Columna, botones, columna */
    gap: 1rem;
    align-items: center;
}

.list-box label[b-q1wxu2cchy] {
    display: block;
    font-weight: 600;
    margin-bottom: 0.5rem;
    text-align: center;
}

.worksite-list[b-q1wxu2cchy] {
    list-style: none;
    padding: 0;
    margin: 0;
    height: 250px;
    border: 1px solid #ccc;
    border-radius: 8px;
    overflow-y: auto; /* Scroll si la lista es muy larga */
}

    .worksite-list li[b-q1wxu2cchy] {
        padding: 0.6rem 1rem;
        cursor: pointer;
        border-bottom: 1px solid #eee;
    }

        .worksite-list li:last-child[b-q1wxu2cchy] {
            border-bottom: none;
        }

        .worksite-list li:hover[b-q1wxu2cchy] {
            background-color: #f8f9fa;
        }

        .worksite-list li.selected[b-q1wxu2cchy] {
            background-color: #007bff;
            color: white;
            font-weight: 500;
        }

.list-actions[b-q1wxu2cchy] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
/* _content/ValanPlataform.BlazorServerHome/Pages/Asistencias/ConfiguracionHorarios.razor.rz.scp.css */

/* --- INICIO: Estilos --- */
.page-container[b-a3fwhn5svj] {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1.5rem 2rem;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

.header-info[b-a3fwhn5svj] {
    text-align: center;
    margin-bottom: 2rem;
}

    .header-info h3[b-a3fwhn5svj] {
        font-weight: 600;
        color: #343a40;
    }

    .header-info p[b-a3fwhn5svj] {
        color: #6c757d;
        margin-top: 0.5rem;
    }

.card-table-container[b-a3fwhn5svj] {
    background-color: #fff;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    overflow: hidden; /* Para que la tabla respete los bordes redondeados */
}

.table-header[b-a3fwhn5svj] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid #dee2e6;
}

.table-title[b-a3fwhn5svj] {
    font-weight: 600;
    font-size: 1.1rem;
}

.editor-actions[b-a3fwhn5svj] {
    margin-bottom: 2rem;
    display: flex;
    justify-content: flex-end; /* Alinea el botón de volver a la derecha */
}

.template-details-form[b-a3fwhn5svj] {
    background-color: #f8f9fa;
    padding: 1.5rem;
    border-radius: 8px;
    border: 1px solid #e9ecef;
    margin-bottom: 2rem;
}

.cards-grid[b-a3fwhn5svj] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.5rem;
}

.day-card[b-a3fwhn5svj] {
    border: 1px solid #dee2e6;
    border-radius: 8px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
    display: flex;
    flex-direction: column;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    background-color: #fff;
}

    .day-card:hover[b-a3fwhn5svj] {
        transform: translateY(-5px);
        box-shadow: 0 4px 15px rgba(0,0,0,0.1);
    }

.card-header[b-a3fwhn5svj] {
    background-color: #f8f9fa;
    padding: 0.75rem 1.25rem;
    font-weight: 600;
    border-bottom: 1px solid #dee2e6;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    text-align: center;
}

.card-body[b-a3fwhn5svj] {
    padding: 1.25rem;
    flex-grow: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 100px;
}

.schedule-summary .schedule-time[b-a3fwhn5svj] {
    font-size: 1.5rem;
    font-weight: 500;
    color: #343a40;
}

.schedule-summary .schedule-details[b-a3fwhn5svj] {
    font-size: 0.9rem;
    color: #6c757d;
}

.not-configured-text[b-a3fwhn5svj], .day-off-text[b-a3fwhn5svj] {
    font-style: italic;
    color: #6c757d;
}

.day-card.is-day-off[b-a3fwhn5svj] {
    background-color: #f8f9fa;
    color: #6c757d;
}

    .day-card.is-day-off .card-header[b-a3fwhn5svj] {
        background-color: #e9ecef;
    }

.card-footer[b-a3fwhn5svj] {
    padding: 0.75rem 1.25rem;
    background-color: #f8f9fa;
    border-top: 1px solid #e9ecef;
    text-align: center;
    font-size: 0.8rem;
    color: #007bff;
    font-weight: 500;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.2s ease;
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
}

.day-card:hover .card-footer[b-a3fwhn5svj] {
    visibility: visible;
    opacity: 1;
}

.loading-indicator[b-a3fwhn5svj] {
    padding: 2rem;
    text-align: center;
    font-style: italic;
    color: #6c757d;
}

/* Estilos del Modal */
.modal-backdrop[b-a3fwhn5svj] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.6); /* Un poco más oscuro */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1050;
    padding: 1rem; /* Añade un poco de espacio para pantallas muy pequeñas */
}

.modal-content[b-a3fwhn5svj] {
    background: white;
    border-radius: 8px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
    width: 100%;
    max-width: 600px; /* Un poco más de ancho para los nuevos campos */
    display: flex;
    flex-direction: column;
    max-height: 90vh; /* El modal nunca será más alto que el 90% de la pantalla */
}

.modal-header[b-a3fwhn5svj] {
    padding: 1.5rem; /* Más espaciado */
    border-bottom: 1px solid #e9ecef;
}

.close-button[b-a3fwhn5svj] {
    border: none;
    background: transparent;
    font-size: 1.5rem;
    cursor: pointer;
}

.modal-body[b-a3fwhn5svj] {
    padding: 1.5rem;
    overflow-y: auto; /* Si el contenido es más alto, APLICA SCROLL AQUÍ */
}

    .modal-body .form-group[b-a3fwhn5svj] {
        margin-bottom: 1rem;
    }

    .modal-body h6[b-a3fwhn5svj] { /* Estilo para los nuevos subtítulos */
        font-weight: 600;
        margin-top: 1rem;
        margin-bottom: 1rem;
        color: #007bff;
    }

    .modal-body .form-row[b-a3fwhn5svj] { /* Para agrupar inputs de a dos */
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
    }


.modal-footer[b-a3fwhn5svj] {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
    padding: 1.5rem;
    border-top: 1px solid #e9ecef;
}
/* _content/ValanPlataform.BlazorServerHome/Pages/Asistencias/ConfiguracionPuntosTrabajo.razor.rz.scp.css */
/* CSS Unificado y Corregido para configuracion-puntos-trabajo.razor.css */

/* --- INICIO: Estilos de Layout y Consistencia --- */
.page-container[b-9uw5j5hyn8] {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1.5rem 2rem;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

.header-info[b-9uw5j5hyn8] {
    text-align: center;
    margin-bottom: 2rem;
}

    .header-info h3[b-9uw5j5hyn8] {
        font-weight: 600;
    }

    .header-info p[b-9uw5j5hyn8] {
        color: #6c757d;
        margin-top: 0.5rem;
    }

.card-table-container[b-9uw5j5hyn8] {
    background-color: #fff;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    overflow: hidden;
}

.table-header[b-9uw5j5hyn8] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid #dee2e6;
}

.table-title[b-9uw5j5hyn8] {
    font-weight: 600;
    font-size: 1.1rem;
}

.editor-actions[b-9uw5j5hyn8] {
    margin-bottom: 2rem;
    display: flex;
    justify-content: flex-end;
}
/* --- FIN: Estilos de Layout --- */


/* --- TUS ESTILOS EXISTENTES PARA EL EDITOR Y EL MAPA (ligeramente ajustados) --- */
.editor-layout[b-9uw5j5hyn8] {
    display: grid;
    grid-template-columns: 1fr 1.2fr; /* Damos un poco más de espacio al mapa */
    gap: 2.5rem;
}

.editor-form[b-9uw5j5hyn8] {
    background-color: #fff;
    border: 1px solid #e9ecef;
    border-radius: 8px;
    padding: 2rem;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}

.map-instructions[b-9uw5j5hyn8] {
    font-size: 0.9em;
    font-style: italic;
    color: #6c757d;
    text-align: center;
    margin-bottom: 0.75rem;
}

.loading-indicator[b-9uw5j5hyn8] {
    padding: 2rem;
    text-align: center;
    font-style: italic;
    color: #6c757d;
}

.editor-map[b-9uw5j5hyn8] {
    display: flex;
    flex-direction: column;
    height: 100%;
}

#config-map[b-9uw5j5hyn8] {
    flex-grow: 1;
    min-height: 500px;
    border-radius: 8px;
    border: 1px solid #dee2e6;
}


/* Media query para apilar las columnas en pantallas pequeñas */
@media (max-width: 992px) {
    .editor-layout[b-9uw5j5hyn8] {
        grid-template-columns: 1fr;
    }

    .editor-map[b-9uw5j5hyn8] {
        height: 400px; /* Altura fija para el mapa en móvil */
        margin-top: 2rem;
    }
}

/* Ajustes adicionales para móviles para evitar desbordamientos */
@media (max-width: 768px) {
    .page-container[b-9uw5j5hyn8] {
        /* Reducimos el padding lateral para darle más espacio al contenido */
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .editor-layout[b-9uw5j5hyn8] {
        /* En móvil, quitamos el espacio grande entre el formulario y el mapa */
        gap: 1.5rem;
    }

    .editor-form[b-9uw5j5hyn8] {
        /* Menos padding dentro del formulario en móvil */
        padding: 1.5rem;
    }

    .editor-map[b-9uw5j5hyn8] {
        height: 400px; /* Esta regla ya la tienes */
        margin-top: 1.5rem;
    }

    /* --- AÑADIR ESTA NUEVA REGLA AQUÍ DENTRO --- */
    #config-map[b-9uw5j5hyn8] {
        /* Le decimos al mapa que ocupe el 100% de la altura de su padre (400px) */
        height: 100%;
        /* Reseteamos la altura mínima de escritorio para que no entre en conflicto */
        min-height: auto;
    }
}
/* _content/ValanPlataform.BlazorServerHome/Pages/Asistencias/DiasDeCampo.razor.rz.scp.css */
/* En DiasDeCampo.razor.css */
.page-container[b-v2zsd96b0w] {
    max-width: 1400px;
    margin: 0 auto;
    padding: 1.5rem;
}

.header-info[b-v2zsd96b0w] {
    text-align: center;
    margin-bottom: 2rem;
}

    .header-info h3[b-v2zsd96b0w] {
        font-weight: 600;
    }

    .header-info p[b-v2zsd96b0w] {
        color: #6c757d;
    }

.page-actions[b-v2zsd96b0w] {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 2rem;
}

.logs-grid[b-v2zsd96b0w] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 1.5rem;
}

.log-card[b-v2zsd96b0w] {
    background-color: #fff;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.07);
    display: flex;
    flex-direction: column;
    cursor: pointer;
    transition: all 0.2s ease-in-out;
}

    .log-card:hover[b-v2zsd96b0w] {
        transform: translateY(-5px);
        box-shadow: 0 8px 20px rgba(0,0,0,0.1);
    }

.card-date-banner[b-v2zsd96b0w] {
    background-color: #343a40;
    color: #fff;
    font-weight: 600;
    padding: 0.75rem 1.25rem;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
}

.card-content[b-v2zsd96b0w] {
    padding: 1.25rem;
    flex-grow: 1;
}

.card-supervisor[b-v2zsd96b0w] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
    color: #6c757d;
    margin-bottom: 1rem;
}

    .card-supervisor i[b-v2zsd96b0w] {
        color: #007bff;
    }

.card-description[b-v2zsd96b0w] {
    font-size: 0.95rem;
    color: #495057;
    /* Limita el texto a 3 líneas y añade "..." */
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.card-footer[b-v2zsd96b0w] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1.25rem;
    background-color: #f8f9fa;
    border-top: 1px solid #dee2e6;
    font-size: 0.85rem;
    font-weight: 500;
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
}

    .card-footer span[b-v2zsd96b0w] {
        display: flex;
        align-items: center;
        gap: 0.5rem;
    }
/* _content/ValanPlataform.BlazorServerHome/Pages/Asistencias/EditarDiasDeCampo.razor.rz.scp.css */
/* En EditarDiasDeCampo.razor.css */
.page-container[b-9q4sk4qf2w] {
    max-width: 900px; /* Un ancho más contenido para un formulario */
    margin: 0 auto;
    padding: 1.5rem;
}

.header-info[b-9q4sk4qf2w] {
    text-align: center;
    margin-bottom: 2rem;
}

    .header-info h3[b-9q4sk4qf2w] {
        font-weight: 600;
    }

    .header-info p[b-9q4sk4qf2w] {
        color: #6c757d;
        max-width: 600px;
        margin: 0.5rem auto 0 auto;
    }

.editor-actions[b-9q4sk4qf2w] {
    display: flex;
    margin-bottom: 1.5rem;
}

/* Estilo principal para cada tarjeta del formulario */
.editor-form-card[b-9q4sk4qf2w] {
    background: #fff;
    padding: 2rem;
    border-radius: 12px;
    border: 1px solid #e9ecef;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
    margin-bottom: 2rem; /* Espacio entre tarjetas */
}

    .editor-form-card h4[b-9q4sk4qf2w] {
        font-weight: 600;
        margin-bottom: 1.5rem;
        display: flex;
        align-items: center;
        gap: 0.75rem;
        color: #343a40;
    }

/* Layout para los campos de "Datos Generales" */
.form-grid[b-9q4sk4qf2w] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}

.form-group.full-width[b-9q4sk4qf2w] {
    grid-column: 1 / -1; /* Ocupa todo el ancho */
}

/* Layout para el formulario de "Añadir Personal" */
.add-personnel-form[b-9q4sk4qf2w] {
    display: flex;
    gap: 1rem;
    align-items: flex-end;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid #f1f1f1;
}

    .add-personnel-form .form-group[b-9q4sk4qf2w] {
        flex-grow: 1;
        margin-bottom: 0;
    }

    .add-personnel-form .btn[b-9q4sk4qf2w] {
        height: 38px;
    }

/* Estilos para la tabla de la cuadrilla */
.crew-table[b-9q4sk4qf2w] {
    font-size: 0.9rem;
}

    .crew-table th[b-9q4sk4qf2w], .crew-table td[b-9q4sk4qf2w] {
        vertical-align: middle;
        text-align: center;
    }

        .crew-table th:first-child[b-9q4sk4qf2w], .crew-table td:first-child[b-9q4sk4qf2w] {
            text-align: left;
        }

    .crew-table input[b-9q4sk4qf2w] {
        max-width: 85px;
        text-align: right;
        padding: 0.25rem 0.5rem;
    }

.footer-actions[b-9q4sk4qf2w] {
    margin-top: 2rem;
    display: flex;
    justify-content: flex-end;
}

/* Responsividad */
@media (max-width: 768px) {
    .form-grid[b-9q4sk4qf2w] {
        grid-template-columns: 1fr;
    }
}

.file-preview-grid[b-9q4sk4qf2w] {
    display: flex;
    flex-direction: column; /* Apilamos los archivos verticalmente */
    gap: 0.5rem;
    margin-top: 1rem;
}

.file-preview-item[b-9q4sk4qf2w] {
    display: flex; /* <-- La clave 1: convierte el item en un contenedor flexible */
    align-items: center; /* <-- La clave 2: alinea verticalmente el nombre y el botón */
    gap: 0.75rem;
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    padding: 0.5rem 0.75rem;
    border-radius: 6px;
}

    .file-preview-item img[b-9q4sk4qf2w] {
        width: 100%;
        height: 120px;
        object-fit: cover;
        border-radius: 8px;
        border: 1px solid #ddd;
    }

    .file-preview-item .btn-danger[b-9q4sk4qf2w] {
        flex-shrink: 0; /* Evita que el botón se encoja o se mueva */
    }

    .file-preview-item .file-icon[b-9q4sk4qf2w] {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        flex-grow: 1; /* Permite que esta sección ocupe todo el espacio disponible */
        min-width: 0; /* Un truco de flexbox para permitir que el texto de adentro se trunque */
    }

        .file-preview-item .file-icon i[b-9q4sk4qf2w] {
            color: #6c757d;
        }

        .file-preview-item .file-icon span[b-9q4sk4qf2w] {
            /* Lógica para truncar el texto si es muy largo con "..." */
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            font-size: 0.9rem;
        }
/* _content/ValanPlataform.BlazorServerHome/Pages/Asistencias/HrReport.razor.rz.scp.css */
/* CSS Final para HrReport.razor */
.page-container[b-uao6cnudbn] {
    max-width: 95%;
    margin: 0 auto;
    padding: 1.5rem;
}

.header-info[b-uao6cnudbn] {
    text-align: center;
    margin-bottom: 2rem;
}

    .header-info h3[b-uao6cnudbn] {
        font-weight: 600;
    }

    .header-info p[b-uao6cnudbn] {
        color: #6c757d;
    }

.filter-card[b-uao6cnudbn] {
    display: flex;
    flex-direction: column; /* Apila las filas verticalmente */
    gap: 1.5rem; /* Espacio entre la fila de arriba y la de abajo */
    padding: 1.5rem;
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    margin-bottom: 2rem;
}

.filter-row[b-uao6cnudbn] {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 1rem;
    width: 100%;
}

    .filter-row .btn-primary[b-uao6cnudbn] {
        margin-left: auto;
        margin-bottom: 5px;
    }

.options-row[b-uao6cnudbn] {
    border-top: 1px solid #e9ecef;
    padding-top: 1.5rem;
}

/* Contenedor para el botón y el menú desplegable */
.metrics-dropdown-container[b-uao6cnudbn] {
    position: relative;
}

/* El menú desplegable con los checkboxes */
.dropdown-menu-metrics[b-uao6cnudbn] {
    position: absolute;
    top: calc(100% + 5px); /* Justo debajo del botón + 5px de espacio */
    left: 0;
    z-index: 1050; /* Un z-index alto para que aparezca por encima de la tabla y otros elementos */
    width: 300px; /* Ancho del menú desplegable */
    background-color: #fff;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.15);
    padding: 0.75rem;
    max-height: 400px; /* Altura máxima antes de que aparezca el scroll */
    overflow-y: auto; /* Muestra el scroll vertical SÓLO si es necesario */
    /* Pequeña animación para que aparezca suavemente */
    animation: fadeIn-b-uao6cnudbn 0.2s ease-out;
}

/* Estilo para cada fila de checkbox */
.dropdown-menu-metrics label[b-uao6cnudbn] {
    display: flex; /* Para alinear el checkbox con el texto */
    align-items: center;
    gap: 0.75rem; /* Espacio entre el checkbox y el texto */
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    border-radius: 4px;
    user-select: none; /* Evita que el texto se seleccione al hacer clic */
}

    .dropdown-menu-metrics label:hover[b-uao6cnudbn] {
        background-color: #f8f9fa;
    }

    /* Estilo del checkbox en sí */
    .dropdown-menu-metrics input[type="checkbox"][b-uao6cnudbn] {
        width: 16px;
        height: 16px;
        cursor: pointer;
    }

/* Pequeña animación de aparición */
@keyframes fadeIn-b-uao6cnudbn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.metric-group[b-uao6cnudbn] {
    margin-bottom: 0.75rem;
}

    .metric-group:last-child[b-uao6cnudbn] {
        margin-bottom: 0;
    }

.metric-group-title[b-uao6cnudbn] {
    font-size: 0.75rem;
    font-weight: 700;
    color: #6c757d;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 0.25rem 0.25rem 0.5rem 0.25rem;
    border-bottom: 1px solid #e9ecef;
    margin-bottom: 0.5rem;
}

.form-group[b-uao6cnudbn] {
    flex: 1 1 200px;
}

    .form-group label[b-uao6cnudbn] {
        font-weight: 500;
        margin-bottom: 0.25rem;
    }

.filter-card .btn[b-uao6cnudbn] {
    min-width: 160px;
    height: 38px;
}

/* --- Estilos del Grid Principal --- */
.report-grid[b-uao6cnudbn] {
    border: 1px solid #dee2e6;
    border-radius: 8px;
    overflow-x: auto;
    display: grid;
}

.grid-cell[b-uao6cnudbn] {
    padding: 0.5rem 0.75rem;
    border-right: 1px solid #e9ecef;
    border-bottom: 1px solid #e9ecef;
    display: flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    font-size: 0.85rem;
}

.header-cell[b-uao6cnudbn] {
    background-color: #f8f9fa;
    font-weight: 600;
    position: sticky;
    top: 0;
    z-index: 10;
}

    .header-cell.user-column[b-uao6cnudbn] {
        position: sticky;
        left: 0;
    }

    .header-cell.metric-column[b-uao6cnudbn] {
        position: sticky;
        left: 150px;
    }

.user-name-cell[b-uao6cnudbn] {
    font-weight: 600;
    background-color: #f8f9fa;
    justify-content: flex-start;
    position: sticky;
    left: 0;
    z-index: 6;
    border-right: 1px solid #d0d5db;
}

.metric-label[b-uao6cnudbn] {
    justify-content: flex-start;
    font-weight: 500;
    background-color: #f8f9fa;
    position: sticky;
    left: 150px;
    z-index: 5;
    border-right: 1px solid #d0d5db;
}

.report-grid > div:last-child[b-uao6cnudbn] {
    border-right: none;
}

.report-grid > div:nth-last-child(-n+@NumberOfColumns)[b-uao6cnudbn] {
    border-bottom: none;
}

.total-value[b-uao6cnudbn] {
    font-weight: bold;
    background-color: #f1f3f5;
}

.metric-cell[b-uao6cnudbn] {
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.clickable-cell[b-uao6cnudbn] {
    cursor: pointer; /* Cambia el cursor a la "manita" */
    transition: all 0.2s ease-in-out; /* Para una animación suave */
}

    /* El efecto visual cuando el mouse pasa por encima */
    .clickable-cell:hover[b-uao6cnudbn] {
        background-color: #e0f0ff; /* Un azul un poco más intenso */
        transform: scale(1.08); /* Un ligero efecto de zoom para que "salte" */
        box-shadow: 0 6px 15px rgba(0,0,0,0.15); /* Una sombra más pronunciada */
        z-index: 20; /* Asegura que la celda se vea por encima de sus vecinas */
    }

/* Estilos para indicadores visuales */
.lateness-indicator[b-uao6cnudbn] {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-right: 6px;
}

.lateness-minor[b-uao6cnudbn] {
    background-color: #ffc107;
}

.lateness-major[b-uao6cnudbn] {
    background-color: #dc3545;
}

.has-adjustment-true[b-uao6cnudbn] {
    color: #007bff;
}
/* _content/ValanPlataform.BlazorServerHome/Pages/Asistencias/MiHorario.razor.rz.scp.css */
/* CSS Unificado y Corregido para MiHorario.razor.css */

/* --- INICIO: Estilos de Contenedor y Cabecera para Consistencia --- */
.page-container[b-5q3qgik29s] {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1.5rem 2rem;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

.header-info[b-5q3qgik29s] {
    text-align: center;
    margin-bottom: 2rem;
}

    .header-info h3[b-5q3qgik29s] {
        font-weight: 600;
    }

    .header-info p[b-5q3qgik29s] {
        color: #6c757d;
        margin-top: 0.5rem;
    }
/* --- FIN: Estilos de Contenedor y Cabecera --- */


.cards-grid[b-5q3qgik29s] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.5rem;
}

.day-card[b-5q3qgik29s] {
    border: 1px solid #dee2e6;
    border-radius: 8px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
    display: flex;
    flex-direction: column;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    background-color: #fff;
}

    .day-card:hover[b-5q3qgik29s] {
        transform: translateY(-5px);
        box-shadow: 0 4px 15px rgba(0,0,0,0.1);
        cursor: pointer;
    }

    /* --- AÑADIDO: Estilo para resaltar el día actual --- */
    .day-card.is-today[b-5q3qgik29s] {
        border: 2px solid #007bff; /* Un borde azul para destacar */
        box-shadow: 0 8px 20px rgba(0, 123, 255, 0.15);
    }


.card-header[b-5q3qgik29s] {
    background-color: #f8f9fa;
    padding: 0.75rem 1.25rem;
    font-weight: 600;
    border-bottom: 1px solid #dee2e6;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    text-align: center;
}

.card-body[b-5q3qgik29s] {
    padding: 1.25rem;
    flex-grow: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 100px;
}

.schedule-summary .schedule-time[b-5q3qgik29s] {
    font-size: 1.5rem;
    font-weight: 500;
    color: #343a40;
}

.schedule-summary .schedule-details[b-5q3qgik29s] {
    font-size: 0.9rem;
    color: #6c757d;
}

.not-configured-text[b-5q3qgik29s], .day-off-text[b-5q3qgik29s] {
    font-style: italic;
    color: #6c757d;
}

.day-card.is-day-off[b-5q3qgik29s] {
    background-color: #f1f3f5;
    color: #6c757d;
}

    .day-card.is-day-off .card-header[b-5q3qgik29s] {
        background-color: #e9ecef;
    }

.loading-indicator[b-5q3qgik29s] {
    padding: 2rem;
    text-align: center;
    font-style: italic;
    color: #6c757d;
}

/* --- INICIO: Estilos para el Modal de Detalles (con correcciones) --- */
.modal-backdrop[b-5q3qgik29s] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.6); /* Un poco más oscuro para mejor contraste */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1050;
}

.modal-content[b-5q3qgik29s] {
    background: white;
    padding: 2rem;
    border-radius: 8px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
    width: 90%;
    max-width: 450px;
    color: #212529; /* CORRECCIÓN 1: Asegura que el texto sea oscuro */
    z-index: 1051; /* CORRECCIÓN 2: Asegura que el contenido esté sobre el fondo oscuro */
}

.modal-header[b-5q3qgik29s] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #e9ecef;
    padding-bottom: 1rem;
    margin-bottom: 1.5rem; /* Más espacio */
}

    .modal-header .modal-title[b-5q3qgik29s] {
        font-weight: 600;
    }


.close-button[b-5q3qgik29s] {
    border: none;
    background: transparent;
    font-size: 1.5rem;
    cursor: pointer;
    color: #6c757d;
    transition: color 0.2s ease;
}

    .close-button:hover[b-5q3qgik29s] {
        color: #212529;
    }


/* Cuadrícula para mostrar los detalles de forma ordenada */
.details-grid[b-5q3qgik29s] {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem 1.5rem;
    align-items: center;
}

    .details-grid span[b-5q3qgik29s] {
        color: #495057;
        display: flex;
        align-items: center;
    }

    .details-grid strong[b-5q3qgik29s] {
        font-weight: 600;
    }

    .details-grid i[b-5q3qgik29s] {
        margin-right: 0.75rem;
        color: #007bff;
        width: 20px;
        text-align: center;
    }

/* --- AÑADIR ESTAS REGLAS AL FINAL DE TU CSS --- */

.worksite-list-card[b-5q3qgik29s] {
    background-color: #fff;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    padding: 1.5rem;
    margin-bottom: 2rem;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}

    .worksite-list-card h4[b-5q3qgik29s] {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        font-weight: 600;
        margin-top: 0;
        margin-bottom: 1rem;
        border-bottom: 1px solid #eee;
        padding-bottom: 1rem;
    }

    .worksite-list-card ul[b-5q3qgik29s] {
        list-style: none;
        padding: 0;
        margin: 0;
    }

    .worksite-list-card li[b-5q3qgik29s] {
        padding: 0.5rem 0;
        display: flex;
        flex-direction: column;
    }

        .worksite-list-card li strong[b-5q3qgik29s] {
            font-weight: 500;
        }
/* _content/ValanPlataform.BlazorServerHome/Pages/Asistencias/MisAsistencias.razor.rz.scp.css */
/* En MisAsistencias.razor.css */

/* Contenedor principal de la página, igual al de Registrar Asistencia */
.page-container[b-fh1vgzh0or] {
    max-width: 1100px;
    margin: 0 auto;
    padding: 1.5rem 2rem;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

/* Encabezado con título centrado */
.header-info[b-fh1vgzh0or] {
    text-align: center;
    margin-bottom: 2rem;
}

    .header-info h3[b-fh1vgzh0or] {
        font-weight: 600;
        color: #343a40;
        margin-bottom: 0.25rem;
    }

    .header-info p[b-fh1vgzh0or] {
        color: #6c757d;
        margin-bottom: 0; /* Quitamos el margen grande del p dentro del header */
    }

.filter-card[b-fh1vgzh0or] {
    display: flex;
    align-items: flex-end;
    gap: 1rem;
    padding: 1.5rem;
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    margin-bottom: 2rem;
    flex-wrap: wrap;
}

.form-group[b-fh1vgzh0or] {
    
}

    .form-group label[b-fh1vgzh0or] {
        font-weight: 500;
        margin-bottom: 0.25rem;
    }

.filter-card .btn[b-fh1vgzh0or] {
    min-width: 120px;
    height: 38px; /* Alinear altura con los inputs */
    margin-left: auto; /* <-- AÑADE ESTA LÍNEA MÁGICA */
}

.results-card[b-fh1vgzh0or] {
    background-color: #fff;
    border-radius: 8px;
    border: 1px solid #dee2e6;
    min-height: 200px;
    overflow-x: auto; /* Permite scroll horizontal en escritorio si la tabla es muy ancha */
}

.table[b-fh1vgzh0or] {
    margin-bottom: 0; /* Quita el margen inferior de bootstrap dentro de la tarjeta */
}

.date-group-header td[b-fh1vgzh0or] {
    background-color: #e9ecef;
    font-weight: 600;
    color: #495057;
    font-size: 1.1rem;
    padding: 0.75rem 1rem;
}

.date-group-header i[b-fh1vgzh0or] {
    margin-right: 0.75rem;
    color: #6c757d;
}

tbody tr td i[b-fh1vgzh0or] {
    margin-right: 0.5rem;
    width: 20px;
    text-align: center;
}

/* Colores para los iconos */
.text-success[b-fh1vgzh0or] {
    color: #198754 !important;
}

.text-warning[b-fh1vgzh0or] {
    color: #ffc107 !important;
}

.text-info[b-fh1vgzh0or] {
    color: #0dcaf0 !important;
}

.text-danger[b-fh1vgzh0or] {
    color: #dc3545 !important;
}


/* ===== MEDIA QUERY PARA MÓVILES (LA MAGIA OCURRE AQUÍ) ===== */
@media (max-width: 768px) {
    .history-container[b-fh1vgzh0or] {
        padding: 1rem 0.5rem; /* Menos padding en móvil */
    }

    .filter-card[b-fh1vgzh0or] {
        flex-direction: column; /* Apila los filtros verticalmente */
        align-items: stretch; /* Estira los elementos al 100% del ancho */
    }

    /* --- ESTILOS PARA TABLA RESPONSIVA EN MÓVIL --- */
    .results-card[b-fh1vgzh0or] {
        border: none;
        background: none;
    }

    .table thead[b-fh1vgzh0or] {
        /* Ocultamos los encabezados de la tabla, ya no los necesitamos */
        display: none;
    }

    .table[b-fh1vgzh0or], .table tbody[b-fh1vgzh0or], .table tr[b-fh1vgzh0or], .table td[b-fh1vgzh0or] {
        display: block; /* Hacemos que todos los elementos se comporten como bloques */
        width: 100%;
    }

        .table tr[b-fh1vgzh0or] {
            /* Cada fila ahora es una tarjeta */
            background-color: #fff;
            border: 1px solid #dee2e6;
            border-radius: 8px;
            margin-bottom: 1rem;
            padding: 0.5rem;
        }

            .table tr.date-group-header[b-fh1vgzh0or] {
                /* El encabezado de fecha se mantiene especial */
                background-color: transparent;
                border: none;
                padding: 0;
                margin-bottom: 0.5rem;
            }

                .table tr.date-group-header td[b-fh1vgzh0or] {
                    border-radius: 8px;
                }


        .table td[b-fh1vgzh0or] {
            /* Acomodamos las celdas para que tengan su etiqueta */
            display: flex;
            justify-content: space-between;
            align-items: center;
            text-align: right;
            padding: 0.75rem;
            border: none;
            border-bottom: 1px solid #f1f1f1;
        }

            .table td:last-child[b-fh1vgzh0or] {
                border-bottom: none;
            }

            /* Usamos el pseudo-elemento ::before para añadir la etiqueta de la columna */
            .table td[b-fh1vgzh0or]::before {
                content: attr(data-label); /* Toma el texto del atributo data-label */
                font-weight: 600;
                text-align: left;
                padding-right: 1rem;
                color: #343a40;
            }
}
/* _content/ValanPlataform.BlazorServerHome/Pages/Asistencias/RegistrarAsistencia.razor.rz.scp.css */
/* En RegistrarAsistencia.razor.css (reemplazar todo el contenido) */

/* Contenedor principal de la página */
.page-container[b-v80z6g71m4] {
    padding: 1.5rem 2rem;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background-color: #f8f9fa; /* Un fondo suave para toda la página */
    min-height: 100vh;
}

/* Encabezado con título y hora */
.header-info[b-v80z6g71m4] {
    text-align: center;
    margin-bottom: 2rem;
}

    .header-info h3[b-v80z6g71m4] {
        font-weight: 600;
        color: #343a40;
    }

.current-time[b-v80z6g71m4] {
    font-size: 1rem;
    color: #6c757d;
}

/* Layout principal de dos columnas usando CSS Grid */
.attendance-layout[b-v80z6g71m4] {
    display: grid;
    grid-template-columns: 400px 1fr; /* Columna izq. de ancho fijo, derecha flexible */
    gap: 2rem; /* Espacio entre las columnas */
    align-items: flex-start;
}

/* Contenedores para cada columna */
.info-column[b-v80z6g71m4] {
    display: flex;
    flex-direction: column;
    gap: 1.5rem; /* Espacio entre las tarjetas de la izquierda */
}

.map-column[b-v80z6g71m4] {
    position: sticky; /* El mapa se queda fijo al hacer scroll */
    top: 2rem;
    height: calc(100vh - 4rem); /* Ocupa casi toda la altura visible */
}

.map-wrapper[b-v80z6g71m4] {
    height: 100%;
    width: 100%;
    border-radius: 12px;
    overflow: hidden; /* Asegura que el mapa respete el borde redondeado */
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    border: 1px solid #dee2e6;
}


/* Estilo base para todas las tarjetas de información */
.status-card[b-v80z6g71m4], .action-card[b-v80z6g71m4], .timeline-card[b-v80z6g71m4] {
    background-color: #fff;
    border-radius: 12px;
    padding: 1.5rem;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
    border: 1px solid #e9ecef;
}

    .status-card h4[b-v80z6g71m4] {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        font-size: 0.9rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        color: #6c757d;
        margin-bottom: 0.5rem;
    }

    .status-card p[b-v80z6g71m4] {
        font-size: 1.1rem;
        font-weight: 500;
        color: #212529;
        margin-left: 1.75rem; /* Alinear con el texto del título */
        margin-bottom: 0;
    }

    .status-card small[b-v80z6g71m4] {
        margin-left: 1.75rem;
    }

/* Tarjeta de acción (botón) */
.action-card[b-v80z6g71m4] {
    text-align: center;
}

.btn-check-in[b-v80z6g71m4] {
    width: 100%;
    font-size: 1.2rem;
    font-weight: 600;
    padding: 0.8rem;
    border-radius: 8px;
    color: #fff;
    border: none;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

    .btn-check-in:hover:not(:disabled)[b-v80z6g71m4] {
        transform: translateY(-2px);
        box-shadow: 0 4px 10px rgba(0,0,0,0.15);
    }

/* (El resto de los estilos del botón .btn-check-in-xxxx permanecen igual) */
.btn-check-in-start[b-v80z6g71m4] {
    background-color: #28a745;
}

.btn-check-in-lunch[b-v80z6g71m4] {
    background-color: #ffc107;
    color: #212529;
}

.btn-check-in-lunch-end[b-v80z6g71m4] {
    background-color: #17a2b8;
}

.btn-check-in-end[b-v80z6g71m4] {
    background-color: #dc3545;
}

.btn-disabled[b-v80z6g71m4] {
    background-color: #6c757d;
    cursor: not-allowed;
}

.location-status[b-v80z6g71m4] {
    margin-top: 1rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

    .location-status.valid[b-v80z6g71m4] {
        color: #28a745;
    }

    .location-status.invalid[b-v80z6g71m4] {
        color: #dc3545;
    }


/* Línea de tiempo de actividad */
.timeline-card h4[b-v80z6g71m4] {
    text-align: center;
    margin-bottom: 1.5rem;
    font-weight: 600;
    color: #343a40;
}

.timeline[b-v80z6g71m4] {
    list-style: none;
    padding: 0;
    margin: 0;
    position: relative;
}
    /* La línea vertical del timeline */
    .timeline[b-v80z6g71m4]::before {
        content: '';
        position: absolute;
        left: 12px;
        top: 5px;
        bottom: 5px;
        width: 2px;
        background: #e9ecef;
    }

    .timeline li[b-v80z6g71m4] {
        display: flex;
        align-items: center;
        gap: 1rem;
        margin-bottom: 1.25rem;
        position: relative;
    }

.timeline-icon[b-v80z6g71m4] {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background-color: #fff;
    border: 2px solid #6c757d;
    color: #6c757d;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
    z-index: 1; /* Para que esté por encima de la línea vertical */
}

.timeline-content[b-v80z6g71m4] {
    display: flex;
    flex-direction: column;
}

    .timeline-content strong[b-v80z6g71m4] {
        font-weight: 600;
        color: #495057;
    }

    .timeline-content span[b-v80z6g71m4] {
        font-size: 0.9rem;
        color: #6c757d;
    }


/* Responsividad para pantallas pequeñas */
@media (max-width: 992px) {
    .attendance-layout[b-v80z6g71m4] {
        grid-template-columns: 1fr; /* Cambia a una sola columna */
    }

    .map-column[b-v80z6g71m4] {
        position: relative; /* Quita el sticky */
        top: 0;
        height: 400px; /* Altura fija para el mapa en móvil */
    }
}


.diagnostic-panel[b-v80z6g71m4] {
    border: 1px solid #ffc107; /* Borde ambar para que destaque como info de debug */
    border-radius: 8px;
    margin: 1.5rem 0;
    background-color: #fffbeb;
    color: #664d03;
}

.diagnostic-header[b-v80z6g71m4] {
    padding: 0.75rem 1.25rem;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    user-select: none; /* Evita que el texto se seleccione al hacer doble clic */
}

.diagnostic-content[b-v80z6g71m4] {
    padding: 1rem 1.25rem 1.25rem 1.25rem;
    border-top: 1px solid #ffe69c;
}

    .diagnostic-content p[b-v80z6g71m4] {
        margin-bottom: 0.5rem;
        color: #555;
    }

    .diagnostic-content code[b-v80z6g71m4] {
        background-color: #fff3cd;
        padding: 0.2rem 0.4rem;
        border-radius: 4px;
        color: #000;
    }

/* Estilo para el icono de flecha */
.diagnostic-header .oi[b-v80z6g71m4] {
    transition: transform 0.2s ease-in-out;
}
/* _content/ValanPlataform.BlazorServerHome/Pages/Asistencias/ReporteExcepcional.razor.rz.scp.css */
/* En ReporteExcepcional.razor.css */
.page-container[b-gaau3cbtcj] {
    max-width: 900px;
    margin: 0 auto;
    padding: 1.5rem 2rem;
}

.header-info[b-gaau3cbtcj] {
    text-align: center;
    margin-bottom: 2rem;
}

    .header-info h3[b-gaau3cbtcj] {
        font-weight: 600;
    }

.selection-card[b-gaau3cbtcj] {
    background-color: #f8f9fa;
    padding: 2rem;
    border-radius: 8px;
    border: 1px solid #dee2e6;
    max-width: 500px;
    margin: 2rem auto;
}

.editor-actions[b-gaau3cbtcj] {
    margin-bottom: 1.5rem;
    display: flex;
}

.editor-form[b-gaau3cbtcj] {
    background-color: #fff;
    padding: 2rem 2.5rem;
    border-radius: 12px;
    border: 1px solid #e9ecef;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}

.form-section[b-gaau3cbtcj] {
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid #f1f1f1;
}

    .form-section:last-of-type[b-gaau3cbtcj] {
        border-bottom: none;
    }

    .form-section h4[b-gaau3cbtcj] {
        font-weight: 500;
        color: #343a40;
    }

.summary-section p[b-gaau3cbtcj] {
    margin-bottom: 0.5rem;
}

.attendance-summary-list[b-gaau3cbtcj] {
    list-style: none;
    padding-left: 0.5rem;
    margin-top: 1rem;
}

    .attendance-summary-list li[b-gaau3cbtcj] {
        margin-bottom: 0.5rem;
        display: flex;
        align-items: center;
        gap: 0.75rem;
    }

    .attendance-summary-list i[b-gaau3cbtcj] {
        color: #6c757d;
    }

.total-hours[b-gaau3cbtcj] {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid #eee;
    font-weight: 600;
}
/* _content/ValanPlataform.BlazorServerHome/Pages/Cuentas/SignIn.razor.rz.scp.css */

/* Estilos para el contenedor principal de la página de inicio de sesión */
.login-page-container[b-ojtjn1h603] {
    display: flex;
    justify-content: center;
    align-items: flex-start; /* Alinea al inicio verticalmente */
    min-height: calc(100vh - 70px - 50px); /* Ajusta a la altura de la pantalla menos navbar y footer */
    padding: 40px 20px; /* Espaciado interno */
    background-color: var(--surface-color); /* Un fondo suave para la página */
}

/* Estilos para la "tarjeta" del formulario de inicio de sesión */
.login-card[b-ojtjn1h603] {
    background-color: var(--contrast-color); /* Fondo blanco para la tarjeta */
    padding: 30px 40px;
    border-radius: 8px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1); /* Sombra suave */
    max-width: 450px; /* Ancho máximo para el formulario */
    width: 100%; /* Ocupa el ancho disponible hasta el max-width */
    text-align: center; /* Centra el texto dentro de la tarjeta */
}

    .login-card h1[b-ojtjn1h603] {
        color: var(--heading-color); /* Color del encabezado */
        margin-bottom: 15px;
        font-size: 2.2rem;
    }

    .login-card p[b-ojtjn1h603] {
        color: var(--default-color); /* Color del texto general */
        margin-bottom: 25px;
    }

.login-image[b-ojtjn1h603] {
    max-width: 250px; /* Tamaño máximo para la imagen */
    height: auto;
    border-radius: 8px; /* Bordes redondeados para la imagen */
    margin-bottom: 30px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08); /* Sombra ligera para la imagen */
}

/* Estilos para los grupos de formulario */
.form-group[b-ojtjn1h603] {
    margin-bottom: 20px;
    text-align: left; /* Alinea etiquetas y campos a la izquierda */
}

    .form-group label[b-ojtjn1h603] {
        font-weight: 600; /* Texto de etiqueta un poco más grueso */
        color: var(--default-color);
        margin-bottom: 8px;
        display: block; /* Asegura que la etiqueta esté en su propia línea */
    }

.form-control[b-ojtjn1h603] {
    width: 100%;
    padding: 12px 15px;
    border: 1px solid #ced4da;
    border-radius: 5px;
    font-size: 1rem;
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

    .form-control:focus[b-ojtjn1h603] {
        border-color: var(--accent-color); /* Borde azul claro al enfocar */
        box-shadow: 0 0 0 0.25rem rgba(62, 193, 213, 0.25); /* Sombra al enfocar */
        outline: none; /* Elimina el contorno predeterminado del navegador */
    }

/* Estilos para los mensajes de validación */
.validation-message[b-ojtjn1h603] {
    color: #dc3545; /* Rojo de error */
    font-size: 0.875em;
    margin-top: 5px;
    display: block;
    text-align: left;
}

.alert.alert-danger[b-ojtjn1h603] {
    color: #842029;
    background-color: #f8d7da;
    border-color: #f5c2c7;
    padding: 10px 15px;
    margin-bottom: 20px;
    border-radius: 5px;
    text-align: left;
}


/* Enlace de "Olvidaste tu contraseña" */
.forgot-password-link[b-ojtjn1h603] {
    color: var(--accent-color); /* Color azul claro para el enlace */
    text-decoration: none;
    font-weight: 500;
    transition: color 0.3s ease;
}

    .forgot-password-link:hover[b-ojtjn1h603] {
        color: var(--heading-color); /* Azul oscuro al pasar el ratón */
        text-decoration: underline;
    }

/* Estilos para el botón de Iniciar Sesión (utiliza los estilos de btn-primary globales que ya definimos) */
.btn.btn-primary[b-ojtjn1h603] {
    /* Estos estilos ya están definidos en tu CSS global para .btn-primary */
    /* Asegúrate de que tu `site.css` se carga antes de este archivo o que las variables de color estén disponibles */
}

/* Estilos del overlay de carga */
.loading-overlay[b-ojtjn1h603] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.8); /* Fondo semitransparente */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999; /* Asegura que esté por encima de todo */
}

.spinner-border[b-ojtjn1h603] {
    width: 3rem;
    height: 3rem;
    color: var(--gold-color) !important; /* Asegura que el spinner sea dorado */
}


/* Responsividad para pantallas más pequeñas */
@media (max-width: 576px) {
    .login-card[b-ojtjn1h603] {
        padding: 25px 25px;
    }

        .login-card h1[b-ojtjn1h603] {
            font-size: 1.8rem;
        }
}
/* _content/ValanPlataform.BlazorServerHome/Shared/Modals/ImageGalleryModal.razor.rz.scp.css */
.gallery-backdrop[b-4b3kmwdz6t] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.75); /* Fondo más oscuro */
    z-index: 1050;
}

.gallery-modal[b-4b3kmwdz6t] {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    max-width: 800px;
    max-height: 90vh;
    background: #fff;
    border-radius: 8px;
    z-index: 1051;
    display: flex;
    flex-direction: column;
}

.gallery-header[b-4b3kmwdz6t] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1.5rem;
    border-bottom: 1px solid #dee2e6;
}

    .gallery-header h5[b-4b3kmwdz6t] {
        margin: 0;
    }

.close-button[b-4b3kmwdz6t] {
    border: none;
    background: none;
    font-size: 2rem;
    color: #6c757d;
    cursor: pointer;
}

.gallery-body[b-4b3kmwdz6t] {
    padding: 1rem;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.main-image-container[b-4b3kmwdz6t] {
    flex-grow: 1; /* Ocupa todo el espacio vertical disponible */
    background-color: #212529;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    min-height: 300px;
}

    .main-image-container img[b-4b3kmwdz6t] {
        max-width: 100%;
        max-height: 65vh;
        object-fit: contain;
    }

.thumbnails-container[b-4b3kmwdz6t] {
    display: flex;
    gap: 0.5rem;
    padding: 0.5rem;
    overflow-x: auto; /* Scroll horizontal para el cintillo */
    background-color: #f8f9fa;
    border-radius: 4px;
}

.thumbnail-item[b-4b3kmwdz6t] {
    height: 70px;
    width: 70px;
    border: 2px solid transparent;
    border-radius: 4px;
    flex-shrink: 0; /* Evita que las miniaturas se encojan */
    cursor: pointer;
    transition: border-color 0.2s ease;
}

    .thumbnail-item:hover[b-4b3kmwdz6t] {
        border-color: #adb5bd;
    }

    .thumbnail-item.active[b-4b3kmwdz6t] {
        border-color: #007bff;
    }

    .thumbnail-item img[b-4b3kmwdz6t] {
        width: 100%;
        height: 100%;
        object-fit: cover;
        border-radius: 2px;
    }
/* _content/ValanPlataform.BlazorServerHome/Shared/Sections/MetricDetailPopover.razor.rz.scp.css */
.metric-popover-backdrop[b-sufskb78ul] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 1040; /* Por debajo del popover, pero por encima de todo lo demás */
    background: transparent;
}

.metric-popover[b-sufskb78ul] {
    position: fixed;
    z-index: 1041;
    background: white;
    border-radius: 8px;
    box-shadow: 0 8px 25px rgba(0,0,0,0.2);
    border: 1px solid #ddd;
    width: 320px;
    transition: opacity 0.2s, transform 0.2s;
    transform-origin: top left;
}

.popover-header[b-sufskb78ul] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid #eee;
}

    .popover-header h5[b-sufskb78ul] {
        margin: 0;
        font-size: 1rem;
        font-weight: 600;
    }

.close-button[b-sufskb78ul] {
    border: none;
    background: none;
    font-size: 1.5rem;
    line-height: 1;
    color: #888;
    cursor: pointer;
}

.popover-body[b-sufskb78ul] {
    padding: 1rem;
}

.details-grid[b-sufskb78ul] {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.5rem 1rem;
    font-size: 0.9rem;
}

    .details-grid span[b-sufskb78ul] {
        color: #6c757d;
    }

    .details-grid strong[b-sufskb78ul] {
        text-align: right;
        font-weight: 600;
    }
