/* Estilos Globales */
* {
    box-sizing: border-box;
}

body {
    font-family: 'Roboto', sans-serif;
    background-color: #f4f4f4; 
    margin: 0;
    padding: 0;
    
}
/* Estilos del Header */
header {
    background: linear-gradient(to right, hsl(261, 71%, 77%), #4c1a85);
    color: white;
    padding: 1rem;
    text-align: center;
}

header h1 {
    font-size: 2rem;
    margin: 0;
}
/* Estilos de Navegación */
nav ul {
    list-style-type: none;
    padding: 0;
}

nav ul li {
    display: inline-block;
    margin: 0 15px;
    padding: 5px 10px; /* Espaciado alrededor del texto */
    border: 2px solid transparent; /* Borde inicial transparente */
    border-radius: 5px; /* Bordes redondeados */
    transition: background-color 0.3s, border-color 0.3s; /* Transición suave */
}

nav a {
    color: white;
    font-size: 18px;
    text-decoration: none;
}

nav ul li:hover {
    background-color: rgba(255, 255, 255, 0.226); /* Fondo al pasar el ratón */
    border-color: white; /* Cambiar color del borde al pasar el ratón */
}
/* Estilos del Main */
main {
background-image: url('../imagenes/fondo.jpeg');
background-size: cover;
padding: 20px;

}
/* Estilos de las Tarjetas */
.card-container {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
}

.card {
    background-color: white;
    border: 4px solid #9477a1;
    border-radius: 5px;
    padding: 15px;
    margin: 10px;
    width: 300px; /* Ancho fijo */
    height: 400px; /* Altura fija */
    display: flex;
    flex-direction: column; /* Para apilar los elementos verticalmente */
}

.card-info {
    flex-grow: 1; /* Permite que esta sección crezca */
    overflow-y: auto; /* Permite el desplazamiento si el contenido es demasiado grande */
}

.card img {
    width: 50%;
}

.card-actions {
   text-align: center; /* Centra los botones y el input */
   margin-top: auto; /* Empuja esta sección hacia abajo */
}

/* Estilo general para el contenedor del carrito */
#cart-items-container {
    display: flex;
    flex-direction: column; /* Asegura que los elementos se apilen verticalmente */
    margin: 0; /* Eliminar márgenes */
    padding: 10px; /* Espaciado interno */
}

/* Estilo para cada elemento del carrito */
.cart-item {
    display: flex; /* Usar flexbox para alinear elementos */
    align-items: center; /* Centrar verticalmente los elementos */
    margin-bottom: 10px; /* Espaciado entre productos */
    padding: 10px; /* Espaciado interno */
    background-color: #f8f8f8; /* Fondo claro para cada producto */
    border-radius: 5px; /* Bordes redondeados */
}

/* Estilo para la imagen del producto */
.cart-item img {
    width: 50px; /* Ancho fijo para las imágenes */
    height: auto; /* Mantener la proporción de la imagen */
    margin-right: 10px; /* Espacio entre la imagen y el texto */
}

/* Estilo para el título del producto */
.cart-item h5 {
    color: black; /* Cambiar el color del texto a blanco */
    margin: 0; /* Eliminar márgenes por defecto */
}

/* Estilo para los botones de acción */
.cart-actions {
    display: flex; /* Usar flexbox para alinear botones horizontalmente */
    align-items: center; /* Centrar verticalmente los botones */
    margin-left: auto; /* Empujar hacia la derecha para alinear con el margen izquierdo */
}

/* Estilo para los botones individuales */
.btn {
    margin-left: 5px; /* Espacio entre los botones */
}

/* Responsividad: ajustar en pantallas pequeñas */
@media (max-width: 600px) {
    .cart-item {
        flex-direction: column; /* Cambiar a columna en pantallas pequeñas */
        align-items: flex-start; /* Alinear a la izquierda */
        text-align: left; /* Alinear texto a la izquierda */
    }

    .cart-actions {
        width: 100%; /* Hacer que los botones ocupen todo el ancho disponible */
        justify-content: space-between; /* Espacio entre botones en móviles */
        margin-top: 5px; /* Espacio superior entre acciones y producto */
    }
}

