/* css/estilos_modernos.css */

/* 1. IMPORTAR FUENTES MODERNAS */
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap');

/* 2. VARIABLES DE COLOR (Basadas en el Logo) */
:root {
    --primary-blue: #004B87;    /* Azul del casco/escudo */
    --secondary-red: #D6001C;   /* Rojo del escudo */
    --accent-gold: #F2A900;     /* Dorado de las herramientas */
    --bg-light: #f4f6f9;        /* Fondo gris muy suave */
    --text-dark: #333333;       /* Texto principal */
    --white: #ffffff;
    --shadow: 0 4px 6px rgba(0,0,0,0.1); /* Sombra suave */
}

/* 3. RESET Y BASE */
body {
    font-family: 'Roboto', sans-serif;
    background-color: var(--bg-light);
    color: var(--text-dark);
    margin: 0;
    padding: 0;
    line-height: 1.6;
}

h1, h2, h3 {
    color: var(--primary-blue);
    font-weight: 700;
}

/* 4. CABECERA MODERNA */
header.main-header {
    background-color: var(--white);
    box-shadow: var(--shadow);
    padding: 10px 40px;
    display: flex;
    justify-content: space-between; /* Logo a la izq, Menú a la der */
    align-items: center;
    position: sticky;
    top: 0;
    z-index: 1000;
    border-bottom: 3px solid var(--secondary-red); /* Detalle corporativo */
}

.logo-container {
    display: flex;
    align-items: center;
    gap: 15px;
}

.logo-img {
    height: 70px; /* Tamaño controlado del logo */
    width: auto;
    transition: transform 0.3s ease;
}

.logo-img:hover {
    transform: scale(1.05);
}

.brand-name {
    font-size: 1.2rem;
    font-weight: bold;
    color: var(--primary-blue);
    text-transform: uppercase;
    display: none; /* Oculto en móviles, visible en escritorio si quieres */
}

@media (min-width: 768px) {
    .brand-name { display: block; }
}

/* --- ESTILOS DEL TÍTULO DE CABECERA --- */

.title-block {
    display: flex;
    flex-direction: column; /* Pone uno encima del otro */
    justify-content: center;
}

.consortium-name {
    font-size: 0.75rem;       /* Texto pequeño */
    color: #666;              /* Gris suave */
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;      /* Separación entre letras */
    line-height: 1.1;
}

.app-title {
    font-size: 1.4rem;        /* Texto grande */
    color: var(--primary-blue); /* Azul corporativo */
    font-weight: 700;         /* Negrita fuerte */
    text-transform: uppercase;
    line-height: 1;
    margin-top: 2px;
}

/* --- AJUSTE PARA MÓVILES (Responsivo) --- */
@media (max-width: 768px) {
    /* En móviles ocultamos el nombre del consorcio para ahorrar espacio */
    /*.item-container { flex-direction: column; }
    body { width: 100% !important; }
    table, thead, tbody, th, td, tr { display: block; } */
    .consortium-name {
        display: none;
    }
    
    /* Y hacemos el título de la app un poco más pequeño */
    .app-title {
        font-size: 1.1rem;
    }
    
    /* Reducimos el logo un poco también */
    .logo-img {
        height: 50px; 
    }
}
/* 5. NAVEGACIÓN Y ENLACES */
nav.main-nav {
    display: flex;
    gap: 15px;
}

nav.main-nav a {
    text-decoration: none;
    color: var(--text-dark);
    font-weight: 500;
    padding: 8px 15px;
    border-radius: 50px;
    transition: all 0.3s ease;
}

nav.main-nav a:hover {
    background-color: var(--primary-blue);
    color: var(--white);
}

nav.main-nav a i {
    margin-right: 5px;
}

