/* Styles généraux */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: 'Poppins', sans-serif;
}

body {
  margin: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: #f0f0f0; /* Couleur de fond latérale */
  /* Retirer le padding global si le main-container a déjà un padding */
}

h1, h2, h3 {
  font-family: 'Playfair Display', serif;
}

/* Header */
header {
  background: green; /* Couleur d'en-tête spécifique (peut être ajustée plus tard avec les couleurs du pays) */
  color: white;
  padding: 20px;
  text-align: center;
}

.header-content {
  max-width: 800px; /* Limiter la largeur du contenu de l'en-tête */
  margin: 0 auto;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* Sections */
/* section { padding: 3rem 1rem; } */
/* section h2 { text-align: center; margin-bottom: 2rem; color: #333; font-size: 2rem; } */

/* Conteneur principal (produits + panier/formulaire) */
.main-container {
  background: white;
  max-width: 1200px;
  margin: 20px auto; /* Marge auto pour centrer, ajuster la marge supérieure si besoin */
  padding: 20px; /* Espacement interne */
  border-radius: 10px;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
  display: flex; /* Utiliser Flexbox pour la mise en page en colonnes */
  gap: 40px; /* Espace entre les colonnes */
  flex-wrap: wrap; /* Permet de passer à une seule colonne sur petits écrans */
  flex-grow: 1; /* Permet au main-container de prendre l'espace disponible */
}

/* Barre latérale (panier et formulaire) */
.sidebar {
  width: 300px; /* Largeur fixe pour la barre latérale */
  padding: 20px;
  /* border-right: 1px solid #eee;  Peut être ajusté ou retiré si le gap est suffisant */
  box-sizing: border-box; /* Inclure padding et border dans la largeur */
  flex-shrink: 0; /* Empêche la barre latérale de rétrécir en dessous de sa largeur */
}

#cart-items {
  margin-bottom: 20px;
}

.cart-summary,
.customer-info-container {
  margin-top: 20px; /* Espace entre les sections dans la sidebar */
  padding-top: 20px;
  border-top: 1px solid #eee; /* Séparateur */
}

.sidebar h2, .sidebar h3 {
  text-align: center; /* Centrer les titres dans la sidebar */
  margin-bottom: 15px;
}

.total-section h3 {
  text-align: right; /* Aligner le total à droite */
}

/* Zone de produits */
.products-section {
  flex-grow: 1; /* La zone des produits prendra plus de place */
}

.search-bar {
  margin-bottom: 20px; /* Espace sous la barre de recherche */
  display: flex; /* Permet d'aligner la barre de recherche et le filtre */
  gap: 10px;
}

.search-bar input[type="text"],
.search-bar select {
  padding: 10px;
  border: 1px solid #ccc;
  border-radius: 5px;
  font-size: 1rem;
}

.search-bar input[type="text"] {
  flex-grow: 1; /* La barre de recherche prend l'espace disponible */
}

.product-grid {
  display: flex; /* Utiliser flexbox */
  flex-wrap: wrap; /* Permettre le retour à la ligne */
  gap: 20px; /* Espacement entre les éléments */
  justify-content: center; /* Centrer les éléments dans le conteneur */
}

.product-item {
  text-align: center;
  border: 1px solid #ddd;
  padding: 15px;
  border-radius: 8px;
  background: white;
  box-shadow: 0 2px 4px rgba(0,0,0,0.1);
  transition: transform 0.3s ease;
  overflow: hidden;
  flex-basis: calc(33.333% - 20px); /* Base de taille flexible pour 3 éléments par ligne avec un écart */
  max-width: 300px; /* Limiter la largeur maximale des éléments */
  width: 100%; /* S'assurer qu'il prend la largeur disponible dans le flex container */
}

.product-item:hover {
  transform: translateY(-5px); /* Effet de survol */
}

.product-item img:hover {
  transform: scale(1.05); /* Agrandissement au survol */
}

.quantity-control {
  display: flex;
  justify-content: center;
  margin: 10px 0;
}

.quantity-control input[type="number"] {
  width: 50px; /* Ajuster la largeur de l'input quantité */
  text-align: center;
  border: 1px solid #ccc;
  border-radius: 5px;
  margin: 0 5px; /* Espacement entre le input et les boutons */
  padding: 5px 0;
}

