/* --- Paleta de Colores Fe y Alegría --- */
:root {
    --rojo-fya: #C8102E; /* Rojo principal */
    --rojo-hover: #A00824; /* Un rojo más oscuro para hover */
    --gris-fya: #F8F9FA; /* Gris muy claro para fondos */
    --gris-texto: #495057; /* Gris para texto */
    --gris-oscuro: #343A40; /* Gris oscuro para contrastes */
}

/* --- Estilos Generales --- */
body {
    background-color: var(--gris-fya);
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    color: var(--gris-texto);
}

/* --- Header del Portal (Principal y de Colegios) --- */
.header-portal {
    background-color: var(--gris-fya) !important;
    color: black !important;
    border-bottom: 1px solid #dee2e6; /* Un borde gris sutil */
}

/* --- Header para otras páginas (como la de registro) --- */
/* Esta regla ahora solo aplicará a headers que no tengan la clase .header-portal */
header:not(.header-portal) {
    background-color: var(--rojo-fya) !important;
    border-bottom: 4px solid var(--rojo-hover);
    color: white !important;
}

header h1 {
    font-weight: 700;
}

/* --- Tarjetas Principales --- */
.card-hover {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    border-top: 5px solid var(--rojo-fya);
}

.card-hover:hover {
    transform: translateY(-10px);
    box-shadow: 0 1rem 3rem rgba(0,0,0,.175)!important;
}

/* --- Botones --- */
.btn-primary {
    background-color: var(--rojo-fya) !important;
    border-color: var(--rojo-fya) !important;
    font-weight: 600;
}

.btn-primary:hover {
    background-color: var(--rojo-hover) !important;
    border-color: var(--rojo-hover) !important;
}

.btn-secondary {
    background-color: var(--gris-oscuro) !important;
    border-color: var(--gris-oscuro) !important;
}

.btn-secondary:hover {
    background-color: #212529 !important;
    border-color: #212529 !important;
}

/* --- Estilos para la página de colegios --- */
.table thead th {
    background-color: var(--rojo-fya) !important;
    color: white !important;
    border-color: var(--rojo-hover) !important;
}

.table-hover tbody tr:hover {
    background-color: rgba(200, 16, 46, 0.05) !important;
}

/* --- Estilos para notificaciones --- */
.notifications-container {
    z-index: 1050;
}

.notification {
    min-width: 300px;
    margin-bottom: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    border-left: 4px solid var(--rojo-fya);
}

.notification-success {
    border-left-color: #28a745;
}

.notification-error {
    border-left-color: #dc3545;
}

.notification-warning {
    border-left-color: #ffc107;
}

/* --- Estilos para la página de registro de equipos --- */
.logo {
    max-width: 150px;
}

.form-file-input input[type="file"] {
    border: 1px solid #ced4da;
    border-radius: 0.375rem;
    padding: 0.375rem 0.75rem;
    width: 100%;
}

.form-file-input input[type="file"]:focus {
    border-color: var(--rojo-fya);
    box-shadow: 0 0 0 0.25rem rgba(200, 16, 46, 0.25);
}

/* --- Corrección para el modal de verificación (Más robusto) --- */
.modal-header {
    background-color: var(--rojo-fya) !important;
    color: white !important;
}

.modal-header .btn-close {
    filter: invert(1);
}

/* --- Corrección para los iconos --- */
.text-primary {
    color: var(--rojo-fya) !important;
}

/* --- Corrección para los enlaces --- */
a {
    color: var(--rojo-fya);
}

a:hover {
    color: var(--rojo-hover);
}

/* --- Estilos para la página de administración de colegios --- */
.access-code-display {
    background-color: #f8f9fa; /* Fondo gris suave */
    border: 1px dashed var(--rojo-fya); /* Borde punteado rojo para destacar */
    border-radius: 5px;
    padding: 10px;
    margin: 10px 0;
    font-family: 'Courier New', Courier, monospace; /* Tipografía de código */
    display: flex; /* Usamos flexbox para alinear elementos */
    align-items: center;
    justify-content: space-between; /* Separa la info del botón */
}

.access-code-display .codigo-info {
    display: flex;
    align-items: center;
}

.access-code-display i.bi-key-fill {
    color: var(--rojo-fya); /* Icono de la llave en rojo */
    margin-right: 8px;
    font-size: 1.1em;
}

.codigo-acceso-texto {
    font-weight: bold;
    font-size: 1.2em;
    color: var(--gris-oscuro); /* Texto del código en gris oscuro */
    letter-spacing: 2px; /* Espaciado entre letras para mejor legibilidad */
    user-select: all; /* Permite seleccionar todo el código con un doble clic */
}

/* --- NUEVO: Estilos para el botón de copiar código de acceso --- */
.copy-access-code-btn {
    background: none;
    border: none;
    color: var(--rojo-fya);
    cursor: pointer;
    padding: 5px;
    margin-left: 10px;
    border-radius: 3px;
    transition: background-color 0.2s, transform 0.1s;
}

.copy-access-code-btn:hover {
    background-color: rgba(200, 16, 46, 0.1); /* Fondo rojo claro al pasar el mouse */
}

.copy-access-code-btn:active {
    transform: scale(0.95); /* Pequeña animación al hacer clic */
}

.copy-access-code-btn i {
    font-size: 1.1em;
}

/* --- Estilos para el componente Particle Net (Fondo Completo) --- */
.particle-net-canvas {
    position: fixed; /* Se queda fijo en la ventana */
    top: 0;
    left: 0;
    width: 100vw; /* 100% del ancho de la ventana */
    height: 100vh; /* 100% del alto de la ventana */
    pointer-events: none; /* Permite hacer clic a través del canvas */
    z-index: 0; /* Se coloca detrás de todo el contenido */
}

/* Asegura que el cuerpo tenga un fondo para que el canvas transparente se vea bien */
body {
    background-color: #f8f9fa; /* Fondo blanco/gris muy claro */
}

/* Aseguramos que todo el contenido de la página esté por encima del canvas */
body > header,
body > main,
body > footer,
body > div:not(.particle-net-canvas) {
    position: relative;
    z-index: 1;
}

/* Opcional: Dar un fondo semi-transparente a las tarjetas para que el efecto se note más */
/* Este estilo es opcional y depende de si usas la clase 'card' */
.card {
    background-color: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(50px); /* Efecto de cristal esmerilado */
    border-radius: 10px;
}