* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
body {
    font-family: Arial, sans-serif;
    background-color: #e0f2e9; /* Color de fondo suave (verde claro) */
    color: #000000; /* Color del texto */
    width: 100%; /* Asegura que el header ocupe el 100% del ancho */
}
.header {
    background: linear-gradient( #00ff08, #4caf50);
    padding: 1rem;
    color: white; /* Color del texto en el header */
}
.header-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%; /* Asegura que el contenedor ocupe el 100% */
    padding: 0 2rem; /* Espacio a los lados */
}
.logo h1 {
    font-size: 25px;
    color: white; /* Asegúrate de que el logo también sea blanco */
}
.logo {
    display: flex; /* Alinea el texto y la imagen en fila */
    align-items: center; /* Centra verticalmente */
}
.logo img {
    width: 80px; /* Ajusta el tamaño del logo aquí */
    height: auto; /* Mantiene la relación de aspecto */
}
.search-bar {
    display: flex; /* Usar flexbox para alinear el input y el botón */
    align-items: center; /* Centrar verticalmente el contenido */
    flex-grow: 1; /* Permite que la barra de búsqueda crezca para ocupar el espacio */
    margin: 0 1rem; /* Espacio a los lados para evitar que se pegue a otros elementos */
}
.search-bar input {
    padding: 0.5rem;
    font-size: 1rem;
    border: 1px solid #ccc; /* Borde del input */
    border-radius: 4px 0 0 4px; /* Esquinas redondeadas en el lado izquierdo */
    flex-grow: 1; /* Permite que el input crezca para ocupar el espacio disponible */
    outline: none; /* Elimina el borde al hacer clic */
}
.search-bar button {
    padding: 0.5rem 1rem;
    background-color: #66bb6a; /* Color del botón (verde claro) */
    border: none;
    color: white; /* Color del texto en el botón */
    cursor: pointer;
    border-radius: 0 4px 4px 0; /* Esquinas redondeadas en el lado derecho */
}
.user-options {
    display: flex; /* Alinea los elementos en línea */
    align-items: center; /* Alinea verticalmente los elementos */
}
.carro {
    display: flex; /* Asegura que el contenido dentro del enlace esté alineado */
    align-items: center; /* Alinea verticalmente los elementos dentro del enlace */
    margin-left: 15px; /* Espacio a la izquierda para separar del texto 'Iniciar sesión' */
}
.carro img {
    width: 24px; /* Ajusta el tamaño del ícono aquí */
    height: auto; /* Mantiene la relación de aspecto */
    margin-left: 5px; /* Espacio entre el texto y el ícono */
}
.user-options {
    margin-left: 1rem;
    display: flex; /* Alinea los elementos en línea */
    align-items: center; /* Alinea verticalmente los elementos */
}
.user-options a {
    color: white; /* Cambia el color del texto de los enlaces a blanco */
    text-decoration: none; /* Elimina el subrayado */
    margin-left: 1rem; /* Espacio entre "Iniciar sesión" y el carro */
}
.navbar {
    background-color: #4caf50; /* Color de fondo de la barra de navegación (verde más oscuro) */
}
.navbar ul {
    list-style: none; /* Elimina los puntos de la lista */
    display: flex; /* Usa flexbox para alinear los elementos horizontalmente */
    justify-content: center; /* Centra los elementos en la barra */
    padding: 1rem; /* Espaciado alrededor de la lista */
}
.navbar ul li {
    margin: 0 1rem; /* Margen a los lados de cada elemento de la lista */
}
.navbar ul li a {
    color: white; /* Cambia el color del texto a blanco */
    text-decoration: none; /* Elimina el subrayado */
    font-size: 1rem; /* Tamaño de la fuente */
}
.producto img {
    width: 200px;
    height: auto;
    margin-left: 5%;
}
.producto img {
    max-width: 100%;
    object-fit: cover; /* Hace que la imagen se ajuste sin deformarse */
    border-radius: 8px;
    border-radius: 8px;
}
.title h2 {
    text-align: center;
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 1em;
}
.product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 1.5em;
    margin: 5px;
    width: 100%; /* Asegura que ocupe el ancho completo dentro del contenedor */
}
.producto {
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 1em;
    text-align: center;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    width: 100%;
    height: 470px; /* Tamaño fijo para cada producto */
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
}
.producto h3 {
    padding: 4px;
}
.buy-button {
    display: inline-block;
    padding: 0.5em 1em;
    background-color: #28a745;
    color: #fff;
    text-decoration: none;
    border-radius: 4px;
}
.precio {
    padding: 8px;
}
.product-container {
    display: flex;
    justify-content: center;
    padding: 2rem; /* Espaciado alrededor del contenedor */
}
/* Pie de página */
.footer {
    background-color: #388e3c; /* Color de fondo del pie de página (verde medio) */
    color: white;
    padding: 1rem;
    text-align: center;
}

.footer-container a {
    color: #000000; /* Color del enlace en el pie de página (se deja igual) */
    text-decoration: none;
    margin: 0 0.5rem;
}

@media (max-width: 768px) {
    .header-container {
        flex-direction: column;
        align-items: flex-start;
    }

    .search-bar {
        flex-grow: unset;
        width: 100%;
    }

    .navbar ul {
        flex-direction: column;
        align-items: center;
    }
    .navbar ul li {
        margin: 0.5rem 0;
        
    }
    .product-grid {
        grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); /* Reduce el ancho mínimo */
        gap: 1rem; /* Espacio más pequeño entre productos */
    }

    .producto {
        padding: 0.8em; /* Reduce el padding */
        height: auto; /* Deja que la altura sea flexible */
    }

    .producto img {
        width: 80%; /* Reduce las imágenes en pantallas pequeñas */
    }

    .footer {
        text-align: center;
        padding: 1rem 0.5rem; /* Reduce los márgenes en móviles */
    }


}

@media (max-width: 480px) {
    .header-container {
        gap: 0.5rem;
    }

    .logo img {
        width: 50px;
    }

    .search-bar input {
        font-size: 0.9rem;
    }

    .search-bar button {
        padding: 0.5rem;
    }

    .product-card {
        padding: 0.5rem;
    }

    .product-card h3 {
        font-size: 1rem;
    }

    .navbar ul li {
        margin: 0.5rem 0; /* Reduce el espacio entre enlaces */
    }

    .search-bar input {
        font-size: 0.8rem; /* Ajusta el tamaño de fuente del input */
    }

    .buy-button {
        font-size: 0.8rem; /* Reduce el tamaño del botón */
        padding: 0.4em 0.8em; /* Menor padding en el botón */
    }

    .producto h3 {
        font-size: 0.9rem; /* Reduce el tamaño del título */
    }

    .precio {
        font-size: 0.9rem; /* Ajusta el tamaño del precio */
    }
}
