:root {

  /* ===============================
     IMAGES ET ASSETS COMMUNS
  =============================== */
  --logo: url('../assets/images/Logo_arth_et_facts.png');
  --handmade: url('../assets/images/handmade.png');
  --bacground: url('../assets/images/Background_noir.png');
  --puce-bg: url('../assets/images/puce.png');
  --puce-select-bg: url('../assets/images/puce_select.png');
  --curve-bg: url('../assets/images/courbes_brun.svg');
  --map: url('../assets/images/ico_map.png');
  --map-select: url('../assets/images/ico_map_select.png');

  --qte-moins: url('../assets/images/moins.png');
  --qte-moins_hover: url('../assets/images/moins_hover.png');
  --qte-plus: url('../assets/images/plus.png');
  --qte-plus_hover: url('../assets/images/plus_hover.png');
  --qte-trash: url('../assets/images/trash.png');
  --qte-trash_hover: url('../assets/images/trash_hover.png');
  --www: url('../assets/images/www.png');
  --www_hover: url('../assets/images/www_hover.png');


 
  /* ===============================
     PALETTE DE COULEURS PRINCIPALE
     (au format r, g, b pour usage rgba())
  =============================== */
  --col-vert:         83, 107, 82;
  --col-vert-clair:   100, 130, 100;
  --col-vert-pale:    201, 240, 209;

  --col-brun:         101, 91, 71;
  --col-brun-clair:   130, 120, 100;

  --col-orange:       205, 102, 0;
  --col-orange-clair: 229, 125, 40;

  --col-beige:        247, 238, 221;
  --col-beige-clair:  255, 250, 240;

  --col-blanc:        255, 255, 255;
  --col-noir:         0, 0, 0;     
  --col-gris-clair:   167, 167, 167;     /* gris doux pour les bordures */
  --col-gris-shadow:  0, 0, 0;           /* utilisé pour box-shadow léger */

  /* ===============================
     TYPOGRAPHIES
  =============================== */
  --font-titre: 'Great Vibes', cursive;
  --font-texte: 'Libre Caslon Text', 'Georgia', serif;
  --font-imput: 'Montserrat', sans-serif;
  --font-texte-2: 'Open Sans', sans-serif;

  --text-size-base: 16px;
  --text-size-titre: 35px;
  --text-line-height: 1.6;

  /* ===============================
     EFFETS & UI DÉCORATIFS
  =============================== */
  --bar-blur: 14px;
}
/* ===========================================================================================================================================================================================
/* ===================================================================               EN COMMUN          ======================================================================================
/* ===========================================================================================================================================================================================*/

body {
  background-image: 
    url('../assets/images/Background.png');
  background-repeat: repeat, repeat;
  background-position: center center, top left;
  
  background-attachment: fixed, fixed;

  margin: 0;
  padding: 0;
  font-family: var(--font-texte);
  font-size: var(--text-size-base);
  font-style:italic;
  line-height: var(--text-line-height);
  color: rgb(var(--col-brun));
  overflow-x: hidden; /* évite le scroll horizontal */
  z-index: -1; 
}

.background-curve {
    position: fixed;   /* reste collée à l'écran */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;       /* derrière le contenu */
    overflow: hidden;  /* évite le scroll */
}


a {
  color: inherit;
  text-decoration: none;
}


.btn-map {
  display: inline-block;
  width: 42px;
  height: 42px;
  margin-left: 8px;
  background-image: var(--map);
  background-size: contain;
  background-repeat: no-repeat;
  text-indent: -9999px;
  overflow: hidden;
  transition: transform 0.2s ease, background-image 0.2s ease;
  vertical-align: middle;
}

.btn-map:hover,
.btn-map.active {
  background-image: var(--map-select);
  transform: scale(1.1);
}


.btn-www {
  display: inline-block;
  width: 42px;
  height: 42px;
  margin-left: 8px;
  background-image: var(--www);
  background-size: contain;
  background-repeat: no-repeat;
  overflow: hidden;
  transition: transform 0.2s ease, background-image 0.2s ease;
  vertical-align: middle;
}

.btn-www:hover {
  transform: scale(1.1);
  background-image: var(--www_hover);
}

/* ===========================================================================================================================================================================================
* ================================================================               ADMIN - OFFFICE          ====================================================================================
/* ===========================================================================================================================================================================================*/


.collection-block {
  margin: 2em auto;
  padding: 2em;
  background: rgba(var(--col-beige), 0.6);
  border-radius: 16px;
  box-shadow: 0 2px 6px rgba(var(--col-noir), 0.05);
  max-width: 90%;
  position: relative;
  
}

.collection-title-admin {
  position: relative;
  text-align: center;
  margin: 2em 0 2em;
  height: 2.6em; /* hauteur contrôlée */
}

.collection-title-admin h2 {
  position: relative;
  z-index: 2;
  font-size: 2.4em;
  font-family: var(--font-titre);
  font-weight: normal;
  margin: 0;
  line-height: 1;
  display: inline-block;
  padding: 0 0.4em;
  background: transparent;
  font-size: 2.8em;         /* ← modifie la taille ici */
  color: rgb(var(--col-vert)); /* ← modifie la couleur ici */
}

.collection-title-admin .puce {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
  width: 60px;
  height: 60px;
  background: var(--puce-bg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0.4; /* doux effet en transparence */
}



.Prod-Img {
  width: 140px;
  height: 140px;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(var(--col-noir), 0.08);
  background: rgb(var(--col-blanc));
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.5em;
  position: relative;
}

.Prod-Img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: inherit;
}

.Prod-Img .img-zoom-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  background: rgba(var(--col-blanc), 0.7);
  border: none;
  border-radius: 6px;
  padding: 2px 6px;
  cursor: pointer;
  font-size: 1.2em;
  display: none;
}

.Prod-Img:hover .img-zoom-btn {
  display: block;
}

.Tbl-Prod {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 2em;
  margin: 2em auto;
  flex-wrap: wrap;
}

.Tbl-Prod:nth-child(even) {
  background-color: rgba(var(--col-brun), 0.15); /* 15% de brun */
    padding: 1em;
  border-radius: 15px;
  box-shadow: 0 1px 6px rgba(var(--col-noir),0.05);
}

.Tbl-Prod:nth-child(odd) {
  background-color: rgba(var(--col-beige), 0.15); /* beige pâle */
    padding: 1em;
  border-radius: 12px;
}


.Prod-Infos {
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 1em;
}

.Tbl-Inf-Base,
.Tbl-Inf-Facul {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8em;
}

.Tbl-Inf-Base .cell,
.Tbl-Inf-Facul .cell {
  flex: 1 1 120px;
  min-width: 120px;
}

/* Bouton */
.Prod-Action {
  display: flex;
  justify-content: flex-end;
  margin-top: 1em;
}

/* Boutons d’action */
/* BOUTON AJOUTER ou BOUTON MODIFIER */
/* BOUTON AJOUTER ou BOUTON MODIFIER */
.Bt-Add, .Bt-Mod {
  position: relative;
  width: 120px;
  height: 40px;
  cursor: pointer;
  display: flex;
  align-items: center;
  border: 1px solid rgb(var(--col-beige));
  
  background-color: rgb(var(--col-vert-clair));
  border-radius: 10px;
  box-shadow: 10px 18px 19px 0 rgba(var(--col-noir), 0.2);
}

.Bt-Add__icon, .Bt-Add__text, .Bt-Mod__icon, .Bt-Mod__text {
  transition: all 0.3s;
}

.Bt-Add__text, .Bt-Mod__text {
  font-family: var(--font-texte);
  font-size: 1em;
  line-height: 1;
  font-style: italic;
  transform: translateX(40px);
  color: rgb(var(--col-blanc));
  font-weight: 600;
}

.Bt-Add__icon, .Bt-Mod__icon {
  position: absolute;
  transform: translateX(-6px);
  height: 100%;
  width: 39px;
  background-color: rgb(var(--col-vert));
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
}

.Bt-Add .svg, .Bt-Mod .svg {
  width: 30px;
  stroke: rgb(var(--col-blanc))fff;
}

.Bt-Add:hover, .Bt-Mod:hover {
  background: rgb(var(--col-vert-clair));
  border: 1px solid rgb(var(--col-vert));
  transform: translateY(-7px);
  box-shadow: 0px 15px 20px rgb(var(--col-vert));
}

.Bt-Add:hover .Bt-Add__text, .Bt-Mod:hover .Bt-Mod__text {
  color: transparent;
}

.Bt-Add:hover .Bt-Add__icon, .Bt-Mod:hover .Bt-Mod__icon {
  width: 120px;
}

