/*========== RESETEO Y BASE ==========*/
* {
    margin: 0;             /* Quita los espacios externos que el navegador pone por defecto */
    padding: 0;            /* Quita los espacios internos por defecto */
    box-sizing: border-box; /* Hace que el padding no aumente el tamaño total de los elementos */
}

body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; /* Fuente principal */
    background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%); /* Fondo oscuro con degradado */
    min-height: 100vh;     /* Asegura que el fondo cubra al menos toda la altura de la pantalla */
    color: #e0e0e0;        /* Color de texto gris claro para que no canse la vista */
    padding-top: 100px;    /* Espacio arriba para que el menú fijo no tape el título h1 */
}

/*========== SCROLLBAR PERSONALIZADA (Barra de navegación lateral) ==========*/
body::-webkit-scrollbar { 
    width: 15px;           /* Ancho de la barra de scroll */
}
body::-webkit-scrollbar-track { 
    background: #2d2d2d;   /* Color del carril por donde se mueve la barra */
}
body::-webkit-scrollbar-thumb {
    background: rgba(245, 243, 243, 0.1); /* Color del "tirador" (traslúcido) */
    border-radius: 10px;   /* Bordes redondeados para la barra */
    border: 4px solid transparent; /* Crea un margen invisible para que la barra se vea más delgada */
    background-clip: content-box;  /* Hace que el color no toque los bordes del scrollbar */
}
body::-webkit-scrollbar-thumb:hover { 
    background: rgba(255, 255, 255, 0.2); /* Brilla un poco más cuando pasas el ratón */
}



/*========== NAVEGACIÓN CON ESTILO MODERNIN==========*/
nav {
    height: 70px;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    /* Estética Glassmorphism */
    background: rgba(30, 30, 30, 0.8);
    backdrop-filter: blur(15px); 
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 40px;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.5);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    z-index: 1000;
}

/* Estilo para los enlaces y el botón del menú */
nav a, .menu-desplegable-btn {
    color: #aaa; /* Gris suave del estilo moderno */
    text-decoration: none;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 10px 20px;
    border-radius: 8px;
    transition: 0.3s;
    display: flex;
    align-items: center;
}

/* Efecto Hover con Brillo Azul */
nav a:hover, 
.menu-desplegable-btn:hover {
    color: #4db8ff;
    text-shadow: 0 0 10px rgba(77, 184, 255, 0.5);
}

/* Ajuste específico para el menú desplegable */
.menu-desplegable-contenido {
    position: absolute;
    top: 100%;
    right: 20px; /* Ajustado para que no pegue al borde */
    background: rgba(30, 30, 30, 0.95); /* Fondo a juego con el nav */
    backdrop-filter: blur(10px);
    min-width: 250px;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.6);
    border: 1px solid rgba(255, 255, 255, 0.1);
    opacity: 0;
    visibility: hidden;
    transform: translateY(15px);
    transition: 0.3s ease;
    overflow: hidden;
}

.menu-desplegable:hover .menu-desplegable-contenido {
    opacity: 1;
    visibility: visible;
    transform: translateY(5px);
}

.menu-desplegable-contenido a {
    text-transform: none; /* Los items del menú se ven mejor en normal */
    letter-spacing: 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}

/*Estilo de la img de inicio*/
.img-home {
    display: inline-block; /*Deja tratar a la img como un botón*/
    width: 40px;
    height: 40px;
    cursor: pointer;
    transition: transform 0.3s ease;
}

.img-home img {
    width: 100%; /*Ajusta la imagen a todo el boton*/
    height: 100%; 
    object-fit: contain; /*Contiene la imagen para que no se deforme*/
    
}

.img-home:hover {
    background-color: none;
    background: none;
    transform: scale(1.2);
}


/*========== CONTENIDO DE LA PÁGINA ==========*/
h1 {
    font-size: 2.5em;
    text-align: center;    /* Centra el título principal */
    margin-bottom: 20px;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.5); /* Sombra para que resalte del fondo */
}

.img-page {
    display: block;        /* Permite usar márgenes auto para centrar la imagen */
    margin: 0 auto 30px;   /* Centrada horizontalmente y con espacio abajo */
    max-width: 400px;      /* Tamaño máximo de la imagen del procesador */
    border-radius: 15px;   /* Esquinas de la foto redondeadas */
    box-shadow: 0 10px 20px rgba(0,0,0,0.4); /* Sombra pesada bajo la foto */
}

p {
    line-height: 1.6;      /* Más espacio entre líneas de texto para que se lea mejor */
    margin-bottom: 20px;
    color: #b8b8b8;        /* Color de texto más suave que el blanco */
}
.descripcion{
    padding: 10px 30px 10px;
    text-align: center;
    font-size: 20px;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.5); /* Sombra para que resalte del fondo */
}
section {
    max-width: 1000px;     /* El contenido no se estira hasta el infinito en pantallas anchas */
    margin: 0 auto;        /* Centra todo el bloque de contenido */
    padding: 20px;
}

article {
    background: rgba(45, 45, 45, 0.6); /* Fondo de caja semi-transparente */
    padding: 30px;         /* Espacio interno del cuadro */
    margin-bottom: 40px;   /* Espacio entre un cuadro y el siguiente */
    border-radius: 12px;   /* Bordes redondeados del cuadro */
    border-left: 5px solid #4db8ff; /* Línea azul a la izquierda para estilo profesional */
}

h2 {
    font-size: 1.8em;
    margin-bottom: 20px;
    color: #ffffff;        /* Títulos de sección en blanco */
}

h3 {
    font-size: 1.3em;
    color: #4db8ff;        /* Subtítulos en azul para jerarquía visual */
    margin: 20px 0 10px 0;
}