/* Estilo para el contenedor de métodos de pago */
#payment-methods {
    background-color: white; /* Fondo blanco */
    color: black; /* Texto negro */
    padding: 20px; /* Espaciado interno */
    border-radius: 5px; /* Bordes redondeados */
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1); /* Sombra sutil */
}

/* Estilo para el título del método de pago */
#payment-methods h2 {
    color: #000;
    margin-top: 0; /* Eliminar margen superior */
}

/* Estilo para el botón de confirmar pago */
#confirm-payment {
    background-color: #612981; 
    color: white; 
    border: none;
    padding: 10px 15px; 
    cursor: pointer; /* Cambiar cursor al pasar sobre el botón */
}

#confirm-payment:hover {
    background-color:#4e1f61 ; /* Color más oscuro al pasar el mouse */
}

.car {
    color: black; /* Cambia el color del texto a negro */
}
.grid-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 15px;
   
}

.reseña {
    background-color: rgba(255, 255, 255, 0.8);
    padding: 15px;
    border: 4px solid #957fa7a1;
    border-radius: 5px;
    text-align: center;
    transition: transform 0.2s, box-shadow 0.2s;
    overflow-wrap: break-word; 
    word-wrap: break-word; 
    font-size: 16px;
}

.reseña:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

form {
    background-color: rgba(168, 128, 177, 0.719);
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 4px 20px rgb(253, 253, 253);
    max-width: 500px;
    margin: auto;
}

form label {
    display: block;
    margin: 10px 0 5px;
}

form input, form textarea {
    width: 100%;
    padding: 10px;
    margin-bottom: 10px;
    border: 4px solid #a78cb9;
    border-radius: 5px;
}
/* Estilos del Footer */
footer {
    text-align: center;
    padding: 10px 0;
    background-color: hsl(261, 71%, 77%);
    color: white;
    position: relative;
    bottom: 0;
    width: 100%;
}
footer nav a {
    font-size: 24px; 
    margin: 0 10px;
    transition: transform 0.2s; 
}

footer nav a:hover {
    transform: scale(1.1); 
}


html, body {
    height: 100%; 
    margin: 0;
}

.container {
    display: grid;
    grid-template-rows: auto 1fr auto;
    min-height: 100vh;
    border: 10px solid #ba35ee; 
    overflow-y: auto; 
    background: linear-gradient(to right, #dbb0e4, #32023b);
    padding: 20px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);  
}

h2 {
    text-align: center; 
    margin-bottom: 20px; 
    color: #f4f4f4;
}
.producto img {
    width: 100%; 
    height: 150px; 
    max-width: 200px; 
    border-radius: 5px; 
    object-fit: cover; 
}
.producto {
    background-color: white;
    border: 4px solid #b9a0bb;
    border-radius: 5px;
    padding: 10px;
    text-align: center;
    height: 300px;
}
p{color: #f3eeee;}
#productos p {
    color: #000000; 
}
/* Media Queries */
@media (max-width: 600px) {
    header h1 {
        font-size: 1.5rem;
        text-align: center;
    }

    h2 {
        font-size: 1.2rem;
        text-align: center;
    }
    nav ul {
        flex-direction: column;
        align-items: center;
        margin-bottom: 20px; 
        padding-left: 0; 
        display: flex;
        gap: 10px;
    }
    .card-container {
        flex-direction: column;
        align-items: center;
        padding-left: 0;
        margin-bottom: 20px; 
    }
    .card {
        width: 90%; /* Ancho más pequeño en pantallas pequeñas */
    }
    form {
        width: 90%; 
        margin: 10px;
        }
        .grid-container {
            grid-template-columns: 1fr; 
            gap: 10px; 
        }
    
    .reseña {
        font-size: 8px; 
        padding: 10px; 
        border-width: 3px; 
        margin-bottom: 10px; 
        text-align:left; 
        width: 100%;  
    }
    #productos-destacados h2, #reseñas h2 {
        font-size: 1.5rem;
        margin-top: 20px;
        }    
}
.terminos-privacidad {
    display: flex; /* flexbox para alinear los elementos */
    align-items: center; /* Centrar verticalmente */
}

