html, body {
    height: 100%; /* Asegura que el html y el body ocupen el 100% de la altura de la ventana */
    margin: 0; /* Elimina el margen por defecto */
    font-family: 'Lexend'; /* Aplica la fuente Lexend al cuerpo */
}


body {
    display: flex;
    flex-direction: column; /* Organiza el contenido en columnas */
    background-image:url(./background.jpg) ;
    background-size: 110% auto;
    background-repeat: no-repeat;
    background-attachment: fixed;
    animation: moverFondo 10s ease-in-out infinite; /* Aplica la animación */
}

@keyframes moverFondo {
    0% {
        background-position: 0% center;
    }
    50% {
        background-position: 40% center; /* Mueve el fondo a la derecha */
    }
    100% {
        background-position: 0% center; /* Regresa a la posición inicial */
    }
}

.zoom-effect {
    width: 100%;
    height: 100%;
    position: absolute; /* Asegura que el efecto cubra todo el fondo */
    top: 0;
    left: 0;
    background-image: url(./background.jpg);
    background-size: cover;
    background-position: center;
    transition: transform 10s ease-in-out; /* Suaviza la transición */
}

body:hover .zoom-effect {
    transform: scale(1.05); /* Aumenta el tamaño al pasar el mouse */
}

main {
    flex: 1; /* Permite que el main ocupe el espacio restante */
    display: flex;
    flex-direction: column; /* Organiza las secciones en columnas */
}

title {
    margin: 0 0 20px; /* Espacio debajo del título */
}

header {
    background: #f60202b6;
    color: #fff;
    text-align: center;
}

.logo-container {
    display: flex;
    flex-wrap: wrap; /* Permite que los logos se envuelvan en lugar de desbordarse */
    justify-content: center; /* Centra los logos en el contenedor */
}

.left-logos, .right-logos {
    display: flex;
    justify-content: center; /* Centra los logos dentro de cada contenedor */
    align-items: center;
    margin: 5px; /* Espacio entre los contenedores de logos */
}

.logo {
    width: 100%; /* Cambia a 100% para que se ajuste al contenedor */
    max-width: 170px; /* Mantiene un tamaño máximo */
    height: auto; /* Mantiene la proporción de aspecto */
    margin: 0 10px; /* Espacio entre los logos */
}

/* Media Queries para Responsividad */
@media (max-width: 768px) {
    .logo {
        max-width: 120px; /* Reduce el tamaño máximo en pantallas más pequeñas */
    }
}

@media (max-width: 480px) {
    .logo {
        max-width: 80px; /* Reduce aún más el tamaño en pantallas muy pequeñas */
    }
}

nav {
    text-align: center; /* Centra el contenido del nav */
}

nav ul {
    list-style: none;
    margin-top: 10px;
}

nav ul li {
    display: inline;
    margin: 0 15px;
}

nav ul li a {
    color: #fff; /* Color del texto por defecto */
    text-decoration: none; /* Sin subrayado */
    transition: color 0.3s ease, font-size 0.3s ease; /* Transición suave para el color y el tamaño de fuente */
    font-size: 20px; /* Tamaño de fuente por defecto */
}

nav ul li a:hover {
    font-size: 22px; /* Aumenta el tamaño de fuente al pasar el mouse */
}

p{
    color: #ffffff;
    text-align: center; 
    margin-left: 150px;
    margin-right: 150px;
    font-size: 17px; /* Tamaño de fuente por defecto */
}

li {
    color: #ffffff;
    text-align: left; 
    margin-left: 500px;
    font-size: 17px; /* Tamaño de fuente por defecto */
}

h1 {    
    margin: 0; /* Elimina márgenes para evitar desplazamientos */
    padding-top: 10px;
    font-size: 40px; /* Tamaño de fuente por defecto */
    text-align: center;
    color: #ffffff;
    text-decoration: underline;

}

h2,h3 {
    margin: 0; /* Elimina márgenes para evitar desplazamientos */
    padding: 15px 0; /* Espacio interno para los encabezados */
    text-align: center;
    color: #ffffff;
    font-size: 25px; /* Tamaño de fuente por defecto */
    text-decoration: underline;
}