.Bt-Add:active .Bt-Add__icon, .Bt-Mod:active .Bt-Mod__icon {
  background-color: rgb(var(--col-vert-clair));
}

.Bt-Add:active, .Bt-Mod:active {
  border: 1px solid  rgb(var(--col-vert-clair));
  transform: translateY(-1px);
}

.Bt-Add:hover .svg,
.Bt-Mod:hover .svg {
  transform: rotate(180deg);
  transition: transform 0.6s ease;
  transform-origin: center;
}

.Bt-Add .svg,
.Bt-Mod .svg {
  transition: transform 0.6s ease;
}

/* =======================================
   ✳️ État MODIFIÉ : bouton en alerte
========================================== */
.Bt-Add.Buzzy,
.Bt-Mod.Buzzy {
  background-color: rgb(var(--col-orange-clair));
  border: 1px solid rgb(var(--col-orange));
  box-shadow: 0px 0px 12px rgba(var(--col-orange), 0.5);
  transition: all 0.3s ease;
}

.Bt-Add.Buzzy:hover,
.Bt-Mod.Buzzy:hover {
  box-shadow: 0px 15px 20px rgba(var(--col-orange), 0.7);
}

.Bt-Add.Buzzy:active,
.Bt-Mod.Buzzy:active {
  border: 1px solid rgb(var(--col-orange-foncé));
}

.Bt-Add.StandBy,
.Bt-Mod.StandBy {
  opacity: 0.5;
  cursor: not-allowed;
}

.Bt-Add.Ready,
.Bt-Mod.Ready {
  background-color: rgba(var(--col-vert-clair));
  cursor: pointer;
}

.Bt-Add.Buzzy,
.Bt-Mod.Buzzy {
  background-color:rgba(var(--col-orange), 0.5);
  cursor: wait;
}



/*-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/* ------------------------------------------------------------------------------------- LES INPUTS --------------------------------------------------------------------------------------------- 
/*-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/


/* ======================== */
/*   INPUTS DE .Tbl-Prod    */
/* ======================== */

.Tbl-Prod input[type="text"],
.Tbl-Prod input[type="number"],
.Tbl-Prod input[type="date"],
.Tbl-Prod input[type="file"],
.Tbl-Prod select {
  background: rgb(var(--col-blanc));
  border: 2px solid rgba(var(--col-gris-clair), 0.55);
  border-radius: 6px;
  padding: 6px 10px;
  font-family: var(--font-texte);
  font-size: 14px;
  box-shadow: 0 2px 5px rgba(var(--col-gris-shadow), 0.06);
  transition: border 0.3s, box-shadow 0.3s;
  width: auto;
  flex: 1 1 auto;
}

.Tbl-Prod input:focus,
.Tbl-Prod select:focus {
  outline: none;
  border-color: rgb(var(--col-vert-clair));
  box-shadow: 0 0 4px rgb(var(--col-vert));
}

.Tbl-Prod input.input-modified {
  background-color: rgba(var(--col-vert), 0.15);
  transition: background 0.3s ease;
}

/* ======================== */
/*    STRUCTURE DES BLOCS   */
/* ======================== */

.Tbl-Inf-Base {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.6em;
  margin-top: 0.5em;
}

.Tbl-Inf-Facul {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8em;
  margin-top: 0.5em;
}

.Tbl-Prod .cell {
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex: 0 1 auto;
  min-width: min-content;
}

.cell.Type select {
  width: 140px;
}

.cell.Prix input {
  width: 110px;
  max-width: 110px;
  text-align: center;
}

.cell.Stock input,
.cell.Poids input,
.cell.Longueur input,
.cell.Largeur input,
.cell.Hauteur input {
  width: 80px;
  max-width: 80px;
  text-align: center;
}

.cell.Desc input {
  min-width: 200px;
}

.cell.Dates input {
  width: 140px;
  min-width: 120px;
  max-width: 160px;
  text-align: center;
}


/* -------------------------------------------------------------------------------------------------------------
/* ------------------------------------- IMAGE ZOOM / MODAL -------------------------------------------------- */


/* ===========================================================================================================================================================================================
/* ===========================================================================================================================================================================================*/

/* Titres de sections / collections */
h1, h2, h3,
.titre-collection {
  font-family: var(--font-titre);
  font-size: var(--text-size-titre);
  font-weight: normal;
  line-height: 1.2;
  color: #333;
}


/* ==========================
   RÉINITIALISATION
========================== */


.splash-content {
 
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0em;
  font-size: 1.2rem;
  font-weight: 300;
  line-height: 0;
  z-index: 10;
}


.logo {
  background: var(--logo);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  transition: filter 0.15s, transform 0.15s;
  
  display: block;
  margin: 0 auto;
}

.handmade {
  background: var(--handmade);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  transition: filter 0.15s, transform 0.15s;

  display: block;
  margin: 0 auto;
}


.btn-fantome {
  position: fixed;
  bottom: 20px;
  right: 20px;
  color: rgb(var(--col-blanc));
  text-decoration: none;
  font-size: 14px;
  font-family: monospace;
  background: rgba(var(--col-vert), 0);
  padding: 5px 10px;
  border-radius: 5px;
  transition: background 0.3s, opacity 0.3s ease;
  z-index: 999;
}

.btn-fantome:hover {
  background: rgb(var(--col-vert));
}

.btn-fantome[data-fantome="on"] {
  color: transparent;
}

.btn-fantome[data-fantome="on"]:hover {
  background-color: rgba(var(--col-vert), 0.5);
  color: rgb(var(--col-blanc));
}


/* ==========================
   NAVIGATION / MENU COLLECTIONS
========================== */

/* === BARRE DE HEADER GÉNÉRALE === */
.header-bar {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 1500px;
  margin: 0 auto;
  padding-top: 1.5em;
  gap: 2vw;
  position: relative;
}

/* === GROUPE MENUS (menu principal + collections) === */
.header-groupe-menus {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  flex: 1 0 auto;
  gap: 0.4em;
}

/* === LISTES DE MENUS === */
.menu-principal ul,
.menu-collections ul {
  display: flex;
  align-items: center;
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.menu-principal ul {
  gap: 0.3em;
}

.menu-collections ul {
  gap: 2.2em;
}

/* === ITEMS DU MENU PRINCIPAL === */
.menu-principal li {
  display: inline-block;
  white-space: nowrap;
  font-family: var(--font-texte-2);
  font-size: 0.9em;
  letter-spacing: 0.03em;
  font-weight: 500;
  color: rgb(var(--col-vert));
  transition: color 0.14s;
}

.menu-principal a {
  color: inherit;
  text-decoration: none;
  padding: 4px 8px;
  border-radius: 8px;
  transition: background 0.15s, color 0.12s;
}

.menu-principal a:hover,
.menu-principal .current > a {
  color: var(--orange);
  background: rgb(var(--col-beige));
  box-shadow: 0 2px 14px rgb(var(--col-brun), 0.3);
}

/* === RESPONSIVE : empilement mobile === */
@media (max-width: 768px) {
  .header-bar {
    flex-direction: column;
    padding-top: 1em;
    gap: 1em;
  }

  .menu-principal ul,
  .menu-collections ul {
    flex-wrap: wrap;
    justify-content: center;
  }

  .menu-principal li {
    text-align: center;
  }

  .header-groupe-menus {
    align-items: center;
  }
}


/* ----------------------------------------------Langue ------------------------------------------------*/

.header-langue {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  z-index: 20;
}

.lang-active {
  background: none;
  border: none;
  font-size: 1.04em;
  color:  rgb(var(--col-brun));       /* --brun défini dans tes variables */
  font-family: inherit;
  cursor: pointer;
  padding: 3px 14px 3px 8px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  position: relative;
}
.lang-arrow {
  margin-left: 3px;
  font-size: 1em;
  pointer-events: none;
  color:  rgb(var(--col-orange));     /* La flèche en orange ! */
  font-weight: bold;
}



.lang-dropdown {
  display: none;
  position: absolute;
  top: 110%;
  right: 0;    /* <- CHANGE left: 0 en right: 0 */
  left: unset;
  background: rgb(var(--col-beige-clair));
  border-radius: 8px;
  box-shadow: 0 4px 16px rgb(var(--col-noir))1;
  list-style: none;
  padding: 0.4em 0;
  margin: 0;
  min-width: 58px;
  z-index: 25;
   pointer-events: auto !important;
}

.header-langue.open .lang-dropdown {
  display: block;
}
.lang-dropdown li {
  padding: 5px 14px;
  cursor: pointer;
  color: rgb(var(--col-brun));
  font-size: 1em;
  text-align: left;
  transition: background 0.18s;
}
.lang-dropdown li:hover {
 background: rgb(var(--col-beige));
   color: rgb(var(--col-orange));
}

Ouvre le menu au survol du bloc langue 
.header-langue:hover .lang-dropdown,
.header-langue:focus-within .lang-dropdown {
  display: block;
}

.header-langue:hover .lang-arrow {
  transform: rotate(180deg);
  transition: transform 0.18s;
  
}

.lang-dropdown .lang-current {
  font-weight: bold;
  color: var(--brun);
  background: rgb(var(--col-beige));
  cursor: default;
  pointer-events: none;
}

.lang-dropdown.visible {
  display: block;
}

/* -----------------------------------------------------------Collection menu */

.menu-collections ul {
  font-size: 1.3em;
  font-family: var(--font-titre);
  
  display: flex;
  align-items: center;
  gap: 1.8em;      /* réduit si trop espacé */
  padding: 20px 0;
  margin: 0;
  list-style: none;
}


.menu-collections .panier-svg-wrap {
  margin-left: 2em;
  display: flex;
  align-items: center;
  height: 44px;
}






.collections-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  width: 100vw;
  padding: 32px 60px 0 60px;
  min-height: 170px;
  box-sizing: border-box;
}