/* 6. BOTONES ELEGANTES Y MODERNOS */
.btn-modern {
    /* 1. ESTRUCTURA (Igualar comportamiento de caja) */
    display: inline-flex;       /* Alinea icono y texto perfectamente */
    align-items: center;        /* Centra verticalmente el contenido */
    justify-content: center;
    box-sizing: border-box;     /* El borde cuenta dentro del tamaño total */
    
    /* 2. TAMAÑO Y ESPACIO */
    padding: 10px 20px;
    font-size: 0.95rem;
    line-height: 1.5;           /* Altura de línea consistente */
    gap: 10px;                  /* Espacio entre icono y texto */
    
    /* 3. RESETEAR ESTILOS DE NAVEGADOR (Clave para <button>) */
    border: 2px solid transparent; /* Define un borde base transparente para todos */
    background: none;              /* Quita fondos grises por defecto */
    appearance: none;              /* Quita estilos nativos del SO (Mac/Windows) */
    -webkit-appearance: none;
    
    /* 4. FUENTE (Importante: button no hereda por defecto) */
    font-family: inherit;       /* Usa la misma fuente que el resto de la web */
    font-weight: 600;
    text-decoration: none;      /* Quita subrayado de enlaces */
    cursor: pointer;            /* Fuerza la manita en botones */
    
    /* 5. ESTÉTICA */
    border-radius: 8px;
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}
/* Botón Primario (Azul) */
.btn-primary {
    background-color: #004B87;
    color: #fff;
    /* El borde sigue siendo transparent (definido en .btn-modern), 
       así que ocupa el mismo espacio que el secundario */
}

.btn-primary:hover {
    background-color: #003366;
    transform: translateY(-2px);
}
/* Botón de Acción/Peligro (Rojo - Ideal para borrar o acciones importantes) */
.btn-danger {
    background-color: #D6001C;
    color: #fff;
}

.btn-danger:hover {
    background-color: #b00015;
    transform: translateY(-2px);
}

/* --- Botón Secundario (Fondo blanco, Borde Azul) --- */
.btn-secondary,
.btn-secondary:visited {
    background-color: #ffffff;
    border-color: #004B87;
    /* Forzamos el azul en estado normal para que no se ponga morado */
    color: #004B87 !important; 
}

.btn-secondary:hover {
    background-color: #004B87; /* Fondo se vuelve azul */
    
    /* SOLUCIÓN AQUÍ: Forzamos el texto a BLANCO */
    color: #ffffff !important; 
    
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0, 75, 135, 0.2);
}

/* 7. CONTENEDORES Y TABLAS */
main.container {
    max-width: 1200px;
    margin: 40px auto;
    padding: 20px;
    background: var(--white);
    border-radius: 12px;
    box-shadow: var(--shadow);
}

table {
    width: 100%;
    border-collapse: collapse;
    margin: 20px 0;
    font-size: 0.95rem;
    border-radius: 8px;
    overflow: hidden; /* Para que los bordes redondeados funcionen en la tabla */
    box-shadow: 0 0 10px rgba(0,0,0,0.05);
}

thead tr {
    background-color: var(--primary-blue);
    color: var(--white);
    text-align: left;
}

th, td {
    padding: 12px 15px;
}

tbody tr {
    border-bottom: 1px solid #dddddd;
}

tbody tr:nth-of-type(even) {
    background-color: #f3f3f3;
}

tbody tr:last-of-type {
    border-bottom: 2px solid var(--primary-blue);
}

tbody tr:hover {
    background-color: #e9f2fb; /* Azul muy clarito al pasar el mouse */
}

/* Estilos para inputs del buscador */
/* AHORA (Corregido) */
input[type="text"], 
input[type="password"], /* <--- AÑADE ESTA LÍNEA */
input[type="date"], 
select {
    width: 100%; /* Asegura que ocupen todo el ancho disponible */
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 5px;
    outline: none;
    transition: border-color 0.3s;
    box-sizing: border-box; /* Importante para que el padding no desborde */
}
input[type="number"]{
    width: 100%;
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 5px;
    box-sizing: border-box; /* Fundamental para que el padding no lo ensanche */
    font-family: inherit;
}

input:focus {
    border-color: var(--primary-blue);
    box-shadow: 0 0 5px rgba(0, 75, 135, 0.2);
}

input:focus {
    border-color: var(--primary-blue);
    box-shadow: 0 0 5px rgba(0, 75, 135, 0.2);
}
/* =========================================
   CORRECCIÓN DE ENLACES VISITADOS
   ========================================= */

/* 1. Para enlaces de texto normales (navegación, tablas, etc.) */
a, 
a:link, 
a:visited, 
a:active {
    color: var(--primary-blue); /* Usa tu variable de azul (#004B87) */
    text-decoration: none;
}

/* Efecto al pasar el ratón (opcional, para dar feedback) */
a:hover {
    color: var(--secondary-red); /* Cambia a rojo al pasar el ratón */
}