.proyecto {
    position: relative; /* Para que las flechas se posicionen correctamente */
    width: 100%; /* Asegúrate de que el contenedor tenga el ancho correcto */
    overflow-x: hidden; /* Hides overflow */
}

.carrousel {
    display: flex; /* Alineamos los media-containers en fila */
    transition: transform 0.5s ease; /* Animación suave para el desplazamiento */
}

.media-container {
    flex: 0 0 33.33%; /* Cada contenedor ocupa un tercio del ancho */
    max-width: 33.33%; /* Máximo ancho */
    transition: transform 0.5s ease; /* Agrega una transición suave */
    display: flex; /* Asegúrate de que el contenedor use flexbox */
    justify-content: center; /* Centra el contenido dentro del contenedor */
    align-items: center; /* Alinea verticalmente el contenido */
    position: relative; /* Asegura que los elementos dentro se posicionen correctamente */
}


.media-container .imagen {
    width: 100%; /* Asegura que la imagen llene el contenedor */
    height: 100%; /* Asegura que la imagen llene el contenedor */
    object-fit: contain; /* Mantiene la proporción de aspecto y cubre el área */
}

.media-container .video {
    width: 100%; /* Asegura que el video llene el contenedor */
    height: 100%; /* Asegura que el video llene el contenedor */
    object-fit: contain; /* Mantiene la proporción de aspecto y cubre el área */
    position: absolute; /* Asegura que el video esté en la misma posición que la imagen */
    top: 0;
    left: 0;
    opacity: 0; /* Inicialmente oculto */
    transition: opacity 0.3s ease; /* Transición suave para la opacidad */
}

.media-container:hover .imagen {
    opacity: 0; /* Oculta la imagen al pasar el mouse */
}

.media-container:hover .video {
    opacity: 1; /* Muestra el video al pasar el mouse */
    pointer-events: auto; /* Permite que el mouse interactúe con el video */
}

.arrow {
    cursor: pointer;
    font-size: 30px;
    position: absolute; /* Fijas dentro del contenedor proyecto */
    top: 50%;
    transform: translateY(-50%);
    z-index: 100;
    color: #ffffff;
    background-color: rgba(0, 0, 0, 0.5); /* Fondo semitransparente para visibilidad */
    padding: 10px;
    border-radius: 20%; /* Estilo circular */
}

.left-arrow {
    left: 10px; /* Posición de la flecha izquierda */
}

.right-arrow {
    right: 10px; /* Posición de la flecha derecha */
}

.skills {
    max-width: 800px;
    margin: auto;
}

.skill {
    display: flex; /* Usar flexbox para alinear el logo y el texto */
    align-items: center; /* Centrar verticalmente */
    margin-bottom: 20px;
}

.skill-logo {
    width: 30px;
    height: 30px;
    margin-right: 10px;
}


.progress-bar {
    background-color: #f0f0f0; /* Color de fondo claro */
    border-radius: 10px; /* Bordes más redondeados */
    height: 15px; /* Barra más delgada */
    flex-grow: 1; /* Hacer que la barra de progreso ocupe el espacio restante */
    margin-left: 10px; /* Espacio entre el texto y la barra de progreso */
}

.progress {
    height: 100%;
    background-color: #4caf50; /* Verde */
    width: 0; /* Cambia esto con JavaScript si es necesario */
    transition: width 0.5s ease; /* Transición más rápida */
    border-radius: 10px; /* Bordes redondeados */
}

span {
    color: #ffffff;
    width: 150px; /* Ajusta el ancho aquí */
    flex-shrink: 0; /* Evita que el span se reduzca */
}

footer {
    text-align: center;
    padding: 10px 0;
    background: #f60202b6;
    color: #fff;
}

.social-icons {
    list-style: none; /* Quitar los puntos de la lista */
    padding: 0; /* Quitar el padding de la lista */
}

.social-icons li {
    display: inline-block; /* Cambiar a inline-block para evitar el espacio extra */
    margin: 0 50px; /* Espaciado entre iconos (ajusta según sea necesario) */
}

.social-icons img {
    width: 70px; /* Ajusta el tamaño del logo aquí */
    height: 70px; /* Establece una altura fija para todos los logos */
}