/* Estilos para el diseño de layout y componentes principales */

body {
  padding: 0;
  margin: 0;
  font-family: var(--font-family-base);
}

main {
  width: 100%;
  min-height: calc(100vh - var(--header-height) - var(--footer-height));
}

.center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.col {
  flex-direction: column;
}

section {
  padding: var(--spacing-xl) 0;
}

.titulo-productos {
    font-size: 3em; /* Ajustar tamaño para que sea más responsive */
    margin: 30px auto; /* Centrar y añadir margen vertical */
    text-align: center; /* Centrar el texto */
    width: 90%; /* Ancho más adaptable */
    max-width: 800px; /* Limitar ancho en pantallas grandes */
}

.contenedor-productos {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    width: 95%; /* Ancho ligeramente menor para margen */
    margin: 20px auto; /* Centrar el contenedor */
    gap: 20px; /* Espacio entre productos */
}

.producto {
    width: calc(25% - 20px); /* 4 productos por fila en desktop, ajusta según el gap */
    min-width: 200px; /* Ancho mínimo para evitar que se pongan demasiado pequeños */
    height: auto; /* Altura auto para que se adapte al contenido */
    margin: 0; /* Margin ya manejado por el gap del contenedor */
    padding: 15px;
    text-align: center;
    border: 1px solid #e0e0e0; /* Borde más sutil */
    border-radius: 8px; /* Más redondeado */
    background-color: #ffffff;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Sombra sutil */
    transition: transform 0.3s ease, box-shadow 0.3s ease; /* Transiciones para hover */
}

.producto:hover {
  transform: translateY(-5px); /* Efecto de elevación al pasar el ratón */
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2); /* Sombra más pronunciada al pasar el ratón */
}

.producto img {
    max-width: 80%; /* Asegurar que la imagen no se desborde */
    height: auto; /* Mantener la proporción */
    object-fit: contain; /* Ajustar la imagen dentro del contenedor */
    margin-bottom: 10px;
}

.producto h4 {
    margin-bottom: 8px;
    font-size: 1.1em; /* Ajustar tamaño de fuente */
    color: #333;
}

.producto p {
    margin-bottom: 12px;
    font-size: 0.9em;
    color: #666;
}

.producto button {
    background-color: #007bff; /* Azul primario */
    color: white;
    border: none;
    padding: 10px 20px;
    border-radius: 5px;
    cursor: pointer;
    font-size: 1em;
    transition: background-color 0.3s ease, transform 0.2s ease; /* Transiciones para hover */
}

.producto button.agregar:hover {
  background-color: #0056b3; /* Azul más oscuro al pasar el ratón */
  transform: translateY(-2px); /* Pequeña elevación */
}

.agregar {
  background-color: #007bff; /* Azul primario */
}

.agregar:hover {
  background-color: #0056b3; /* Azul más oscuro al pasar el ratón */
  opacity: 1; /* Asegurar opacidad completa */
}

.footer {
    background-color: #f8f8f8; /* Fondo más claro */
    padding: 40px 20px; /* Ajustar padding */
    display: flex;
    justify-content: space-around; /* Distribuir uniformemente */
    flex-wrap: wrap;
    border-top: 1px solid #e0e0e0; /* Borde más sutil */
    color: #555; /* Color de texto más suave */
  }
  
  .footer__links,
  .footer__contact,
  .footer__social {
    flex-basis: 28%; /* Ajustar para 3 columnas en desktop */
    margin-bottom: 20px;
    text-align: center; /* Centrar el texto en cada sección del footer */
  }
  
  .footer__links h3,
  .footer__contact h3,
  .footer__social h3 {
    margin-bottom: 15px;
    color: #333; /* Color de encabezado más oscuro */
    font-size: 1.2em;
  }
  
  .footer__links ul,
  .footer__contact ul,
  .footer__social ul {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  
  .footer__links ul li,
  .footer__contact ul li,
  .footer__social ul li {
    margin-bottom: 8px; /* Más espacio entre elementos de lista */
  }
  
  .footer__links a,
  .footer__contact a,
  .footer__social a {
    color: #555;
    text-decoration: none;
    transition: color 0.3s ease; /* Transición suave para hover */
  }
  
  .footer__links a:hover,
  .footer__contact a:hover,
  .footer__social a:hover {
    color: #007bff; /* Cambiar color al pasar el ratón */
    text-decoration: none; /* Mantener sin subrayado */
  }

/* Media queries para responsividad */
@media (max-width: 1024px) {
  .producto {
    width: calc(33.33% - 20px); /* 3 productos por fila en tablets */
  }
}

@media (max-width: 768px) {
  .producto {
    width: calc(50% - 20px); /* 2 productos por fila en tablets pequeñas */
  }
  .footer__links,
  .footer__contact,
  .footer__social {
    flex-basis: 48%; /* 2 columnas en tablets */
  }
}

@media (max-width: 480px) {
  .titulo-productos {
    font-size: 2em; /* Reducir tamaño de fuente en móviles */
  }
  .contenedor-productos {
    width: 100%;
    padding: 0 10px;
  }
  .producto {
    width: calc(100% - 20px); /* 1 producto por fila en móviles */
  }
  .footer__links,
  .footer__contact,
  .footer__social {
    flex-basis: 90%; /* 1 columna en móviles */
  }
  .footer {
    flex-direction: column;
    align-items: center;
  }
}

/*/*register/*/
.container-register {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background-color: #fff;
  padding: 5%;
  border-radius: 10px;
  margin: 0px 10%;
}

.container-register form div input {
  width: 100%;
}

.container-register form {
  border-radius: 10px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.699);
  padding: 40px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 70%;
}