/* Menu horizontal desktop, vertical mobile */
.collections-menu {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  gap: 3vw;
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1 1 auto;
}

.nav-item {
  position: relative;
  display: flex;
  align-items: flex-end;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
  min-width: 62px;
  margin-top:2.5em; /* si tu veux juste le texte, en complément */
}

/* TITRES COLLECTIONS AVEC PUCE EN BACKGROUND */
.collection-title {
  font-family: var(--font-titre);
  font-size: var(--text-size-titre);
  color: rgb(var(--col-vert-clair))!important;
  padding: 0.12em 0.22em;
  position: relative;
  z-index: 1;
  transition: color 0.15s;
  text-align: center;
  line-height: 1.1;
  display: inline-block; /* Force le contexte pour position absolute */
  vertical-align: middle;
}

/* État sélectionné (ex. : classe .current appliquée dynamiquement) */
.collection-title.current {
  color: rgb(var(--col-brun))!important;
}
.collection-title.current::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 56%;
  transform: translate(-50%, -50%);
  width: 70px;
  height: 34px;
  background: var(--puce-select-bg) center/contain no-repeat;
  z-index: -1;
}

/* État survolé */
.collection-title:hover {
  color: rgb(var(--col-vert))!important;
}
.collection-title:hover::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 56%;
  transform: translate(-50%, -50%);
  width: 70px;
  height: 34px;
  background: var(--puce-bg) center/contain no-repeat;
  z-index: -1;
  opacity: 0.67;
  pointer-events: none;
}

.collection-title:not(.current)::after {
  display: none;
}


/* =============== PANIER =============== */
/* Panier VIDE */
.panier-svg-shape .panier-path {
  fill: rgb(var(--col-brun));
  stroke: rgb(var(--col-brun));
  stroke-width: 10;
}
/* Panier REMPLIS */
.panier-rempli .panier-svg-shape .panier-path {
  fill: rgb(var(--col-vert));
  stroke: rgb(var(--col-vert));
}
/* Panier Ajout */
.panier-ajout .panier-svg-shape .panier-path {
  fill: rgb(var(--col-orange));
  stroke: rgb(var(--col-orange));
}

.panier-count {
  font-family: Arial, sans-serif;
  font-size: 400px;
  fill: rgb(var(--col-orange));
  font-weight: bold;
  pointer-events: none;
  user-select: none;
}

/* ==========================
   LOGO & LIENS
========================== */
.header-side {
    display: flex;
    flex-direction: row;      /* logo et colonne de liens côte à côte */
    align-items: center;      /* centrer verticalement */
    justify-content: flex-end;
    gap: 32px;
    height: 140px;            /* adapte selon ta ligne de nav */
    position: relative;
    z-index: 2;
}




.logo:hover { filter: brightness(1.08) saturate(1.12); }
.links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.1em;
}
.header-link {
  font-family: 'Great Vibes', cursive;
  font-size: 1.5rem;
  color: rgb(var(--col-vert));
  text-decoration: none;
  margin-bottom: 0.18em;
  transition: color 0.13s;
  display: block;
  text-align: center;
}
.header-link.current,
.header-link:active { color: rgb(var(--col-brun)); }
.header-link:hover { color: rgb(var(--col-vert-clair)); }

.header-link, .logo, .collection-link {
  text-decoration: none;
  color: inherit;
}

a, a:visited, a:active {
  text-decoration: none;
  color: inherit;
}

.side-links {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.3em;
}

/* Pour qu’ils gardent le style collection mais s’alignent à droite */
.side-link {
  text-align: right;
  padding: 0.12em 0.22em;
  position: relative;
  z-index: 1;
}



/* ===========================================================================================================================================================================================
/* ===========================================================================================================================================================================================
/* ===========================================================================================================================================================================================
/* ===========================================================================================================================================================================================
/*


/* ========================== */
/*      CONTENU PRINCIPAL     */
/* ========================== */

.menu-principal ul, .menu-langues ul {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: large;
}

.menu-principal li, .menu-langues li {
  margin: 0 1em 0 0;
}

.menu-principal a.active {
  color: rgb(var(--col-orange));
  font-weight: bold;
  text-shadow: 1px 1px 1px rgba(0,0,0,0.1);
}


.menu-langues {
  margin-left: auto; /* Si menu en flex */
}

.btn-lang {
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 1em;
  color: rgb(var(--col-brun));
  padding: 2px 8px;
  transition: color 0.2s;
}
.btn-lang:hover {
  color: rgb(var(--col-vert));
  text-decoration: underline;
}





/* Structure générale */
.collections-grid {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 3em;
  margin: 0 auto;
  max-width: 1100px;
  padding-top: 1.8em;
}

/* Grille de miniatures 2x3 */
.collections-thumbs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: repeat(3, 1fr);
  gap: 0.6em;
}
.thumb {
  width: 145px;
  height: 145px;
  background: rgb(var(--col-beige));
  border-radius: 16px;
  box-shadow: 0 4px 22px rgb(var(--col-noir))1;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  cursor: pointer;
  border: 8px solid transparent;
  transition: box-shadow 0.18s, border-color 0.13s;
  position: relative;
  box-shadow: inset 0 0 12px rgb(var(--col-vert), 0.6), 0 8px 24px rgb(var(--col-noir), 0.4);
}
.thumb.selected,
.thumb:hover {
  border-color: rgb(var(--col-vert-clair));
  box-shadow: inset 0 0 12px rgb(var(--col-vert), 0.8), 0 8px 24px rgb(var(--col-noir), 0.6);
}
.thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* ============================================================================================*/
/* Navigation verticale des miniatures (↑ ↓) */
/*============================================================================================*/

.collections-thumbs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}


.thumbs-layout {
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
}

.thumbs-arrow {
  font-size: 50px;
  color: rgb(var(--col-vert));
  cursor: pointer;
  opacity: 0.6;
  transition: opacity 0.2s ease;
  user-select: none;
  padding: 0 5px;
}

.thumbs-nav {
  font-size: 50px;
  color: rgb(var(--col-orange-clair));
  cursor: pointer;
  user-select: none;
  opacity: 0.5;
  transition: opacity 0.3s;
}

.thumbs-nav-last:hover {
  opacity: 1;
  transform: translateX(-5px);
}
.thumbs-nav-next:hover {
  opacity: 1;
  transform: translateX(5px);
}

.top-arrow {
  align-self: flex-start; /* à gauche */
  margin-left: -10px;     /* décale un peu à gauche si besoin */
}

.bottom-arrow {
  align-self: flex-end;   /* à droite */
  margin-right: -10px;    /* décale un peu à droite si besoin */
}

.thumbs-block {
  display: grid;
  grid-template-columns: repeat(2, auto);
  gap: 8px;
}


.thumbs-zone {
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto auto; /* 3 lignes : top, middle, bottom */
  align-items: center;
  gap: 12px;
}

.thumbs-nav.thumbs-nav-last {
  grid-row: 1; /* Haut */
  grid-column: 1; /* Gauche */
}

.collections-thumbs {
  grid-row: 1 / span 3; /* Centré verticalement sur les 3 lignes */
  grid-column: 2;
}

.thumbs-nav.thumbs-nav-next {
  grid-row: 3; /* Bas */
  grid-column: 3; /* Droite */
}

/* ============================================================================================ */




