* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body, html {
    margin: 0;
    padding: 0;
    height: 100%;
    overflow-x: hidden;
    font-family: 'Fira Code', monospace; /* Aplica Fira Code a todo el cuerpo */
}

h1, h2, h3, p {
    font-family: 'Fira Code', monospace; /* Aplica Fira Code a elementos específicos */
}

/* Estilos para el header */
header {
    background-color: rgba(0, 0, 0, 0); /* Fondo completamente transparente */
    padding: 5px;
    color: #fff;
    position: fixed; /* Mantiene el header en la parte superior */
    width: 100%;
    top: 0;
    left: 0;
    z-index: 10;
    transition: transform 0.3s ease; /* Transición para suavizar el ocultamiento/mostrado */
}

nav {
    text-align: left; /* Alinea el contenido del nav a la izquierda */
    margin-left: 20px; /* Margen izquierdo para separar del borde */
    margin-top: 20px; /* Margen superior para mover los botones hacia abajo */
}

nav ul {
    list-style: none;
    display: flex; /* Alinea los elementos de la lista en una línea */
    padding: 0; /* Elimina el padding de la lista */
    margin: 0; /* Elimina el margen de la lista */
}

nav ul li {
    margin-right: 20px; /* Espacio entre los enlaces */
}

nav ul li a {
    color: #fff;
    text-decoration: none;
    font-weight: bold;
}


#ctf-maquinas {
    background: #121212; /* Fondo negro */
    color: #f0f0f0; /* Texto claro */
    padding: 60px 20px;
    text-align: center;
}

/* Título principal */
#ctf-maquinas h2 {
    font-size: 2.5rem;
    color: #ff9800; /* Naranja vibrante */
    margin-bottom: 20px;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.7);
}

/* Cada plataforma (VulnHub, TryHackMe, etc.) */
.ctf-plataforma {
    margin-top: 40px;
}

.ctf-plataforma h3 {
    font-size: 2rem;
    color: #00bcd4; /* Azul cian para diferenciar secciones */
    border-bottom: 2px solid #ff9800;
    padding-bottom: 5px;
    display: inline-block;
    margin-bottom: 20px;
}

/* Diseño de la cuadrícula de máquinas */
.projects-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px;
}

/* Tarjetas de cada máquina */
.project-item {
    background: #1e1e1e; /* Fondo gris oscuro */
    border: 1px solid #333;
    border-radius: 8px;
    padding: 20px;
    box-shadow: 0 4px 6px rgba(255, 255, 255, 0.1);
    transition: all 0.3s ease;
}

.project-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 12px rgba(255, 255, 255, 0.2);
}

/* Títulos de las máquinas */
.project-item h3 {
    color: #ff9800;
    margin-bottom: 10px;
    font-size: 1.4rem;
}

/* Descripción de las máquinas */
.project-item p {
    color: #d0d0d0;
    font-size: 1rem;
    line-height: 1.5;
}

/* Estilo para los botones */
.project-item a {
    display: inline-block;
    margin-top: 10px;
    padding: 10px 15px;
    font-size: 1rem;
    font-weight: bold;
    color: #121212;
    background: #ff9800;
    border: none;
    border-radius: 5px;
    text-decoration: none;
    transition: all 0.3s ease;
}

.project-item a:hover {
    background: #ff5722;
    color: #fff;
    transform: translateY(-3px);
    box-shadow: 0 4px 10px rgba(255, 87, 34, 0.5);
}

/* Estilos para la parte de contactos */
#social-media {
    padding: 50px;
    background-color: #222; /* Fondo oscuro para la sección */
    color: #f9f9f9; /* Color del texto claro */
    text-align: center;
}

#social-media h3 {
    margin-bottom: 20px;
    font-size: 1.8em;
    color: #f9f9f9; /* Color del texto del encabezado claro */
}

.social-icons {
    display: flex;
    justify-content: center;
    gap: 20px; /* Espacio entre los iconos */
}

.social-icon {
    color: #f9f9f9; /* Color de los iconos */
    font-size: 2em; /* Tamaño de los iconos */
    transition: color 0.3s ease-in-out; /* Efecto de transición */
}