.terminos-privacidad input[type="checkbox"] {
    margin-right: 10px; /* Espacio entre la casilla y el texto */
}

/*estilo para el boton*/
button {
    background-color: #612981; /* Color de fondo verde */
    color: white; /* Color del texto */
    border: none; /* Sin borde */
    padding: 5px 10px; /* Espaciado interno */
    text-align: center; /* Centrar el texto */
    text-decoration: none; /* Sin subrayado */
    display: inline-block; /* bloque en línea */
    font-size: 14px; /* Tamaño de fuente */
    margin: 10px 2px; /* Margen alrededor del botón */
    margin-top: 5px; /* Espacio entre los botones */
    cursor: pointer; /* Cambiar cursor al pasar por encima */
    border-radius: 5px; /* Bordes redondeados */
    transition: background-color 0.3s, transform 0.2s; /* Transición suave para el color de fondo y transformación */
}

button:hover {
    background-color: #b38bd8; /* Color de fondo más oscuro al pasar el ratón */
    transform: scale(1.05); /* Aumentar ligeramente el tamaño al pasar el ratón */
}

button:active {
    transform: scale(0.95); /* Disminuir el tamaño al hacer clic */
}

.carousel {
    position: relative;
    width: 80%;
    margin: auto;
    overflow: hidden;
}

.carousel-inner {
    display: flex;
    transition: transform 0.5s ease;
}

.carousel-item {
    min-width: 100%;
    box-sizing: border-box;
}

img {
    width: 100%; /* Asegura que la imagen ocupe todo el ancho del contenedor */
    height: auto; /* Mantiene la proporción de la imagen */
    object-fit: contain; /* Ajusta la imagen para encajar dentro del contenedor sin recortarse */
    max-height: 300px; /* Limita la altura máxima para evitar que se vea gigante */
}

/* Contenedor de botones centrado */
.button-container {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); /* Centra los botones */
    display: flex; /* Utiliza Flexbox para alinear los botones */
    justify-content: space-between; /* Espacio entre los botones */
    width: 100%; /* Ocupa todo el ancho del contenedor */
}
.prev {
    left: 10px;
    
}

.next {
    right: 10px;
}



/* estilo ubicacion */
.contenedorPrincipal {
    padding: 20px;
    margin: 0 auto;
    max-width: 800px; 
    text-align: center; 
}

.contenedorPrincipal h3 {
    font-size: 1.5em; 
    margin: 5px 0;
    color: #f4f4f4;
}
/* Map */
.mapa {
    width: 100%; 
    height: 300px;
    border: none; 
}

/* Media queries for responsiveness */
@media (max-width: 600px) {
    
    .contenedorPrincipal h3 {
        font-size: 1.2em; 
    }

    .mapa {
        height: 200px; 
    }
}
/* terminos y condiciones y privacidad*/
ul {
    margin-left: 20px;
    color: white; 
    background-color: transparent; 
}
li {
    color: white; 
    padding: 5px; 
    margin-bottom: 5px; 
}
/*Medios de Pago*/
#payment-methods {
    display: none; /* Ocultar inicialmente */
    border: 1px solid #ccc;
    padding: 15px;
    margin-top: 10px;
}
#buy-button {
    padding: 10px 15px;
    background-color: #c300ff;
    color: white;
    border: none;
    cursor: pointer;
}
#confirm-payment {
    margin-top: 10px;
    padding: 10px 15px;
    background-color: #c300ff;
    color: white;
    border: none;
    cursor: pointer;
}