/* Grande illustration à droite */
.collections-detail {
  width: 484px;
  height: 484px; /* carré strict pour ratio 3*145 + 2*1.2em d'espacement ! */
  background: rgb(var(--col-beige));
  border-radius: 16px;
  box-shadow: 0 4px 22px rgb(var(--col-noir) , 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  cursor: pointer;
  border: 8px solid transparent;
  transition: box-shadow 0.18s, border-color 0.13s;
  position: relative;
}
.detail-img-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.detail-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* == Overlay Bandeau Bas == */
.detail-overlay-bar {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;

  /* Hauteur dynamique selon contenu */
  height: auto;
  padding: 1.2em 2em;

  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;

  /* Fond flouté avec couleur semi-transparente */
  background: rgba(var(--col-brun), 0.3); /* ou var(--col-vert-alpha) si défini */
  backdrop-filter: blur(var(--bar-blur));

  /* Apparition/disparition fluide */
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;

  box-sizing: border-box;
  z-index: 2;
}
.detail-img-wrap:hover .detail-overlay-bar,
.detail-img-wrap:focus-within .detail-overlay-bar {
  opacity: 1;
  pointer-events: auto;
}

/* Les infos à gauche (nom/prix) */
.detail-info-left {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 0.25em;
  flex: 1;
  color: rgb(var(--col-beige-clair));
  text-shadow: 0px 0px 6px rgba(var(--col-noir),0.7);
}

/* Ligne combinée Titre + Prix */
.detail-title-line {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  gap: 0.4em;
  flex-wrap: wrap;
}

/* Nom de la pièce */
.detail-title {
  font-family: var(--font-texte);
  font-weight: 600;
  font-size: 1.8em;
  color: rgb(var(--col-beige));
  text-shadow: 0px 0px 6px rgba(var(--col-noir),0.7);
  line-height: 1.2;
}

/* Prix à côté du titre */
.detail-prix {
  font-family: var(--font-texte);
  font-style: italic;
  font-weight: 600;
  font-size: 1.8em;
  text-shadow: none;
  color: rgb(var(--col-beige));
}

/* Description en dessous */
.detail-desc {
  font-family:  var(--font-texte);
  font-style: italic;
  font-size: 1em;
  color: rgb(var(--col-beige-clair));
  line-height: 1.4;
  margin-top: 0.25em;
}

/* Bouton panier */
.btn-panier {
  border: none;
  background: rgba(var(--col-blanc),0.58);
  border-radius: 50%;
  width: 56px; height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  position: relative;
  margin-left: 0.6em;
  box-shadow: 0 1px 8px rgb(var(--col-brun));
  transition: background 0.14s;
  z-index: 5;
}
.btn-panier:hover,
.btn-panier:focus {
  background: rgb(var(--col-blanc));
}

.panier-ajout .panier-svg-shape .panier-path {
  fill: rgb(var(--col-brun));
  stroke: rgb(var(--col-brun));
}

.btn-panier:hover .panier-svg-shape .panier-path,
.btn-panier:focus .panier-svg-shape .panier-path {
  fill: rgb(var(--col-orange-clair));
  stroke: rgb(var(--col-orange-clair));
}


.icon-panier-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(var(--col-blanc),0.47);
  box-shadow: 0 1.5px 7px rgb(var(--col-noir))2;
  transition: box-shadow 0.15s, background 0.2s;
}
.btn-panier:hover .icon-panier-wrap,
.btn-panier:focus .icon-panier-wrap {
  background: rgba(var(--col-blanc),0.78);
  box-shadow: 0 4px 18px rgba(var(--col-brun),0.78);
}
.icon-panier {
  width: 28px;
  height: 28px;
  display: block;
  pointer-events: none;
}

/* Bulle info au survol */
.bubble-panier {
  display: none;
  position: absolute;
  left: 58px; /* À droite du bouton */
  top: 50%;
  transform: translateY(-50%);
  padding: 0.58em 1.25em;
  background: rgb(var(--col-blanc),0.9);
  border-radius: 1.5em;
  box-shadow: 0 3px 12px rgb(var(--col-noir))1;
  color: var(--overlay-info-color);
  font-size: 1.02em;
  font-family: 'Montserrat', Arial, sans-serif;
  font-weight: 600;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.15s, left 0.18s;
  z-index: 8;
}
.btn-panier:hover .bubble-panier,
.btn-panier:focus .bubble-panier {
  display: block;
  opacity: 1;
  left: -180px;
}

/* === PANIER SVG === */
.panier-svg-shape .panier-path {
  fill: var(--panier-color, var(--col-brun));
  stroke: var(--panier-color,var(--col-brun));
  stroke-width: 22;
}

.zoomable {
  cursor: zoom-in;
}

.btn-panier {
  cursor: pointer;
}

.cursor-zoom {
  cursor: zoom-in;
}
.cursor-default {
  cursor: default;
}


/* ===========================================================================================================================================================================================
/* ===========================================================================================================================================================================================
/* ===========================================================================================================================================================================================
/* ===========================================================================================================================================================================================








/* ===========================================================================================================================================================================================
/* ===========================================================================================================================================================================================

/* ==========================
   RESPONSIVE
========================== */

/* Responsive : mobile, passe en colonne */
@media (max-width: 850px) {
  .collections-grid {
    flex-direction: column;
    align-items: center;
    gap: 2em;
  }
  .collections-thumbs {
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(2, 1fr);
  }
  .collections-detail {
    width: 94vw;
    max-width: 98vw;
    height: 350px;
  }
}


@media (max-width: 1000px) {
  .collections-header {
    flex-direction: column;
    align-items: stretch;
    padding: 24px 0 0 0;
    min-height: unset;
  }
  .collections-menu {
    flex-direction: column;
    gap: 1em;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin-bottom: 18px;
  }
  .header-side {
    flex-direction: row;
    align-items: flex-end;
    justify-content: center;
    gap: 30px;
    margin: 0 auto;
    min-width: unset;
  }
  .links {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }
  .logo { width: 72px; height: 72px; }
  .collections-thumbs {
    grid-template-columns: repeat(2, minmax(110px, 1fr));
    gap: 1.3em;
  }
  .collections-detail {
    min-width: 98vw;
    max-width: 98vw;
    padding: 1.4em 0.7em 1.7em 0.7em;
  }
}
@media (max-width: 700px) {
  .collections-menu {
    gap: 2vw;
    flex-wrap: wrap;
    justify-content: center;
  }
  .header-side {
    flex-direction: column;
    align-items: center;
    margin: 0 auto;
    gap: 7px;
  }
  .logo { width: 52px; height: 52px; margin-bottom: 5px; }
  .header-link { font-size: 1.02rem; }
  .collections-thumbs {
    grid-template-columns: repeat(1, minmax(100px, 1fr));
    gap: 1em;
  }
  .collections-detail {
    border-radius: 18px;
    padding: 1em 0.3em 1em 0.3em;
  }
}
@media (max-width: 500px) {
  .collections-header { padding: 0.7em 0.1em; }
  .collections-content { margin-top: 22px; }
  .logo { width: 42px; height: 42px; }
  .collection-title { font-size: 1.15em; }
}

/* ------------------------------------
   Responsive quick fix (mobile/tablette)
------------------------------------ */
@media (max-width: 1000px) {
  .collections-grid {
    flex-direction: column;
    align-items: center;
    gap: 2.1em;
  }
  .collections-detail {
    width: 98vw; height: 98vw; max-width: 470px; max-height: 470px;
  }
}



/* =========================== */
/*   AJOUTS DE recup.css      */
/* =========================== */

/* === Bloc image de la pièce === */
.Prod-Img {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.7em;
}

.img-thumb {
  display: inline-flex; /* ou flex si tu veux centrer le contenu */
  justify-content: center;
  align-items: center;


  border-radius: 8px;
  /*border: 0px solid rgb(var(--col-beige));
  background: rgb(var(--col-beige-clair));*/
  cursor: pointer;
  transition: box-shadow 0.2s;
  overflow: hidden; /* important si l'image dépasse */
}

.img-thumb:hover {
box-shadow: 0 0 0 20px rgba(var(--col-vert-clair), 0.9);

}

.img-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}


input[type="text"],
input[type="number"],
input[type="email"],
input[type="date"],
textarea,
select {
  padding: 7px 10px;
  border-radius: 7px;
  border: 1.2px solid   rgb(var(--col-brun-clair));
  background: rgb(var(--col-beige-clair));
  color:  rgb(var(--col-brun));
  font-size: 1.1em;
  outline: none;
  transition: border 0.2s, box-shadow 0.2s;
  margin-bottom: 0.7em;
  width: 100%;
  box-sizing: border-box;
}
input[type="text"]:focus,
input[type="number"]:focus,
input[type="email"]:focus,
input[type="date"]:focus,
textarea:focus,
select:focus {
  border-color: var(--col-vert);
  box-shadow: 0 0 0 2px rgb(var(--col-vert-clair),0.5);
}   
        