.social-icon:hover {
    color: #f7c600; /* Color amarillo al pasar el cursor */
}



/* Estilos para el footer */
footer {
    position: relative;
    background-color: #282828;
    color: #fff;
    padding: 20px 0; /* Ajusta el padding superior e inferior */
    overflow: hidden; /* Asegúrate de que el efecto no se desborde */
}

/* Asegúrate de que el texto esté encima del efecto */
footer .container {
    position: relative;
    z-index: 2;
}

/* Estilos para el contenedor de las olas */
.wave-container {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 120px; /* Ajusta la altura de la ola */
    overflow: hidden;
    z-index: 1; /* Asegúrate de que el efecto esté detrás del contenido */
}

/* Efecto de olas */
.wave {
    position: absolute;
    left: 50%;
    width: 200%;
    height: 100px; /* Por aquí puedo ajustar la altura de la ola */
    background: linear-gradient(to right, rgba(180, 170, 26, 0.893) 0%, rgba(200, 161, 35, 0.938) 50%, rgb(192, 184, 34) 100%);
    border-radius: 50%;
    transform: translateX(-50%);
    animation: wave 10s linear infinite;
}

.wave.wave2 {
    height: 150px; /* Mayor altura para olas más pronunciadas */
    background: linear-gradient(to right, rgba(210, 193, 26, 0.982) 0%, rgba(200, 185, 29, 0.776) 50%, rgba(200, 196, 34, 0.2) 100%);
    animation: wave 15s linear infinite;
}

@keyframes wave {
    0% {
        transform: translateX(-50%) translateY(0);
    }
    50% {
        transform: translateX(-50%) translateY(20px); /* Mayor desplazamiento vertical para olas más pronunciadas */
    }
    100% {
        transform: translateX(-50%) translateY(0);
    }
}

/* Estilos para alinear el texto y los íconos */
footer .row {
    display: flex;
    align-items: center;
    justify-content: space-between; 
    position: relative;
    z-index: 2;
    text-align: center; /* Centra el texto dentro de cada columna */
}

footer .col-4 {
    display: flex;
    align-items: center;
    justify-content: center; /* Centra el contenido dentro de cada columna */
}

footer .text-start {
    text-align: left;
    flex: 1; /* Ocupa el espacio disponible a la izquierda */
    padding-left: 20px; /* Espacio adicional a la izquierda */
}

footer .text-end {
    text-align: right;
    flex: 1; /* Ocupa el espacio disponible a la derecha */
    padding-right: 20px; /* Espacio adicional a la derecha */
}

footer .text-center {
    text-align: center;
    flex: 1; /* Ocupa el espacio central */
}

footer .text-center i {
    margin: 0 10px; /* Espacio entre los íconos */
}

/* Opcional: Estilos para los íconos en el footer */
footer i {
    font-size: 1.5em;
    color: #fff; /* Color blanco para los íconos */
}