.quantity-control button {
  background: var(--accent-color); /* Utiliser la variable de couleur */
  color: white;
  border: none;
  padding: 5px 10px;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.quantity-control button:hover {
  background-color: var(--accent-hover);
}

.add-to-cart {
  background: var(--accent-color); /* Utiliser la variable de couleur */
  color: white;
  padding: 8px 15px;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 0.3s ease;
  margin-top: 10px; /* Espace au-dessus du bouton */
}

.add-to-cart:hover {
   background-color: var(--accent-hover);
}

/* Styles pour le pied de page */
footer {
  margin-top: 20px;
  background: #f9f9f9; /* Fond du footer */
  padding: 20px;
  text-align: center; /* Centrer le texte */
  border-radius: 10px; /* Bords arrondis */
}

.footer-content {
  max-width: 800px;
  margin: 0 auto;
  /* Les styles spécifiques aux éléments du footer-content sont déjà gérés par des règles plus générales ou doivent être ajoutés */
}

.footer-content ul {
  padding: 0;
  list-style: none;
  margin-bottom: 10px;
}

.footer-content li {
  margin-bottom: 5px;
}

/* Responsive */
@media (max-width: 768px) {
  .main-container {
    flex-direction: column; /* Empiler les colonnes sur petits écrans */
    gap: 20px; /* Réduire l'espace */
    padding: 10px; /* Réduire le padding sur petits écrans */
  }

  .sidebar {
    width: 100%; /* La barre latérale prend toute la largeur */
    border-right: none; /* Retirer la bordure droite */
    padding: 15px; /* Ajuster le padding */
  }

  .products-section {
    width: 100%; /* La zone des produits prend toute la largeur */
    padding: 10px; /* Ajouter un padding si nécessaire */
  }

  .search-bar {
    flex-direction: column; /* Empiler barre de recherche et filtre si nécessaire */
    gap: 10px;
  }

  .product-item img {
    height: 150px; /* Ajuster la hauteur de l'image sur petits écrans */
  }

   .product-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); /* Ajuster la grille sur petits écrans */
    gap: 15px;
  }

  h1 {
      font-size: 1.8rem; /* Ajuster la taille du H1 */
  }

  h2 {
      font-size: 1.5rem; /* Ajuster la taille du H2 */
  }

  h3 {
      font-size: 1.2rem; /* Ajuster la taille du H3 */
  }

  .order-form {
    padding: 15px; /* Réduire le padding du formulaire */
  }

  .order-form label {
    font-size: 0.9rem; /* Réduire la taille de police des labels */
  }

  .order-form input[type="text"], 
  .order-form input[type="tel"] {
    margin: 8px 0 15px; /* Ajuster les marges */
    padding: 8px; /* Ajuster le padding */
  }

  .order-form button[type="button"] {
    padding: 10px 15px; /* Ajuster le padding du bouton */
    font-size: 1rem; /* Ajuster la taille de police du bouton */
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  /* Styles pour tablettes */
  .main-container {
    flex-direction: row; /* Garder les colonnes côte à côte */
    gap: 30px; /* Ajuster l'espace */
    padding: 15px; /* Ajuster le padding */
  }

  .sidebar {
    width: 250px; /* Ajuster la largeur de la barre latérale */
    padding: 15px; /* Ajuster le padding */
  }

  .products-section {
    flex-grow: 1; /* Permettre à la zone des produits de prendre l'espace restant */
  }

  .product-grid {
    gap: 15px; /* Ajuster l'espace */
  }

  .product-item {
    flex-basis: calc(50% - 15px); /* Base de taille pour 2 éléments par ligne */
    max-width: none; /* Retirer la limitation de largeur */
  }

  .product-item img {
    height: 180px; /* Ajuster la hauteur de l'image */
  }
}

@media (min-width: 1025px) {
  /* Styles pour grands écrans (potentiellement réappliquer des styles par défaut si nécessaire) */
  .main-container {
    flex-direction: row; 
    gap: 40px; 
    padding: 20px; 
  }

  .sidebar {
    width: 300px; 
    padding: 20px; 
  }

  .products-section {
    flex-grow: 1; 
  }

  .product-grid {
    gap: 20px; 
  }

   .product-item {
    flex-basis: calc(33.333% - 20px); /* Base de taille pour 3 éléments par ligne */
    max-width: 300px; 
  }

  .product-item img {
    height: 200px; 
  }
}

/* Conservation des styles existants qui peuvent toujours être utiles */
/* :root { ... } */
/* .hero { ... } - Si vous utilisez toujours cette classe pour d'autres en-têtes */
/* .country-selector { ... } */
/* .cards, .card, .country-flag, .content { ... } - Si utilisés sur d'autres pages */
/* .intro, .cta, .btn, .links { ... } - Si utilisés sur d'autres pages */