/* === Bouton loupe (zoom) === */
.img-zoom-btn {
  position: absolute;
  top: 6px; right: 8px;
  background:rgb(var(--col-beige-clair));
  border: none;
  font-size: 1.3em;
  border-radius: 50%;
  cursor: pointer;
  padding: 3px 8px;
  opacity: 0.85;
  z-index: 4;
  box-shadow: 0 2px 6px rgb(var(--col-noir))1;
  display: none;
}
.Prod-Img:hover .img-zoom-btn {
  display: inline-block;
}

/* === Bouton pour ajouter une image === */
.Bt-Img {
  background: rgb(var(--col-orange-clair));
  color: rgb(var(--col-beige-clair));
  font-weight: 600;
  font-family: var(--font-texte);  /* Assure-toi que c'est la même variable utilisée dans .Bt-Add__text */
  font-size: 1em;
  font-style: italic;
  border: 1px solid rgb(var(--col-orange-foncé));
  cursor: pointer;
  border-radius: 10px;
  padding: 0;
  margin: 0;
  width: 105px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 10px 18px 19px 0 rgba(var(--col-noir), 0.2);
  transition: background 0.18s, box-shadow 0.18s;
}

.Bt-Img:hover {

  background: rgb(var(--col-vert-clair));
  border: 1px solid rgb(var(--col-vert));
  transform: translateY(-7px);
  box-shadow: 0px 15px 20px rgb(var(--col-vert));
}
.Prod-Img {
  background: none !important;
  box-shadow: none !important;
}



/* === État modifié sur bouton modifier === */
.btn-modified {
  background:rgb(var(--col-orange-clair)) !important; /* jaune/orangé, modifie si tu veux */
  color:rgb(var(--col-brun)) !important;
  border: 2px solid rgb(var(--col-orangeo)) !important;
  transition: background 0.2s;
}
/* Bordure verte sur input modifié */
.input-modified {
  border: 2px solid rgb(var(--col-vert-clair)) !important;
  background: rgb(var(--col-beige-clair))!important;
  box-shadow: 0 0 0 2px rgb(var(--col-vert));
}

/* === Section des blocs collection === */
.collection-block {
  margin: 50px auto;
  max-width: 1600px;
  width: 80%;
  display: block;
}



/* === Cacher l'input file === */
input[type="file"].input-file {
  display: none !important;
}

.fiche-piece {
  position: relative;
  /* ... garde tes autres styles ... */
}


/* ==========================
   BANNIÈRE INDISPONIBLE
========================== */

.indispo-overlay {
  position: absolute;
  inset: 0;
  background: rgba(var(--col-orange), 0.28); /* Opacité à ajuster */
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 50;
  pointer-events: none;
}

.indispo-text {
  display: inline-block;
  color: rgba(var(--col-blanc), 1);
  font-family: Montserrat, sans-serif;
  font-weight: bold;
  font-size: 2.2em;
  text-transform: uppercase;
  transform: rotate(-24deg);
  text-shadow: 0 2px 8px rgba(var(--col-noir), 0.8);
  letter-spacing: 0.04em;
  pointer-events: none;

}




.stock-corner {
  position: absolute;
  top: 0.4em;
  left: 0.4em;
  background: rgba(var(--col-orange), 0.50);
  color: rgba(var(--col-blanc), 1);
  border-radius: 8px;
  font-family: sans-serif;
  font-size: 1.06em;
  font-weight: normal;
  z-index: 5;
  text-shadow: 0 2px 6px rgba(var(--col-blanc), 0.9),
               0 1px 3px rgba(var(--col-noir), 0.2);
  pointer-events: none;
  max-width: 90%; /* optionnel pour ne pas dépasser l’image */
  white-space: pre-line;
  box-shadow: 0 1px 4px rgba(var(--col-noir), 0.2);
  padding: 0.2em 0.4em;
}



/*===============================================================================*/

input:required:invalid,
select:required:invalid,
textarea:required:invalid {
  border: 2px solid rgb(var(--col-orange));
  background-color: rgba(var(--col-orange), 0.15);
}

input.invalid,
select.invalid,
textarea.invalid {
  border: 2px solid rgb(var(--col-orange-foncé));
  background-color: rgba(var(--col-orange), 0.15);
}