.container-register button {
  background-color: blue;
    border: none;
    border-radius: 5px;
    color: #fff;
    cursor: pointer;
    font-size: 16px;
    padding: 10px;
    align-items: center;
    width: 50%;
}

.form-group {
  margin-bottom: 15px;
}

.register {
  width: 100%;
}

label {
  display: block;
  margin-bottom: 5px;
}

input:not([type="radio"]):not([type="checkbox"]) {
  width: 100%;
  padding: 10px;
  border: 1px solid #ccc;
  border-radius: 5px;
  box-sizing: border-box;
  margin-top: 5px;
}

.error-password {
  color: red;
  font-size: 12px;
}

button {
  color: white;
  padding: 10px 15px;
  border: none;
  border-radius: 5px;
  cursor: pointer;
}


/*producto.css*/
.a {
  text-decoration: none;
  color: white;
}



/*carrito/*


/* Estilos generales */
body {
  font-family: Arial, sans-serif;
  margin: 0;
  padding: 0;
  background-color: #f9f9f9; /* Color de fondo más suave */
  height: auto;
}

.fixed {
  position: fixed;
}

.cart {
  cursor: pointer;
}

/* Estilos para el contenedor de productos */
.products {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  margin: 20px 0;
}

.product {
  text-align: center;
  width: 200px;
  padding: 20px;
  margin: 10px;
  border: 1px solid #e2e2e2;
  border-radius: 8px; /* Bordes redondeados */
  background-color: #fff; /* Fondo blanco para los productos */
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); /* Sombra sutil */
}

/* Estilos para el carrito */
.cart-container {
  position: fixed;
  top: 0;
  right: 0;
  background-color: #fff;
  height: 100%;
  width: 300px;
  padding: 20px;
  box-shadow: -2px 0 5px rgba(0, 0, 0, 0.1);
  display: none; /* Cambiar a 'block' cuando se muestre el carrito */
  border-radius: 8px; /* Bordes redondeados */
}

/* Estilos para las imágenes del carrito */
.imgcarrito {
  width: auto;
  height: auto;
  max-width: 20vw;
  max-height: 20vh;
}

.mobileshow {
  display: none;
}

/* Estilos para el total */
.total {
  display: flex;
  width: 100%;
  flex-direction: row;
  justify-content: space-around;
  margin-top: 20px; /* Margen superior para separación */
}

.total p {
  font-size: 20px;
  font-weight: 800;
}

/* Estilos para el icono del carrito */
.carrito-icon {
  display: inline-block;
  margin-right: 5px;
}

.carrito-icon a img {
  width: 16px;
  height: 16px;
}

/* Estilos para la lista de productos en el carrito */
.cart-list {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #ddd;
}

.cart-list th,
.cart-list td {
  padding: 10px;
  text-align: center;
}

.cart-list tr:nth-child(even) {
  background-color: #f2f2f2; /* Color alterno para filas */
}

/* Estilos para los botones de cantidad */
.cart-list .quantity-btn {
  background-color: transparent;
  border: none;
  outline: none;
  padding: 5px;
  cursor: pointer;
}

.cart-list .quantity-btn:hover {
  opacity: 0.7; /* Efecto hover */
}

/* Estilos para el botón de pagar */
.pagar-btn {
  background-color: #4CAF50; /* Verde más atractivo */
  color: white;
  border: none;
  border-radius: 5px;
  padding: 10px 20px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 16px;
  margin: 4px 2px;
  cursor: pointer;
}


/* perfil */

.container {
  max-width: 800px;
  margin: 50px auto;
  padding: 40px;
  background-color: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

h1 {
  text-align: center;
  color: #333;
}

.user-info {
  margin-top: 20px;
}

.user-info p {
  font-size: 18px;
  color: #555;
}

.user-info strong {
  color: #000;
}


/*index*/
.mensaje {
  color: white;
  margin-top: 10px;
  top: 5%;
  padding: 10px 15px;
  position: fixed;
  background-color: rgb(0, 180, 0);
  border-radius: 10px;
  transition: opacity 0.5s ease; /* Transición suave para la opacidad */
  opacity: 1;
  z-index: 10;
}

.paginacion {
  display: flex;
  justify-content: center;
  align-items: center;
}


.paginacion button {
  background-color: blue;
  margin: 10px 20px;
}