/* Styles spécifiques aux pages pays (si nécessaires en plus du nouveau layout) */
/* .country-page header { ... } */
/* .country-page .logo-container .logo { ... } */
/* .country-header-content { ... } */
/* .country-hero { ... } - Si utilisé */
/* .country-page main { ... } - Remplacé par .main-container, .products-section, .sidebar */
/* .vedette { ... } - Si utilisé */
/* .parfums { ... } - Si utilisé */
/* #nos-produits { ... } - Si utilisé */
/* .search-container { ... } - Remplacé par .search-bar */
/* #search-bar { ... } - Stylé maintenant dans .search-bar */
/* .liste-produits { ... } - Remplacé par .product-grid */
/* .produit { ... } - Remplacé par .product-item */
/* .produit img { ... } - Remplacé par .product-item img */
/* .btn, .buy-btn { ... } - Si utilisé en dehors des nouveaux boutons */
/* #choix-pays { ... } - Si utilisé */
/* .pays { ... } - Si utilisé */
/* .cart-section { ... } - Remplacé par .sidebar / .cart-summary-container */
/* #cart-items { ... } - Stylé par .sidebar */
/* .cart-item { ... } - Existait déjà, styles conservés/ajustés */
/* .btn-clear, .btn-validate { ... } - Existaient déjà, styles conservés/ajustés */

:root {
    --primary-color: #1a1a1a;
    --accent-color: #c5a880;
    --light-bg: #f9f9f9;
    --dark-bg: #121212;
    --text-color: #333;
    --accent-hover: #e0c8a3;
}

.hero {
    text-align: center;
    padding: 40px 20px;
    background: var(--primary-color);
    color: white;
    border-radius: 10px;
    margin-bottom: 40px;
    position: relative; /* Permet de positionner absolument les enfants */
}

.cards {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
}

.card {
    background: white;
    padding: 20px;
    border-radius: 15px;
    text-align: center;
    flex: 1 1 300px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    transition: transform 0.3s, box-shadow 0.3s;
    text-decoration: none;
    color: var(--primary-color);
    position: relative;
    overflow: hidden;
}

.card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 16px rgba(0,0,0,0.2);
}

.country-flag {
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: 10px;
    transition: transform 0.3s;
}

.card:hover .country-flag {
    transform: scale(1.05);
}

.content {
    padding-top: 15px;
}

.content h3 {
    margin-bottom: 5px;
    color: var(--accent-color);
}

.content p {
    color: #666;
    font-size: 0.9rem;
}

footer {
    text-align: center;
    padding: 20px;
    margin-top: 40px;
    background: var(--dark-bg);
    color: white;
    border-radius: 10px;
}

/* Responsive */
@media (max-width: 768px) {
    .hero h1 {
        font-size: 1.8rem;
    }
    .card {
        flex: 1 1 250px;
    }
}

/* Styles pour le formulaire de commande */
.order-form {
    max-width: 800px;
    margin: 0 auto 40px;
    padding: 20px;
    background: white;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

.search, .cart, .customer-info {
    margin-bottom: 30px;
}

input[type="text"], input[type="tel"] {
    width: 100%;
    padding: 10px;
    margin: 10px 0 20px;
    border: 1px solid #ccc;
    border-radius: 5px;
}

#productList li {
    padding: 10px;
    cursor: pointer;
    border-bottom: 1px solid #eee;
}

#productList li:hover {
    background: #f0f0f0;
}

.cart-item {
    display: flex;
    justify-content: space-between;
    margin: 10px 0;
}

button[type="button"] {
    background: var(--accent-color);
    color: white;
    border: none;
    padding: 12px 20px;
    font-size: 16px;
    border-radius: 5px;
    cursor: pointer;
    transition: background 0.3s;
}

button[type="button"]:hover {
    background: var(--accent-hover);
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 15px; /* Ajouter un padding horizontal pour éviter que le contenu ne touche les bords sur mobile */
}

.intro {
    padding: 40px 0;
    background: #f4f4f4;
}

.cta {
    padding: 60px 0;
    background: var(--primary-color);
    color: white;
    text-align: center;
}

.btn {
    background: var(--accent-color);
    color: white;
    padding: 15px 40px;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-size: 1.1rem;
    transition: background 0.3s;
}

.btn:hover {
    background: var(--accent-hover);
}

.links a {
    color: white;
    margin: 0 15px;
    text-decoration: none;
}

/* Styles pour la grille de produits et le panier */
/* Ancien layout flex supprimé ou commenté si nécessaire */