/* Popup flottante d'erreur */
.popup-erreur {
  position: absolute;
  background-color: rgba(var(--col-orange-foncé), 0.95);
  color: white;
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 0.85em;
  z-index: 99;
  top: -35px;
  left: 0;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.invalid:hover .popup-erreur {
  opacity: 1;
}


.img-thumb-container {
  position: relative;
  display: inline-block;
}

.img-zoom-icon {
  position: absolute;
  top: 5px;
  right: 5px;
  font-size: 18px;
  background:rgba(var(--col-vert), 0.40);
  border-radius: 50%;
  padding: 2px;
  pointer-events: auto;
  cursor: zoom-in;
}

.img-zoom-icon:hover {
  transform: scale(1.2);
}

.img-zoom-icon-article {
  position: absolute;
  top: 5px;
  right: 5px;
  font-size: 18px;
  background:rgba(var(--col-vert), 0.40);
  border-radius: 50%;
  padding: 2px;
  pointer-events: auto;
  cursor: zoom-in;
}

.img-zoom-icon-article:hover {
  transform: scale(1.2);
}


/* ============================================================================================== */

.tableau_noir {  
  position: fixed;
  top: 0;
  left: 0;
  background: rgba(var(--col-noir), 0.40);
  width: 500px;
  height: 500px;
   z-index:99;

}



/* ============================================================================================== */

/* ============================================================================================== */

/* ============================================================================================== */

/* ============================================================================================== */

/* ============================================================================================== */

/* ============================================================================================== */

/* ==============================================
   ✅ MODAL – VERSION ACTIVE POUR L’ADMIN (PIÈCES)
   ============================================== */

.modal-piece-images {
  position: fixed;
  inset: 0;
  background-color: rgba(var(--col-brun), 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  z-index: 999;
}
.modal-piece-images.open {
  opacity: 1;
  pointer-events: auto;
}

.modal-wrapper {
  display: flex;
  max-height: 90vh;
  gap: 2em;
  padding: 1em;
  box-sizing: border-box;
}

.modal-thumbs {
  display: flex;
  flex-direction: column;
  gap: 1em;
}
.modal-thumb {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 8px;
  border: 8px solid rgb(var(--col-beige));
  cursor: pointer;
  transition: border 0.2s;
}
.modal-thumb:hover {
  border-color: rgb(var(--col-orange-clair));
}
.modal-thumb.selected {
  border-color: rgb(var(--col-vert));
  box-shadow: 0 0 18px rgba(var(--col-noir), 0.2);
}

.modal-main {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-main:hover .modal-nav {
  opacity: 1;
}
.modal-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 35px;
  height: 35px;
  border-radius: 50%;
  background-color: rgba(var(--col-vert), 0.35);
  color: rgb(var(--col-blanc));
  font-size: 20px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  opacity: 0;
  transition: opacity 0.2s, background-color 0.2s;
}
.modal-nav-prev:hover,
.modal-nav-next:hover {
  color: rgb(var(--col-beige));
  background-color: rgba(var(--col-vert), 0.65);
}
.modal-nav-prev {
  left: 8px;
}
.modal-nav-next {
  right: 8px;
}

.modal-img-frame {
  background: none;
  padding: 0;
  border-radius: 16px;
  max-height: 80vh;
  max-width: 70vw;
  box-shadow: 0 0 18px rgba(var(--col-noir), 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  aspect-ratio: 1 / 1;
}

.modal-img-padding {
  background: rgb(var(--col-beige));
  padding: 24px;
  border-radius: 16px;
  height: 100%;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

#modal-main-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  border-radius: 12px;
}

.modal-close {
  position: absolute;
  top: 10px;
  right: 10px;
  background-color: rgba(var(--col-vert), 0.15);
  border: none;
  border-radius: 50%;
  width: 35px;
  height: 35px;
  color: rgb(var(--col-vert));
  font-size: 30px;
  font-weight: bold;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
  transition: background-color 0.2s, color 0.2s;
}
.modal-close:hover {
  background-color: rgba(var(--col-orange), 0.25);
  color: rgb(var(--col-orange));
}

.modal-img-index {
  position: absolute;
  bottom: 16px;
  right: 16px;
  min-width: 100px;
  min-height: 28px;
  background: rgb(var(--col-beige-clair),0.3);
  padding: 4px 10px;
  border-radius: 8px;
  border: 1px solid rgb(var(--col-orange-clair));
  font-size: 14px;
  font-family: var(--font-serif); /* ou une autre selon ton style */
  color: rgb(var(--col-orange-foncé)); /* ou une teinte bien lisible */
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
    overflow: hidden;

  z-index: 10;
}













.header-bar {
  width: 100%;
  padding: 1rem 2rem;
}

.header-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  gap: 2rem;
}

.header-left {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.menu-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.menu-row nav {
  flex-grow: 1;
}

.header-right {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.header-right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 85px; /* largeur minimale raisonnable */
  max-width: 10vw;  /* évite l'étirement */
}

.header-center .logo {
  display: block;
  width: 150px;
  height:150px;
  background: var(--logo) no-repeat center/contain;
}

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

.lang-active {
  padding: 0.3em 0.5em;
  font-size: 0.9em;
}

/* ========================================================
            FORMULAIRE LIEUX
===========================================================*/

.lieux-section {
  padding: 3rem 1rem;
  background: var(--fond-clair);
  border-top: 1px solid #ccc;
}

.lieux-section h2 {
  font-family: 'Great Vibes', cursive;
  font-size: 2.2rem;
  margin-bottom: 1rem;
}

.lieux-form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: flex-end;
  margin-bottom: 2rem;
}

.lieux-form input,
.lieux-form select {
  padding: 0.5rem 1rem;
  border: 1px solid var(--brun-clair);
  border-radius: 5px;
  font-size: 1rem;
  background-color: white;
}

.lieux-form input[type="text"],
.lieux-form input[type="number"] {
  width: 160px;
}

.lieux-form input[name="nom"] {
  width: 200px;
}

.lieux-form input[name="rue"] {
  width: 200px;
}

.lieux-form input[name="localite"] {
  width: 160px;
}

.lieux-form input[name="latitude"],
.lieux-form input[name="longitude"] {
  width: 120px;
}

.lieux-form select[name="type"] {
  width: 140px;
}

.lieux-form .checkbox {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* ============================================
   🌍 CARTO — Leaflet : Structure principale
   ============================================ */

/* Conteneur principal (liste + carte) */
.carte-layout {
  display: flex;             /* disposition en ligne */
  gap: 1rem;                 /* espace entre la liste et la carte */
  min-height: 520px;         /* hauteur minimum */
}

/* Colonne de gauche contenant les listes */
.carte-list {
  width: 32%;                /* largeur de la liste */
  background: rgb(var(--col-beige), 0.5); /* fond beige translucide */
  border-radius: 1rem;       /* angles arrondis */
  padding: 1rem;             /* marge interne */
}

/* Carte Leaflet à droite */
.carte-map {
  flex: 1;                   /* prend le reste de l’espace */
  min-height: 520px;         /* hauteur minimale */
  border-radius: 1rem;       /* angles arrondis */
  overflow: hidden;          /* cache les débordements */
}


/* ============================================
   📋 LISTES de lieux & personnes
   ============================================ */

/* UL de la liste (lieux ou personnes) */
.carte-ul {
  list-style: none;          /* pas de puce */
  margin: 0;
  padding: 0;
}

/* Élément LI d’un lieu ou d’une personne */
.carte-li {
  margin: 0.25rem 0;         /* espacement vertical */
}

/* Bouton cliquable dans chaque item */
.carte-li-btn {
  width: 100%;               /* occupe toute la largeur */
  text-align: left;          /* alignement du texte à gauche */
  display: grid;
  grid-template-columns: 20px 1fr; /* icône + texte */
  gap: 0.6rem;
  background: rgb(var(--col-blanc));      /* fond blanc */
  border: 1px solid rgba(var(--col-noir), 0.08); /* bordure discrète */
  border-radius: 0.75rem;    /* coins arrondis */
  padding: 0.6rem 0.8rem;    /* marges internes */
  cursor: pointer;
  transition:                /* transition douce */
    transform 0.12s ease,
    box-shadow 0.12s ease,
    border-color 0.12s ease;
}

/* Effet au survol */
.carte-li-btn:hover {
  transform: translateY(-1px);                      /* léger soulèvement */
  box-shadow: 0 2px 8px rgba(var(--col-noir), 0.06); /* ombre portée */
}

/* Bouton actif (sélectionné) */
.carte-li-btn.active {
  border-color: rgb(var(--col-orange));              /* contour orange */
  box-shadow: 0 0 0 2px rgba(var(--col-orange), 0.15) inset; /* halo intérieur */
}


/* ============================================
   🎯 PUCE & DOTS (icônes miniatures)
   ============================================ */

/* Petite puce ronde pour les lieux */
.pin.pin-lieu {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: rgb(var(--col-brun-clair));    /* brun clair */
  display: inline-block;
  margin-top: 0.3rem;
}

/* Dot verte pour les personnes dans les popups */
.dot.dot-vert {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: rgb(var(--col-vert-clair));    /* vert clair */
  display: inline-block;
  margin-right: 0.4rem;
  vertical-align: middle;
}


/* ============================================
   📝 EN-TÊTE LISTE
   ============================================ */

.carte-list-header h2 {
  margin: 0 0 0.25rem;
  font-size: 2rem;
  color: rgb(var(--col-vert));
}

.carte-list-header .hint {
  margin: 0 0 0.75rem;
  opacity: 0.7;
  font-size: 1rem;
}


/* ============================================
   📌 POPUPS Leaflet (lieux/personnes)
   ============================================ */

/* Titre principal du popup */
.popup-lieu h3 {
  margin: 0.2rem 0;
  font-size: 2.2rem;
  /*font-weight: bold;*/
  color: rgb(var(--col-vert));     /* vert principal */
}

/* Type du lieu ou rôle de la personne */
.popup-lieu p.type {
  margin: 0.2rem 0 0.4rem;
  font-style: italic;
  color: rgb(var(--col-brun));     /* brun ou autre teinte */
  opacity: 0.9;
}

/* Liste des personnes liées */
.popup-lieu .persons {
  margin: 0.3rem 0 0;
  padding-left: 1em;
  list-style: none;
}

/* Élément individuel d’une personne liée */
.popup-lieu .persons li {
  margin: 0.2rem 0;
  font-size: 0.95em;
  display: flex;
  align-items: center;
}

/* Message d’absence de personne */
.popup-lieu .muted {
  font-size: 0.9rem;
  color: #999;
  font-style: italic;
}


/* ========================
   📐 Carte : mise en page
   ======================== */

.carte-layout {
  display: flex;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

.carte-list {
  width: 25%;               /* liste plus étroite */
  max-width: 300px;
  padding: 1em;
}

.carte-map {
  width: 75%;
  height: 75vh;
}

.carte-wrapper {
  width: 70%;
  margin: 0 auto;
}

.thumbs-dots {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: 10px;
}
.thumbs-dots .dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 0;
  background:rgb(var(--col-vert));
  opacity: .35;
  cursor: pointer;
  transition: transform .15s ease, opacity .15s ease;
}
.thumbs-dots .dot:hover { opacity: .6; transform: scale(1.1); }
.thumbs-dots .dot.is-active {
  background: rgb(var(--col-orange));
  opacity: 1;
  transform: scale(1.15);
}

/* OFFICE – grille simple */
.Row { display:flex; gap:12px; align-items:flex-start; }
.Row--tight { gap:8px; }
.Col--2 { flex: 2 1 0; }
.Col--1 { flex: 1 1 0; }

.Field-Grid { display:grid; grid-template-columns: 1fr 1fr 1fr; gap:8px; }
.Field-Min { font-size:.85rem; color:#827864; display:flex; flex-direction:column; gap:4px; }

/* ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/* ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/* ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/* ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

/* container (on s’ancre sur #app-content pour battre tout style global) */
#app-content .af-articles     { max-width: 70%; margin: 2rem auto; }
#app-content .af-article-title{ text-align:center; margin:0 0 1.25rem; color: rgb(var(--col-vert)); }

/* grille 3 colonnes bien figée */
#app-content .af-grid{
  display:grid;
  grid-template-columns:minmax(220px,1fr) minmax(360px,2fr) minmax(240px,1fr);
  grid-template-areas:"photo texte infos";
  gap:2rem;
  align-items:start;
  margin:2rem 0;
  clear:both;            /* casse tout float externe */
  position:relative;
}
#app-content .af-col-photo{ grid-area:photo; justify-self:start; align-self:start; float:none!important; }
#app-content .af-col-texte{ grid-area:texte; }
#app-content .af-col-infos{ grid-area:infos; }

/* neutralisation SANS équivoque de tout effet hover/zoom/float */
#app-content .af-col-photo img.af-photo-main,
#app-content .af-col-photo img.af-thumb,
#app-content img.img-zoom-icon-article{
  float:none!important;
  position:static!important;
  transform:none!important;
  transition:none!important;
  filter:none!important;
  box-shadow:none!important;
  outline:none!important;
  cursor:zoom-in;
}
#app-content .af-col-photo img.af-photo-main:hover,
#app-content .af-col-photo img.af-thumb:hover,
#app-content img.img-zoom-icon-article:hover{
  transform:none!important;
  filter:none!important;
  box-shadow:none!important;
}

/* gabarits image */
#app-content .af-photo-main{ width:100%; max-width:280px; border-radius:12px; background:none; padding:0; display:block; }
#app-content .af-thumbs{ display:grid; grid-template-columns:repeat(3,90px); gap:.5rem; margin-top:.75rem; }
#app-content .af-thumb{ width:90px; height:90px; object-fit:cover; border-radius:8px; background:none; padding:0; }

/* texte */
#app-content .af-desc{ line-height:1.75; text-align:justify; text-align-last:left; }

/* encart infos */
#app-content .af-infos{ background:rgba(var(--col-brun),.06); padding:1rem; border-radius:12px; font-size:.95rem; }
#app-content .af-infos p{ margin:.5rem 0; }
#app-content .af-date{ font-weight:700; }
#app-content .af-lieu{ font-weight:700; color:rgb(var(--col-vert)); }
#app-content .af-personne{ color:rgb(var(--col-vert)); font-weight:600; }
#app-content .af-actions{ margin-top:.75rem; display:flex; gap:.5rem; flex-wrap:wrap; }
#app-content .af-btn{ display:inline-flex; align-items:center; gap:.4rem; padding:.5rem .8rem; border-radius:8px; background:rgb(var(--col-orange)); color:#fff; text-decoration:none; font-size:.9rem; }
#app-content .af-btn:hover{ background:rgb(var(--col-orange-clair)); }

@media (max-width:920px){
  #app-content .af-grid{ grid-template-columns:1fr; grid-template-areas:"photo" "texte" "infos"; }
  #app-content .af-photo-main{ max-width:100%; }
}



/* Mode résumé */
.af-article-summary {
  background: rgba(0,0,0,0.02);
  padding: .75rem;
  border-radius: 8px;
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.af-summary .af-photo-summary {
  width: 140px;
  height: 140px;
  object-fit: cover;
  border-radius: 8px;
}

.af-summary-text {
  flex: 1;
  font-size: .95rem;
  line-height: 1.4;
}
.af-summary-btn {
  color: rgb(var(--col-orange));
  cursor: pointer;
  margin-left: .25rem;
  font-weight: 600;
}
.af-summary-btn:hover {
  text-decoration: underline;
}


/* Si jamais un bloc infos restait, on le masque (par sécurité) */
.af-summary .af-col-infos{ display:none; }

/* Un peu d’air pour le texte */
.af-summary .af-col-texte .af-desc{ line-height:1.7; }


/* --- Summary mode for multi-article pages --- */
#app-content .af-grid.is-collapsed{
  grid-template-columns:140px 1fr;        /* photo + texte */
  grid-template-areas:"photo texte";
}

#app-content .af-grid.is-collapsed .af-col-infos{ display:none; }

#app-content .af-grid.is-collapsed .af-col-photo .af-photo-main{
  width:140px; height:140px; object-fit:cover; border-radius:10px;
}