@media (max-width: 768px) {
    nav {
        justify-content: space-around; /* Espaciar los elementos de navegación */
    }
    
    ul {
        display: flex; /* Asegura que los elementos estén en una fila */
        flex-direction: row; /* Asegurar que los elementos estén en fila */
        justify-content: center; /* Centrar elementos en la fila */
        padding: 0; /* Eliminar el padding predeterminado de la lista */
        margin: 0; /* Eliminar el margen predeterminado de la lista */
        list-style-type: none; /* Eliminar los puntos de la lista */
    }
    
    li {
        flex: 1; /* Hacer que cada elemento ocupe espacio igual */
        font-size: 0.6rem; /* Ajusta este valor según el tamaño deseado */
        white-space: nowrap; /* Evitar saltos de línea en los elementos */
    }

    .principal-contenido {
        padding: 0px; /* Espaciado interno para evitar que el contenido toque los bordes */
        text-align: center; /* Centrar el texto */
        background-color: #22222200; /* Fondo oscuro elegante */
        color: #f0f0f0; /* Texto claro para mejorar legibilidad */
        margin: 10px auto; /* Margen automático para centrar el div */
        
    }
    
    .principal-contenido h1 {
        font-size: 2rem; /* Tamaño del encabezado */
        margin-bottom: 10px; /* Espacio debajo del encabezado */
    }
    
    .principal-contenido h2 {
        font-size: 1.3rem; /* Tamaño del subtítulo */
        margin-bottom: 15px; /* Espacio debajo del subtítulo */
    }
    
    .principal-contenido p {
        font-size: 1rem; /* Tamaño del texto */
        margin-bottom: 20px; /* Espacio debajo del párrafo */
    }
    
    .principal-contenido .cta-button {
        font-size: 1.1rem; /* Tamaño del botón */
        padding: 12px 20px; /* Espaciado interno del botón */
        background-color: #f0db4f; /* Color del botón */
        color: #333; /* Color del texto del botón */
        border: none; /* Sin borde para un estilo minimalista */
        border-radius: 5px; /* Bordes redondeados para el botón */
        text-decoration: none; /* Eliminar subrayado en el enlace */
        display: inline-block; /* Hacer que el botón sea en línea pero como bloque */
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2); /* Sombra suave para el botón */
        transition: background-color 0.3s ease; /* Transición suave al interactuar */
    }
    
    .principal-contenido .cta-button:hover {
        background-color: #e8c547; /* Cambiar el color en hover para interacción */
        color: #222; /* Color del texto en hover */
    }
    



    .skills-grid {
        display: flex;
        flex-direction: column; /* Coloca los elementos en columna */
        align-items: center; /* Centra los elementos */
    }

    .skill-item {
        width: 90%; /* Ajusta el ancho de los elementos */
        margin: 10px 0; /* Espaciado entre habilidades */
    }

    .projects-grid {
        display: flex;
        flex-direction: column; /* Coloca los proyectos en columna */
        align-items: center; /* Centra los elementos */
    }

    .project-item {
        width: 90%; /* Ajusta el ancho de los proyectos */
        margin: 10px 0; /* Espaciado entre proyectos */
    }


    #sobre-mi {
        padding: 20px;
        background-color: #222; /* Fondo oscuro elegante */
        color: #f0f0f0; /* Texto claro para mejorar legibilidad */
        text-align: center; /* Centrar todo el texto */
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Sombra sutil para darle profundidad */
        max-width: 100%; /* Asegurar que no se desborde en móviles */
        margin: 0; /* Eliminar márgenes superior e inferior */
    }
    
    #sobre-mi h2 {
        font-size: 1.8rem; /* Ajustar el tamaño del encabezado */
        margin-bottom: 15px; /* Añadir espacio debajo del título */
        color: #ffffff; /* Color amarillo suave que resalta */
    }
    
    #sobre-mi p {
        font-size: 1.1rem; /* Ajustar el tamaño del texto */
        margin-bottom: 15px; /* Espaciado entre los párrafos */
        line-height: 1.6; /* Mejorar la legibilidad aumentando el espacio entre líneas */
    }
    
    #sobre-mi .cta-button {
        font-size: 1.2rem;
        padding: 12px 20px; /* Botón más grande y cómodo de tocar */
        background-color: #f0db4f; /* Botón amarillo destacado */
        color: #333; /* Texto oscuro en el botón */
        border: none; /* Sin borde para un estilo minimalista */
        border-radius: 5px; /* Bordes redondeados para el botón */
        text-decoration: none; /* Eliminar subrayado en el enlace */
        display: inline-block; /* Botón en línea pero bloque */
        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2); /* Sombra suave para destacar */
        transition: background-color 0.3s ease; /* Transición suave al interactuar */
        margin-top: 20px; /* Espacio entre el botón y el contenido anterior */
    }
    
    #sobre-mi .cta-button:hover {
        background-color: #e8c547; /* Cambiar el color en hover para interacción */
        color: #222; /* Color del texto en hover */
    }
    
    

    #servicios {
        display: none;
    }

    

    .visible-images img {
        width: 60px; /* Tamaño de las imágenes en móviles pequeños */
        height: auto; /* Mantener la relación de aspecto */
    }

    #seccion-galeria {
        padding: 10px; /* Reducir espaciado interno en móviles pequeños */
    }


}