.main-container {
    display: flex;
    gap: 40px; /* Espace entre les colonnes */
    margin: 40px auto; /* Centrer le conteneur principal */
    max-width: 1200px; /* Largeur maximale */
    padding: 0 20px; /* Marges latérales */
    flex-wrap: wrap; /* Permet le passage à une seule colonne sur petits écrans */
}

.products-section {
    flex: 2; /* La zone des produits prendra plus de place */
}

.sidebar {
    flex: 1; /* La barre latérale prendra moins de place */
    background: white; /* Fond pour la barre latérale */
    padding: 20px; /* Espacement interne */
    border-radius: 10px; /* Bords arrondis */
    box-shadow: 0 2px 4px rgba(0,0,0,0.1); /* Ombre */
}

.search-bar {
    margin-bottom: 20px; /* Espace sous la barre de recherche */
    display: flex; /* Permet d'aligner la barre de recherche et le filtre si besoin */
    gap: 10px;
}

.search-bar input[type="text"], .search-bar select {
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 5px;
    font-size: 1rem;
}

.search-bar input[type="text"] {
    flex-grow: 1; /* La barre de recherche prend l'espace disponible */
}

.product-grid {
    display: flex; /* Utiliser flexbox */
    flex-wrap: wrap; /* Permettre le retour à la ligne */
    gap: 20px; /* Espacement entre les éléments */
    justify-content: center; /* Centrer les éléments dans le conteneur */
}

.cart-summary,
.customer-info-container {
    margin-top: 20px; /* Espace entre les sections dans la sidebar */
    padding-top: 20px;
    border-top: 1px solid #eee; /* Séparateur */
}

.cart-summary-container h2,
.sidebar h2,
.sidebar h3 {
    text-align: center; /* Centrer les titres dans la sidebar */
    margin-bottom: 15px;
}

.total-section h3 {
    text-align: right; /* Aligner le total à droite */
}

/* Styles pour le pied de page */
footer {
    text-align: center;
    padding: 20px;
    margin-top: 40px;
    background: var(--dark-bg);
    color: white;
    border-radius: 10px;
}

.footer-content h3 {
    color: white; /* S'assurer que les titres du footer sont blancs */
    margin-bottom: 10px;
}

.footer-content p,
.footer-content ul,
.footer-content li {
    color: #ccc; /* Couleur du texte dans le footer */
    list-style: none;
    padding: 0;
    margin-bottom: 5px;
}

.links a {
    color: white; /* S'assurer que les liens sont blancs */
    margin: 0 10px;
    text-decoration: none;
}

.back-btn {
     display: inline-block;
     margin-top: 20px;
     padding: 10px 20px;
     background-color: var(--accent-color);
     color: white;
     text-decoration: none;
     border-radius: 5px;
     transition: background-color 0.3s ease;
}

.back-btn:hover {
     background-color: var(--accent-hover);
}

/* Responsive */
@media (max-width: 768px) {
    .main-container {
        flex-direction: column; /* Empiler les colonnes sur petits écrans */
        gap: 20px; /* Réduire l'espace */
    }

    .products-section, .sidebar {
        flex: none; /* Désactiver le flex-grow/shrink */
        width: 100%; /* Prendre toute la largeur */
    }

    .search-bar {
        flex-direction: column; /* Empiler barre de recherche et filtre si nécessaire */
    }
}

/* Limitez la largeur des images à 100% de leur conteneur */
.product-image {
    max-width: 100%; /* Force l'image à ne pas dépasser le conteneur */
    height: auto;    /* Maintient le ratio largeur/hauteur */
    display: block;  /* Évite les espaces sous l'image */
}

/* Contrôlez la hauteur maximale si nécessaire */
.product-container {
    max-height: 300px; /* Ajustez selon vos besoins */
    overflow: hidden;   /* Cache les parties hors du cadre */
    display: flex; /* Utiliser flexbox pour centrer l'image verticalement si nécessaire */
    justify-content: center; /* Centrer l'image horizontalement */
    align-items: center; /* Centrer l'image verticalement */
}

.product-grid .product-item img {
    display: block; /* Assurer que l'image est un élément de bloc */
    width: 100%; /* L'image prend 100% de la largeur de son conteneur (.product-item) */
    max-width: 100%; /* Assurer que l'image ne dépasse pas la largeur de son conteneur */
    height: 200px; /* Hauteur fixe pour l'image */
    object-fit: cover; /* S'assurer que l'image couvre bien la zone sans déformation */
    border-radius: 4px; /* Bords arrondis pour l'image */
    margin-bottom: 10px; /* Espace sous l'image */
}

