/* Styles pour boutique.html et pages produits (product-*.html) */

/* Shop Content */
.shop-content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
  background: linear-gradient(90deg, rgba(184, 115, 51, 0.1), rgba(107, 62, 117, 0.1), rgba(42, 75, 61, 0.1));
  border-radius: 8px;
}

/* Titre et Icône */
.shop-content h1 {
  font-family: 'Playfair Display', serif;
  color: #6B3E75;
  font-size: 36px;
  text-align: center;
  margin-bottom: 10px;
}
.title-icon {
  display: block;
  margin: 0 auto 20px;
  width: 60px;
  height: 60px;
  filter: sepia(100%) hue-rotate(15deg) saturate(600%) brightness(90%) contrast(150%) !important; /* Cuivre #B87333 */
}

/* Sous-titre */
.shop-subtitle {
  text-align: center;
  margin-bottom: 30px;
}
.shop-subtitle p {
  font-family: 'Montserrat', sans-serif;
  color: #2A4B3D;
  font-size: 18px;
  line-height: 1.8;
  margin: 8px 0;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

/* Philtres */
.shop-philtres, .product-philtres {
  margin-bottom: 60px; /* Espacement accru */
}
.shop-philtres h2, .product-philtres h2 {
  font-family: 'Cinzel', serif;
  color: #2A4B3D;
  font-size: 22px;
  margin: 10px 0;
  text-align: center;
}
.philtres-buttons {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}
.philtres-button {
  background: linear-gradient(90deg, #B87333, #6B3E75);
  color: #F5E8D3;
  font-family: 'Cinzel', serif;
  font-weight: bold;
  padding: 8px 16px;
  border: none;
  border-radius: 5px;
  cursor: pointer;
}
.philtres-button:hover, .philtres-button.active {
  background: linear-gradient(90deg, #6B3E75, #B87333);
  transform: scale(1.05);
}

/* Grille Produits (boutique.html) */
.shop-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); /* Ajusté pour éviter débordement */
  gap: 10px;
  overflow-x: auto;
}
.shop-grid.publications {
  margin-bottom: 40px; /* Espacement avant titre Goodies */
}
.shop-grid.goodies h2 {
  margin-top: 60px; /* Espacement accru avant titre Goodies */
  margin-bottom: 20px; /* Espacement avant encarts Goodies */
}
.shop-grid h2 {
  font-family: 'Cinzel', serif;
  color: #2A4B3D;
  font-size: 22px;
  text-align: center;
  margin: 30px 0 15px;
  margin-left: auto;
  margin-right: auto;
}
.shop-item {
  background: rgba(107, 62, 117, 0.1);
  padding: 15px;
  border-radius: 8px;
  border: 1px solid #B87333;
  text-align: center;
  min-height: 400px;
  min-width: 260px; /* Réduit pour éviter débordement */
  transition: transform 0.3s ease;
}
.shop-item:hover {
  transform: scale(1.03);
}
.shop-item .item-image {
  width: 100%;
  max-height: 200px;
  object-fit: contain;
  border-radius: 8px;
  margin-bottom: 12px;
}
.shop-item h3 {
  font-family: 'Cinzel', serif;
  color: #2A4B3D;
  font-size: 18px;
  margin-bottom: 8px;
}
.shop-item .item-description {
  font-family: 'Montserrat', sans-serif;
  color: #2A4B3D;
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 12px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.shop-item .item-collection {
  font-family: 'Montserrat', sans-serif;
  color: #6B3E75;
  font-size: 12px;
  font-style: italic;
  margin-bottom: 12px;
}
.shop-item .item-availability {
  font-family: 'Montserrat', sans-serif;
  color: #6B3E75;
  font-size: 12px;
  font-style: italic;
  margin-bottom: 12px;
}
.shop-item .action-button {
  background: linear-gradient(90deg, #B87333, #6B3E75);
  color: #F5E8D3;
  font-family: 'Cinzel', serif;
  font-weight: bold;
  padding: 10px 20px;
  border-radius: 5px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 5px;
}
.shop-item .action-button:hover {
  background: linear-gradient(90deg, #6B3E75, #B87333);
  transform: scale(1.05);
}
.shop-item .button-icon {
  width: 20px;
  height: 20px;
  filter: sepia(100%) hue-rotate(20deg) saturate(50%) brightness(170%) contrast(110%) !important; /* Crème #F5E8D3 */
}

/* Styles pour pages produits (product-*.html) */
.product-content {
  max-width: 800px;
  margin: 0 auto;
  padding: 20px;
  background: rgba(107, 62, 117, 0.1);
  border-radius: 8px;
}
.product-content .product-image {
  display: block;
  margin: 0 auto 20px;
  max-height: 300px;
  object-fit: contain;
  border-radius: 8px;
}
.product-content h1 {
  font-family: 'Playfair Display', serif;
  color: #6B3E75;
  font-size: 32px;
  text-align: center;
  margin-bottom: 15px;
}
.product-content .product-meta {
  font-family: 'Montserrat', sans-serif;
  color: #6B3E75;
  font-size: 14px;
  font-style: italic;
  text-align: center;
  margin-bottom: 20px;
}
.product-content .product-description {
  margin-bottom: 20px;
}
.product-content .product-description p {
  font-family: 'Montserrat', sans-serif;
  color: #2A4B3D;
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 15px;
}
.product-content .product-description ul {
  font-family: 'Montserrat', sans-serif;
  color: #2A4B3D;
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 15px;
  padding-left: 20px;
}
.product-content .product-description ul li {
  margin-bottom: 10px;
}
.product-content .action-button {
  background: linear-gradient(90deg, #B87333, #6B3E75);
  color: #F5E8D3;
  font-family: 'Cinzel', serif;
  font-weight: bold;
  padding: 12px 24px;
  border-radius: 5px;
  text-decoration: none;
  display: block;
  margin: 0 auto 20px;
  text-align: center;
  align-items: center;
  gap: 8px;
}
.product-content .action-button:hover {
  background: linear-gradient(90deg, #6B3E75, #B87333);
  transform: scale(1.05);
}
.product-content .button-icon {
  width: 20px;
  height: 20px;
  filter: sepia(100%) hue-rotate(20deg) saturate(50%) brightness(170%) contrast(110%) !important; /* Crème #F5E8D3 */
}
.product-social {
  margin: 20px 0;
  text-align: center;
}
.product-social h3 {
  font-family: 'Cinzel', serif;
  color: #2A4B3D;
  font-size: 18px;
  margin-bottom: 10px;
}
.product-social ul {
  display: flex;
  justify-content: center;
  gap: 15px;
  padding: 0;
}
.product-social .social-icon {
  width: 24px;
  height: 24px;
}
.product-carousel {
  margin: 20px 0;
}
.product-carousel h2 {
  font-family: 'Cinzel', serif;
  color: #2A4B3D;
  font-size: 20px;
  text-align: center;
  margin-bottom: 15px;
}
.carousel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 15px;
}
.carousel-item {
  background: rgba(107, 62, 117, 0.1);
  padding: 15px;
  border-radius: 8px;
  border: 1px solid #B87333;
  text-align: center;
}
.carousel-item .item-image {
  width: 100%;
  max-height: 150px;
  object-fit: contain;
  border-radius: 8px;
  margin-bottom: 12px;
}
.carousel-item h3 {
  font-family: 'Cinzel', serif;
  color: #2A4B3D;
  font-size: 16px;
  margin-bottom: 8px;
}
.carousel-item .item-description {
  font-family: 'Montserrat', sans-serif;
  color: #2A4B3D;
  font-size: 12px;
  line-height: 1.6;
  margin-bottom: 10px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.carousel-item .action-button {
  background: linear-gradient(90deg, #B87333, #6B3E75);
  color: #F5E8D3;
  font-family: 'Cinzel', serif;
  font-weight: bold;
  padding: 10px 20px;
  border-radius: 5px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.carousel-item .action-button:hover {
  background: linear-gradient(90deg, #6B3E75, #B87333);
  transform: scale(1.05);
}
.carousel-item .button-icon {
  width: 20px;
  height: 20px;
  filter: sepia(100%) hue-rotate(20deg) saturate(50%) brightness(170%) contrast(110%) !important; /* Crème #F5E8D3 */
}

/* Responsive Design */
@media (max-width: 768px) {
  .shop-content, .product-content {
    padding: 15px;
  }
  .shop-content h1, .product-content h1 {
    font-size: 28px;
  }
  .shop-subtitle p {
    font-size: 16px;
  }
  .shop-philtres h2, .product-philtres h2, .shop-grid h2, .product-carousel h2 {
    font-size: 20px;
  }
  .philtres-button {
    padding: 6px 12px;
    font-size: 14px;
  }
  .shop-item {
    min-height: 350px;
  }
  .shop-item .item-image, .product-content .product-image {
    max-height: 180px;
  }
  .product-content .product-description p, .product-content .product-description ul {
    font-size: 14px;
  }
}
@media (max-width: 480px) {
  .shop-content h1, .product-content h1 {
    font-size: 24px;
  }
  .shop-subtitle p {
    font-size: 14px;
  }
  .shop-philtres h2, .product-philtres h2, .shop-grid h2, .product-carousel h2 {
    font-size: 18px;
  }
  .philtres-button {
    font-size: 12px;
  }
  .shop-item .item-image, .product-content .product-image {
    max-height: 150px;
  }
  .shop-item h3, .carousel-item h3 {
    font-size: 16px;
  }
  .shop-item .item-description, .product-content .product-description p, .product-content .product-description ul {
    font-size: 13px;
  }
  .shop-item .item-collection, .shop-item .item-availability {
    font-size: 11px;
  }
  .shop-item .action-button, .carousel-item .action-button {
    padding: 8px 16px;
    font-size: 12px;
  }
  .carousel-item .item-description {
    font-size: 11px;
  }
}