/* clamp text (keeps HTML marks) */
#app-content .af-grid.is-collapsed .af-desc{
  display:-webkit-box; -webkit-line-clamp:4; -webkit-box-orient:vertical;
  overflow:hidden;
}

/* “Voir plus / Réduire” button */
#app-content .af-more{
  display:inline-block; margin-top:.5rem; padding:.25rem .5rem;
  font-size:.85rem; border-radius:6px; background:rgb(var(--col-orange));
  color:#fff; border:none; cursor:pointer;
}
#app-content .af-more:hover{ background:rgb(var(--col-orange-clair)); }


/*=============================================================================================================================================================*/

/* =======================================
   🛒 PANIER - ARTH & FACTS
   ======================================= */

/* === WRAPPER PRINCIPAL === */
.panier-wrapper {
  max-width: 70%;
  margin: 0 auto;
  display: flex;
  gap: 50px;
  align-items: flex-start;
  padding: 40px 0;
}

/* === COLONNE GAUCHE === */
.panier-left {
  flex: 1;
}

.panier-left h2 {
  font-family: var(--font-titre);
  font-style: italic;
  font-size: 3em;
  color: rgb(var(--col-orange));
  margin-bottom: 30px;
}

/* === LISTE DES ARTICLES === */
.panier-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.panier-item {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 15px 0;
  border-bottom: 1px solid rgba(var(--col-beige), 1);
}

/* === THUMBNAIL === */
.panier-item img.thumb {
  width: 100px;
  height: 100px;
  object-fit: cover;
  border-radius: 8px;
  cursor: zoom-in;
  box-shadow: 0 2px 5px rgba(var(--col-gris-shadow), 0.1);
}

/* === NOM DU PRODUIT === */
.panier-nom {
  flex: 1;
  font-family: var(--font-titre);
  font-style: italic;
  font-size:2em;
  color: rgb(var(--col-vert));
}

/* === PRIX UNITAIRE === */
.panier-prix {
  font-size: 1.1em;
  font-weight: bold;
  color: rgb(var(--col-brun));
  margin-left: auto;
}

/* === GESTION DES QUANTITÉS === */
.panier-qte {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: 20px;
}

.panier-qte .btn-qte {
  width: 32px;
  height: 32px;
  background-color: transparent;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  border: none;
  cursor: pointer;
}

.panier-qte .btn-qte.plus       { background-image: var(--qte-plus); }
.panier-qte .btn-qte.plus:hover { background-image: var(--qte-plus_hover); }

.panier-qte .btn-qte.moins       { background-image: var(--qte-moins); }
.panier-qte .btn-qte.moins:hover { background-image: var(--qte-moins_hover); }

.panier-qte .btn-qte.trash       { background-image: var(--qte-trash); }
.panier-qte .btn-qte.trash:hover { background-image: var(--qte-trash_hover); }

.panier-qte .qte {
  font-weight: bold;
  color: rgb(var(--col-vert));
  min-width: 20px;
  text-align: center;
}

/* === FOOTER PANIER === */
.panier-footer {
  margin-top: 30px;
  text-align: right;
}

.panier-total {
  font-family: "Adobe Caslon Pro", serif;
  font-style: italic;
  font-size: 2em;
  color: rgb(var(--col-orange));
  margin-bottom: 20px;
}

/* === BOUTONS ACTIONS === */
.panier-actions {
  display: flex;
  justify-content: flex-end;
  gap: 20px;
}

.panier-actions button {
  font-family: "Adobe Caslon Pro", serif;
  font-style: italic;
  font-size: 1em;
  padding: 10px 24px;
  border-radius: 5px;
  transition: 0.2s ease;
  border: none;
  cursor: pointer;
}

#btn-clear {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: transparent;
  color: rgb(var(--col-vert));
  border: none;
  padding: 0;
  font-family: "Adobe Caslon Pro", serif;
  font-style: italic;
  font-size: 1.2em;
  cursor: pointer;
  font-weight: bold;
}

#btn-clear:hover {
  color: rgba(var(--col-vert), 0.8);
  text-decoration: underline;
}

#btn-clear .icon-trash {
  display: inline-block;
  width:45px;
  height: 45px;
  background-image: var(--qte-trash);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  transition: filter 0.2s;
}

#btn-clear:hover .icon-trash {
  background-image: var(--qte-trash_hover);
}


#btn-validate {
  background: rgb(var(--col-orange));
  color: white;
  font-size: 1.2em;
}
#btn-validate:hover {
  background: rgb(var(--col-orange-clair));
}

/* === COLONNE DROITE === */
.panier-right {
  flex: 1;
  font-size: 1em;
  color: rgb(var(--col-brun));
}

.panier-right h3 {
  font-family: "Adobe Caslon Pro", serif;
  font-size: 1.6em;
  color: rgb(var(--col-orange));
  margin-bottom: 15px;
}

.panier-right p {
  margin-bottom: 12px;
  line-height: 1.5em;
}

.panier-right ul {
  list-style: none;
  padding: 0;
  margin-top: 15px;
}