/*========== LISTAS Y SUB-LISTAS ==========*/
ul {
    list-style-type: none; /* Quita los puntos gordos de la lista principal */
    padding-left: 10px;
}

/* Estilo para las listas que están dentro de otras listas */
ul ul {
    list-style-type: circle; /* Usa círculos huecos para sub-puntos */
    padding-left: 30px;    /* Mueve la sub-lista a la derecha */
    margin-top: 5px;
}

li {
    margin-bottom: 10px;   /* Espacio entre cada punto de la lista */
}

/* Alineación de los párrafos que están dentro de una lista */
li p {
    text-align: left;      /* Fuerza el texto a la izquierda en los detalles técnicos */
    padding: 0;
    margin: 0;
    font-size: 1em;
}

/*========== ESTILOS DE ENLACES TÉCNICOS (TÉRMINOS) ==========*/
.tech-link {
    color: #4db8ff; /*Azul claro para destacar*/
    text-decoration: none; /*Sin subrayado por defecto*/
    font-weight: 600; /*Semi-negrita*/
    background: rgba(77, 184, 255, 0.1); /*Fondo azul semi-transparente*/
    padding: 2px 6px; /*Espaciado interno pequeño*/
    border-radius: 4px; /*Esquinas ligeramente redondeadas*/
    transition: all 0.3s ease; /*Animación suave*/
    cursor: pointer; /*Cambia cursor al pasar*/
    border-bottom: 2px solid #4db8ff; /*Línea punteada inferior*/
}

/*========== EFECTO AL PASAR SOBRE ENLACES TÉCNICOS ==========*/
.tech-link:hover {
    color: #ffffff; /*Texto blanco*/
    background: rgba(77, 184, 255, 0.25); /*Fondo más opaco*/
    box-shadow: 0 0 10px rgba(77, 184, 255, 0.3); /*Resplandor azul*/
    border-bottom: 2px solid #ffffff; /*Línea blanca*/
    text-decoration: none; /*Mantiene sin subrayado*/
    transform: translateY(-1px); /*Levanta ligeramente*/
}

/*========== FOOTER ==========*/
footer {
    text-align: center;
    padding: 60px 20px;
    color: #555;
    font-size: 0.9rem;
}

/*========== ESTILOS PARA LOS MODALES ==========*/

.modal-overlay {
    /* Fija el fondo para que no se mueva al hacer scroll */
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    
    /* Fondo oscuro semitransparente */
    background: rgba(0, 0, 0, 0.85);
    
    /* EFECTO BLUR (Desenfoque): 
       -webkit es necesario para que funcione en Safari y Chrome de iOS */
    -webkit-backdrop-filter: blur(10px); 
    backdrop-filter: blur(10px);
    
    /* CENTRADO CON FLEXBOX:
       Incluye prefijos para versiones antiguas de Chrome, Safari y Edge */
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; /* Centra horizontalmente */
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;     /* Centra verticalmente */
    
    /* Capa superior para que nada lo tape */
    z-index: 2000;
    
    /* ESTADO INICIAL: Oculto */
    opacity: 0;
    visibility: hidden;
    
    /* Transición suave al aparecer/desaparecer */
    -webkit-transition: all 0.4s ease;
    -o-transition: all 0.4s ease;
    transition: all 0.4s ease;
}

/* ACTIVACIÓN: Cuando el ID del modal está en la URL (ej: index.html#modal1) */
.modal-overlay:target {
    opacity: 1;
    visibility: visible;
}

.modal-box {
    background: #2d2d2d;
    padding: 35px;
    border-radius: 20px;
    max-width: 500px;
    width: 90%;
    position: relative; /* Para posicionar la "X" de cerrar dentro */
    
    /* Borde y resplandor azul */
    border: 1px solid rgba(77, 184, 255, 0.4);
    -webkit-box-shadow: 0 0 30px rgba(77, 184, 255, 0.2);
    box-shadow: 0 0 30px rgba(77, 184, 255, 0.2);
    
    /* ANIMACIÓN DE ENTRADA:
       Empieza un poco más pequeño (scale 0.8) */
    -webkit-transform: scale(0.8);
    -ms-transform: scale(0.8);
    transform: scale(0.8);
    
    /* Transición específica para la propiedad transform */
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    -o-transition: transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}

/* Cuando el modal se activa, la caja sube a su tamaño original (escala 1) */
.modal-overlay:target .modal-box {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
}

.modal-box h3 {
    margin-top: 0;
    color: #4db8ff;
    font-size: 1.6em;
}

.modal-box p {
    color: #e0e0e0;
    font-size: 1.1em;
    margin-top: 15px;
    line-height: 1.5; /* Mejora la legibilidad del texto */
}

/* BOTÓN CERRAR (La X) */
.modal-close {
    position: absolute;
    top: 15px;
    right: 20px;
    font-size: 32px;
    color: #ffffff;
    text-decoration: none; /* Quita el subrayado del enlace */
    line-height: 1;
    transition: 0.3s;
}

.modal-close:hover {
    color: #4db8ff; /* Cambia a azul al pasar el mouse */
}

/* IMAGEN DISPARADORA (La que abres al hacer clic) */
.img-modal {
    display: inline-block;
    width: 350px;
    height: 350px;
    max-width: 100%; /* Para que no se rompa en celulares */
    object-fit: cover; /* Asegura que la imagen no se deforme */
    cursor: pointer;
    
    /* Transición para el efecto hover */
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    -o-transition: transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}

.img-modal:hover {
    /* Un pequeño aumento para dar feedback visual sin pixelar */
    -webkit-transform: scale(1.05);
    -ms-transform: scale(1.05);
    transform: scale(1.05);
}