.product-item img:hover {
    transform: scale(1.05); /* Agrandissement au survol */
}

/* Styles pour les liens sociaux dans l'en-tête */
.social-links-header {
    margin-top: 15px; /* Espace au-dessus des liens sociaux */
    display: flex;
    justify-content: center;
    gap: 10px; /* Espacement entre les icônes */
}

.social-links-header a {
    display: inline-flex; /* Permet d'aligner l'icône et le texte si présent */
    align-items: center;
    justify-content: center;
    width: 40px; /* Taille du bouton */
    height: 40px;
    background-color: rgba(255, 255, 255, 0.2); /* Fond semi-transparent */
    color: white; /* Couleur de l'icône */
    border-radius: 50%; /* Bouton rond */
    text-decoration: none;
    font-size: 1.2rem;
    transition: background-color 0.3s ease, transform 0.3s ease;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Ombre pour l'effet 3D */
    position: relative; /* Nécessaire pour l'effet 3D */
    overflow: hidden; /* Cache le débordement de l'effet de survol */
}

.social-links-header a:first-child {
    margin-left: 0; /* Pas de marge à gauche pour le premier élément */
}

.social-links-header a:hover {
    background-color: rgba(255, 255, 255, 0.3); /* Changement au survol */
     transform: translateY(-2px); /* Léger soulèvement au survol */
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.3); /* Ombre plus prononcée au survol */
}

.social-links-header a:active {
     transform: translateY(0); /* Retour à la position normale lors du clic */
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); /* Ombre réduite lors du clic */
}

.social-links-header a[aria-label="Discutez sur WhatsApp"] {
    background-color: #25D366; /* Vert WhatsApp */
}

.social-links-header a[aria-label="Discutez sur WhatsApp"]:hover {
    background-color: #1DA851; /* Vert WhatsApp plus foncé au survol */
}

/* Style spécifique pour le lien Admin */
.social-links-header .admin-link {
     background-color: rgba(255, 255, 255, 0.2); /* Fond similaire */
    color: white; /* Texte blanc */
    padding: 0 10px; /* Ajouter un padding pour le texte */
     width: auto; /* Ajuster la largeur au contenu */
    border-radius: 20px; /* Bords arrondis pour un bouton rectangulaire */
    font-size: 1rem;
}

.social-links-header .admin-link:hover {
    background-color: rgba(255, 255, 255, 0.3);
     transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.3);
}

.social-links-header .admin-link:active {
     transform: translateY(0);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* Styles pour le conteneur du lien Admin en haut à droite */
.admin-corner {
    position: absolute; /* Positionnement absolu par rapport à l'en-tête parent */
    top: 20px; /* Distance du haut */
    right: 20px; /* Distance de la droite */
     z-index: 10; /* Assure qu'il est au-dessus des autres éléments */
}

.admin-corner .admin-link {
     display: inline-block; /* Afficher comme un bloc en ligne */
     padding: 8px 15px; /* Padding pour le bouton */
     background-color: var(--accent-color); /* Couleur d'accent pour le bouton */
     color: white; /* Texte blanc */
     text-decoration: none; /* Pas de soulignement */
     border-radius: 20px; /* Bords arrondis */
     font-size: 1rem;
     transition: background-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
     box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.admin-corner .admin-link:hover {
    background-color: var(--accent-hover);
     transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.3);
}

.admin-corner .admin-link:active {
     transform: translateY(0);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* Styles pour la barre de recherche et l'autocomplétion */
.search-container {
    position: relative;
    max-width: 600px;
    margin: 2rem auto;
}

.search-input-group {
    display: flex;
    gap: 10px;
    align-items: center;
}

#search-bar {
    flex: 1;
    padding: 12px 20px;
    font-size: 16px;
    border: 2px solid #ddd;
    border-radius: 25px;
    outline: none;
    transition: border-color 0.3s ease;
}

.search-button {
    background: var(--accent-color);
    color: white;
    border: none;
    padding: 12px 20px;
    border-radius: 25px;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.search-button:hover {
    background: var(--accent-hover);
}

#search-bar:focus {
    border-color: #4CAF50;
}

.search-suggestions {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: white;
    border: 1px solid #ddd;
    border-radius: 0 0 10px 10px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    z-index: 1000;
    display: none;
}

.suggestion-item {
    padding: 10px 20px;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.suggestion-item:hover {
    background-color: #f5f5f5;
} 