.panier-right li {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.panier-right input[type="radio"] {
  transform: scale(1.2);
  accent-color: rgb(var(--col-vert));
}

.panier-right {
  display: flex;
  flex-direction: column;
  align-items: flex-start; /* ✅ force tout à gauche */
  justify-content: flex-start;
}

.success-msg {
  text-align: center;
  margin-top: 1rem;
  font-style: italic;
  color: rgb(var(--col-vert));
  font-size: 1.1rem;
}


.btn-panier.btn-added {
  background-color: rgb(var(--col-vert)) !important;
  color: #fff !important;
  transition: background-color 0.3s, color 0.3s;
}

/* Forcer l’affichage permanent des détails quand .always-show est présent */
.detail-img-wrap.always-show .detail-overlay-bar {
  opacity: 1 !important;
  transform: none !important;
  visibility: visible !important;
  pointer-events: auto; /* pour cliquer sur le bouton panier */
}

/* Neutralise le :hover si tu avais une règle du type :
   .detail-img-wrap:hover .detail-overlay-bar { opacity: 1; ... } */
.detail-img-wrap.always-show:hover .detail-overlay-bar {
  opacity: 1;
  transform: none;
}
.fiche-piece-mention-global {
    margin-top: 15px;
    text-align: center;
    font-size: 0.9em;
    color: rgb(var(--col-vert-clair));
    grid-column: 1 / span 3; /* pour l’étendre sous toute la grille */
}
/*
.af-disclaimer {
    position: fixed;
    bottom: 15px;
    left: 50%;
    transform: translateX(-50%);
    max-width: 90%;
    background: rgba(255, 255, 255, 0.9);
    color: rgb(var(--col-vert));
    font-size: 0.9em;
    padding: 8px 14px;
    border-radius: 8px;
    text-align: center;
    box-shadow: 0 2px 6px rgba(0,0,0,0.15);
    z-index: 1000;
    display: block; 
}
*/

.index-disclaimer {
  display: none;
}

/* Affiché uniquement sur mobile si tu veux */
@media (max-width: 768px) {
    .index-disclaimer {
        display: block;
    }
}
.fiche-piece-mention-top {
    text-align: center;
    color: rgb(var(--col-orange));
    font-family: "Adobe Caslon Pro", serif;
    font-style: italic;
    font-size: 1.2em;
    margin-bottom: 10px;
    margin-top: 5px;
    opacity: 0.9;
}


/* ===========================
   THEMA — Titres des sections
   =========================== */
.theme-section {
  margin: 80px 0 100px; /* espace vertical entre les blocs */
  text-align: center;
}

.theme-title {
  font-size: 2em;
  color: rgb(var(--col-vert));
  text-align: center;
  letter-spacing: 0.5px;
  margin-top: -20px;
  margin-bottom: 10px;
  position: relative;
}

/* Petite ligne décorative sous le titre */
.theme-title::after {
  content: "";
  display: block;
  width:100px;
  height: 2px;
  background-color: rgb(var(--col-orange));
  margin: 5px auto 0;
  border-radius: 2px;
}


html { scroll-behavior: smooth; }

.af-highlight {
  background: linear-gradient(to right, rgb(var(--col-orange)), transparent);
  transition: background 0.8s ease;
}





/*=============================================================================================================================================================*/

/*=============================================================================================================================================================*/





.retrait-list {
  margin-left: 20px;       /* ✅ petit retrait élégant */
  margin-top: 10px;
  display: none;           /* cachée par défaut */
  flex-direction: column;
  gap: 10px;
  align-items: flex-start; /* ✅ force l’alignement des boutons à gauche */
  width: 100%;             /* évite le centrage automatique */
}

.retrait-item {
  display: flex;
  align-items: center;
  gap: 10px;
}

.btn-retrait, .btn-map {
  width: 200px;
  height: 40px;
  border-radius: 8px;
  border: 0px solid rgb(var(--col-orange));
  cursor: pointer;
  transition: all 0.2s ease;
}

.btn-retrait {
  background-color:  rgb(var(--col-beige));
  font-family: "Adobe Caslon Pro", serif;
  font-size: 0.95em;
  color: rgb(var(--col-orange));
}

.btn-retrait:hover,
.btn-retrait.selected {
  background-color: rgb(var(--col-orange));
  color: #fff;
  transform: scale(1.03);
}

.btn-map {
  width: 40px;
  height: 40px;
  background-image: var(--map);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.btn-map:hover {
  background-image: var(--map-select);
  transform: scale(1.1);
}


#message {
  display: block;
  width: 100%;
  min-height: 120px;
  height: auto;
  overflow-y: auto;        /* permet le scroll et le resize manuel */
  resize: vertical;        /* laisse l'utilisateur agrandir */
  transition: height 0.25s ease;
}

#contactForm textarea[name="message"]{
  box-sizing: border-box;
  min-height: 120px;        /* base confortable */
  height: auto;             /* laisse le JS ajuster */
  overflow-y: hidden;       /* pas de double scroll interne */
  resize: vertical !important; /* laisser l’utilisateur agrandir si besoin */
}
/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

.login-modal {
  position: fixed;
  inset: 0; /* équivaut à top:0; right:0; bottom:0; left:0; */
  display: flex;
  justify-content: center;
  align-items: center;
  background: rgba(0,0,0,0.6);
  z-index: 9999;
  overflow: hidden;
}

.login-box {
  background: var(--beige);
  color: var(--brun);
  padding: 24px 30px;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
  text-align: center;
  width: 300px;
  max-width: 90%;
  animation: popupZoom 0.25s ease;
}

.login-box h2 {
  margin-bottom: 15px;
  font-size: 1.3em;
  color: var(--orange);
  font-family: "Adobe Caslon Pro", serif;
}

.login-box input {
  width: 100%;
  margin-bottom: 10px;
  padding: 8px 10px;
  border: 1px solid var(--brun);
  border-radius: 6px;
  font-family: "Adobe Caslon Pro", serif;
}

#btn-login {
  background: var(--orange);
  color: #fff;
  border: none;
  padding: 8px 16px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.2s ease;
}
#btn-login:hover {
  background: var(--orange-clair);
}

/* --- ANIMATION --- */
@keyframes popupZoom {
  from {
    opacity: 0;
    transform: scale(0.8);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

#modalPieceImages {
  opacity: 0;
  transition: opacity 0.3s ease;
}

#modalPieceImages[aria-hidden="false"] {
  opacity: 1;
}


/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

@keyframes fadeIn {
  from { opacity: 0; transform: translate(-50%, 20px); }
  to { opacity: 1; transform: translate(-50%, 0); }
}

/* =========================================================
   📱 PAGE INDEX – Responsive mobile
   ========================================================= */
@media (max-width: 768px) {

  /* SVG d’arrière-plan */
  .svg-curve {
    position: absolute !important;
    top: 30vh !important;  /* descend un peu le motif sous le logo */
    left: 0;
    width: 100%;
    height: auto;
    z-index: 0;
  }

  /* Centrage simplifié (pas de translate complexe) */
  .splash-content {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    margin: 40vh auto 0;
    text-align: center;
    gap: 0.6em;
    z-index: 10;
  }

  /* Logo et handmade plus petits */
  .logo {
    width: 140px;
    height: 140px;
    background-size: contain;
  }

  .handmade {
    width: 100px;
    height: 60px;
  }

  /* Bouton “Entrer” adapté tactile */
  .btn-enter {
    display: inline-block;
    margin-top: 1em;
    padding: 12px 24px;
    font-size: 1.2em;
    font-family: var(--font-texte);
    color: rgb(var(--col-blanc));
    background: rgb(var(--col-orange));
    border-radius: 8px;
    box-shadow: 0 3px 8px rgba(var(--col-noir), 0.2);
    transition: background 0.2s ease, transform 0.1s ease;
  }
  .btn-enter:hover {
    background: rgb(var(--col-orange-clair));
    transform: translateY(-2px);
  }

  /* Disclaimer visible sur mobile */
  .index-disclaimer {
    display: block;
    animation: fadeIn 0.8s ease forwards;
  }
  .index-disclaimer {
    position: fixed;
    bottom: 15px;
    left: 50%;
    transform: translateX(-50%);
    max-width: 90%;
    background: rgba(255, 255, 255, 0.9);
    color: rgb(var(--col-vert));
    font-size: 0.9em;
    padding: 8px 14px;
    border-radius: 8px;
    text-align: center;
    box-shadow: 0 2px 6px rgba(0,0,0,0.15);
    z-index: 1000;
    display: block; /* toujours visible */
    animation: fadeIn 0.8s ease forwards;
}
}