/* 2. Para tus botones modernos (IMPORTANTE) */
/* Esto asegura que el texto del botón siga siendo blanco aunque lo hayas pulsado */

/* Botones Primarios y de Peligro (Texto blanco) */
.btn-primary, .btn-primary:visited,
.btn-danger, .btn-danger:visited {
    color: var(--white) !important;
}

/* Estilos para Drag & Drop */

/* El icono de agarre */
.handle {
    cursor: grab; /* Muestra la mano abierta */
    padding: 0 10px;
    color: #bbb;
    font-size: 1.2rem;
}

.handle:active {
    cursor: grabbing; /* Muestra la mano cerrada al arrastrar */
}

/* El elemento "Fantasma" (El hueco donde va a caer el item) */
.sortable-ghost {
    background-color: #e3f2fd; /* Azul muy claro */
    border: 2px dashed var(--primary-blue);
    opacity: 0.5;
}

/* El elemento mientras lo estás arrastrando */
.sortable-drag {
    background-color: white;
    box-shadow: 0 10px 20px rgba(0,0,0,0.2);
    transform: rotate(2deg); /* Un pequeño giro para efecto visual */
}
/* =======================================================
   ESTILOS RESPONSIVE (MÓVIL)
   ======================================================= */

/* 1. Ajustes Generales para Móvil */
@media (max-width: 768px) {
    
    /* El cuerpo ocupa el 100% y no permite scroll horizontal fantasma */
    body {
        width: 100%;
        overflow-x: hidden;
    }

    /* 2. Cabecera: Apilar elementos */
    header.main-header {
        flex-direction: column; /* Pone el logo arriba y menú abajo */
        padding: 10px;
        height: auto;
    }

    .logo-container {
        margin-bottom: 15px;
        justify-content: center;
    }

    /* 3. Menú de Navegación: Botones más grandes y apilados o en rejilla */
    nav.main-nav {
        display: flex;
        flex-wrap: wrap; /* Permite que los botones bajen si no caben */
        justify-content: center;
        gap: 10px;
        width: 100%;
    }

    nav.main-nav a {
        font-size: 0.85rem;
        padding: 8px 12px;
        flex-grow: 1; /* Los botones ocupan el espacio disponible */
        text-align: center;
        white-space: nowrap; /* Evita que el texto del botón se rompa feo */
    }

    /* 4. Contenedor Principal */
    main.container {
        width: 95%; /* Ocupa casi toda la pantalla */
        margin: 20px auto;
        padding: 15px;
        box-shadow: none; /* Quitamos sombra en móvil para ganar espacio */
        border: 1px solid #eee;
    }

    /* 5. Títulos y Textos */
    h1 { font-size: 1.5rem; }
    h2 { font-size: 1.2rem; }

    /* 6. Formularios en columna */
    form {
        flex-direction: column;
        align-items: stretch !important;
    }
    
    /* Inputs ocupan todo el ancho */
    input[type="text"], input[type="date"], input[type="email"], input[type="password"], select {
        width: 100% !important;
        min-width: 0; /* Evita desbordamiento */
        margin-bottom: 10px;
    }
    
    /* Ocultar elementos innecesarios en móvil si quieres */
    .brand-name {
        font-size: 1rem; /* Texto más pequeño */
    }
}
/* Contenedor para hacer tablas scrollables en móvil */
.table-responsive {
    width: 100%;
    overflow-x: auto; /* Scroll horizontal automático */
    -webkit-overflow-scrolling: touch; /* Scroll suave en iPhone */
    margin-bottom: 15px;
    border: 1px solid #ddd;
}

/* Asegurar que la tabla no se aplaste demasiado */
.table-responsive table {
    min-width: 600px; /* Fuerza un ancho mínimo para que se lea bien */
    margin-bottom: 0;
    border: none;
}
/* --- Estructura de Formulario de 2 Columnas (Desktop) --- */
.form-grid-2 {
    display: grid;
    /* Dos columnas de ancho igual */
    grid-template-columns: 1fr 1fr; 
    gap: 25px; /* Espacio entre columnas y filas */
    margin-bottom: 20px;
}

/* --- Estructura de Formulario (Móvil) --- */
@media (max-width: 768px) {
    .form-grid-2 {
        /* Colapsar a una sola columna */
        grid-template-columns: 1fr; 
        gap: 15px; /* Reducir espacio en móvil */
    }
}