/* ==========================================================================
   Lumi?res ? th?me enfant de classic
   Le Petit Atelier des Lumi?res ? bijoux faits main
   Direction : ? l'?crin ? ? ivoire chaud, encre brune, or champagne,
   serif Cormorant Garamond pour les titres, Mulish pour le texte.
   Pens? mobile-first : la majorit? des visiteurs sont sur t?l?phone/iPad.
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Fontes auto-h?berg?es (RGPD : aucun appel ? Google)
   -------------------------------------------------------------------------- */
@font-face {
  font-family: 'Cormorant Garamond';
  src: url('/themes/lumieres/assets/fonts/CormorantGaramond-500-normal.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Cormorant Garamond';
  src: url('/themes/lumieres/assets/fonts/CormorantGaramond-600-normal.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Cormorant Garamond';
  src: url('/themes/lumieres/assets/fonts/CormorantGaramond-500-italic.woff2') format('woff2');
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Mulish';
  src: url('/themes/lumieres/assets/fonts/Mulish-400-normal.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Mulish';
  src: url('/themes/lumieres/assets/fonts/Mulish-600-normal.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

/* --------------------------------------------------------------------------
   2. Palette & variables
   -------------------------------------------------------------------------- */
:root {
  --lum-ivoire: #faf7f1;        /* fond g?n?ral, papier de soie */
  --lum-creme: #f1eadd;         /* bandes de section */
  --lum-encre: #2b2520;         /* texte principal, brun-noir chaud */
  --lum-encre-douce: #6b6157;   /* texte secondaire */
  --lum-or: #b08d57;            /* or champagne, accent principal */
  --lum-or-fonce: #8f7044;      /* or au survol */
  --lum-filet: #e3dac9;         /* filets et bordures fines */
  --lum-nuit: #262019;          /* pied de page */
  --lum-serif: 'Cormorant Garamond', Georgia, serif;
  --lum-sans: 'Mulish', 'Segoe UI', sans-serif;
}

::selection { background: var(--lum-or); color: #fff; }

/* --------------------------------------------------------------------------
   3. Base : fond, texte, titres, liens
   -------------------------------------------------------------------------- */
body {
  background: var(--lum-ivoire);
  color: var(--lum-encre);
  font-family: var(--lum-sans);
  font-size: 0.9750rem;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4,
.h1, .h2, .h3 {
  font-family: var(--lum-serif);
  font-weight: 600;
  color: var(--lum-encre);
  letter-spacing: 0.01em;
}

a { color: var(--lum-or-fonce); }
a:hover { color: var(--lum-or); }

p { color: inherit; }

/* Titres de sections (Produits phares, Nouveaux produits?) :
   centr?s, serif, soulign?s d'un fin filet dor? */
.products-section-title,
#content-wrapper .page-home h2,
.featured-products h2 {
  font-family: var(--lum-serif);
  font-weight: 500;
  font-size: clamp(1.7rem, 4.5vw, 2.4rem);
  text-align: center;
  text-transform: none;
  color: var(--lum-encre);
  margin: 2.5rem 0 0.75rem;
  position: relative;
  padding-bottom: 1.1rem;
}
.products-section-title::after,
.featured-products h2::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 56px;
  height: 1px;
  background: var(--lum-or);
}

/* --------------------------------------------------------------------------
   4. Bandeau haut + en-t?te
   -------------------------------------------------------------------------- */
.header-nav {
  background: var(--lum-encre);
  color: #efe9df;
  border-bottom: none;
  max-height: none;
}
.header-nav .container { padding-top: 0.2rem; padding-bottom: 0.2rem; }
.header-nav #_desktop_contact_link,
.header-nav .contact-link,
.header-nav a,
.header-nav span {
  color: #efe9df;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
}
.header-nav .user-info a:hover,
.header-nav a:hover { color: var(--lum-or); }

/* Top-bar : glyphes material-icons (connexion, panier) centres verticalement avec le texte
   (ils etaient cales trop bas a cause de leur line-height). */
#header .header-nav .material-icons { line-height: 1; }
#header .header-nav .user-info a,
#header .header-nav .blockcart a {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}
#header .header-nav .blockcart {
  background: transparent;
}

/* Bandeau bureau : tout est centre verticalement sur une ligne de 44px,
   on neutralise les marges/paddings disparates de classic */
@media (min-width: 768px) {
  #header .header-nav .container > .row > .hidden-sm-down {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 44px;
  }
  #header .header-nav .container > .row > .hidden-sm-down > div {
    float: none;
    display: flex;
    align-items: center;
    min-height: 44px;
    margin-top: 0;
    margin-bottom: 0;
  }
  #header .header-nav .right-nav {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 1.6rem;
  }
  #header .header-nav .right-nav > div { margin: 0; }
  /* classic : #header .header-nav #_desktop_contact_link #contact-link
     (trois ID !) -> on aligne la specificite */
  #header .header-nav #_desktop_contact_link #contact-link {
    margin: 0;
    padding-top: 0;
    padding-bottom: 0;
  }
  #header .header-nav #_desktop_contact_link #contact-link a,
  #header .header-nav #_desktop_contact_link #contact-link span {
    color: #efe9df;
  }
  #header .header-nav #_desktop_user_info .material-icons { color: #efe9df; }
  #header .header-nav .user-info {
    display: flex;
    align-items: center;
    height: auto;
    padding: 0;
  }
  #header .header-nav .blockcart {
    display: flex;
    align-items: center;
  }
  #header .header-nav .user-info { margin-top: 0; }
  #header .header-nav .user-info a {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-left: 0;
  }
  #header .header-nav .user-info .material-icons {
    color: inherit;
    font-size: 1.15rem;
  }
  #header .header-nav .blockcart {
    height: auto;
    padding: 0;
  }
  #header .header-nav .blockcart .header {
    margin-top: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
  }
  #header .header-nav .blockcart .material-icons { font-size: 1.2rem; }
}
/* --- Etat connecte (lien Deconnexion) + panier rempli : forcer la charte ---
   classic preface ses regles par #header (plus specifiques que les notres) :
     #header .header-nav .blockcart a{color:#7a7a7a}
     #header .header-nav .blockcart a:hover{color:#24b9d7}
     #header .header-nav .cart-preview.active{background:#24b9d7}  <- panier bleu
     .account-list a:hover{color:#24b9d7}
   On repasse tout en creme (#efe9df) / or, en prefixant pareil + !important. */
#header .header-nav a,
#header .header-nav span,
#header .header-nav .user-info a,
#header .header-nav .blockcart a,
#header .header-nav .blockcart .material-icons,
#header .header-nav .cart-preview .shopping-cart {
  color: #efe9df !important;
}
#header .header-nav a:hover,
#header .header-nav .user-info a:hover,
#header .header-nav .blockcart a:hover,
#header .header-nav .blockcart.active a:hover {
  color: var(--lum-or) !important;
}
/* Panier rempli : on tue le fond bleu, texte/icone en creme (or au survol) */
#header .header-nav .blockcart.active,
#header .header-nav .cart-preview.active {
  background: transparent !important;
}
#header .header-nav .cart-preview.active a,
#header .header-nav .cart-preview.active i,
#header .header-nav .cart-preview.active .material-icons {
  color: #efe9df !important;
}
#header .header-nav .blockcart .cart-products-count {
  color: var(--lum-or) !important;
  font-weight: 600;
}

#header {
  background: var(--lum-ivoire);
  box-shadow: none;
  border-bottom: 1px solid var(--lum-filet);
}
#header .header-top {
  background: var(--lum-ivoire);
  padding-top: 0.9rem;
  padding-bottom: 0.35rem;
}

/* Menu principal : capitales espac?es, soulignement dor? au survol */
#header .top-menu a[data-depth="0"] {
  font-family: var(--lum-sans);
  font-weight: 600;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--lum-encre);
  position: relative;
  padding-bottom: 0.3rem;
}
#header .top-menu a[data-depth="0"]::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 0;
  height: 1px;
  background: var(--lum-or);
  transition: width 0.25s ease;
}
#header .top-menu a[data-depth="0"]:hover { color: var(--lum-or-fonce); }
#header .top-menu a[data-depth="0"]:hover::after { width: 100%; }
#header .top-menu .sub-menu {
  border-top: 2px solid var(--lum-or);
  box-shadow: 0 14px 30px rgba(43, 37, 32, 0.10);
}

/* Logo : calligraphie en haut, centr?e, taille contenue (PNG @2x => net) */
#header #_desktop_logo img,
#header .top-logo img {
  height: auto;
}

@media (min-width: 768px) {
  /* l'en-t?te devient une colonne : logo centr? en haut, menu en dessous */
  #header .header-top > .container > .row:first-child {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  #header #_desktop_logo {
    flex: none;
    width: 100%;
    max-width: none;
    text-align: center;
    padding: 0.5rem 0 0.9rem;
  }
  #header #_desktop_logo h1 { margin: 0; }
  #header #_desktop_logo a { display: inline-block; }
  #header #_desktop_logo img {
    max-width: clamp(250px, 34vw, 400px);
  }
  #header .header-top-right {
    flex: none;
    width: 100%;
    max-width: none;
    border-top: 1px solid var(--lum-filet);
    padding-top: 0.55rem;
  }
  /* menu centr? */
  #header .header-top-right .menu { width: 100%; }
  #header ul#top-menu {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
}

@media (min-width: 992px) {
  /* la recherche se glisse ? droite du menu sans le d?centrer */
  #header .header-top-right { position: relative; }
  #header .header-top-right .search-widget,
  #header #search_widget {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    margin: 0;
  }
  #header .search-widget form input[type="text"] { min-width: 9.5rem; }
}

/* --------------------------------------------------------------------------
   En-t?te mobile (<768px) : barre ivoire, burger et panier bien visibles,
   logo calligraphi? centr?
   -------------------------------------------------------------------------- */
@media (max-width: 767px) {
  .header-nav {
    background: var(--lum-ivoire);
    border-bottom: 1px solid var(--lum-filet);
  }
  .header-nav .mobile { padding: 0.45rem 0; }

  /* burger, compte, panier : encre sur ivoire */
  .header-nav .mobile .material-icons,
  #menu-icon .material-icons,
  .header-nav #_mobile_cart .material-icons,
  .header-nav #_mobile_user_info .material-icons {
    color: var(--lum-encre);
    font-size: 1.7rem;
  }
  .header-nav .mobile a, .header-nav .mobile span { color: var(--lum-encre); }
  .header-nav .blockcart .cart-products-count {
    color: var(--lum-or-fonce);
    font-weight: 600;
  }

  /* barre mobile sur deux lignes :
     1) burger ... compte + panier   2) logo en grand, bien lisible */
  .header-nav .mobile {
    padding: 0.55rem 0 0.75rem;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
  }
  .header-nav .mobile #menu-icon { order: 0; float: none; margin: 0 0 0 16px; }
  /* classic cale le burger sur une ligne de 50px : on neutralise pour
     que les trois icones partagent le meme centre vertical */
  #header #menu-icon .material-icons { line-height: 1; display: block; }
  .header-nav .mobile #_mobile_user_info {
    order: 1;
    margin-left: auto;
    float: none;
  }
  .header-nav .mobile #_mobile_user_info .user-info { margin-top: 0; padding: 0; }
  .header-nav .mobile #_mobile_user_info .user-info a { margin-top: 0; padding: 0; }
  .header-nav .mobile #_mobile_cart {
    order: 2;
    float: none;
    margin-left: 0.8rem;
    margin-right: 16px;
  }
  #header .header-nav .blockcart .header { margin-top: 0; }
  .header-nav .mobile .clearfix { display: none; }

  /* normalise les hauteurs imposees par classic : les trois icones
     partagent exactement le meme centre vertical */
  #header .header-nav .mobile #menu-icon,
  #header .header-nav .mobile #_mobile_user_info,
  #header .header-nav .mobile #_mobile_cart,
  #header .header-nav .mobile .user-info,
  #header .header-nav .mobile .blockcart {
    height: auto;
    min-height: 0;
    line-height: 1;
    padding-top: 0;
    padding-bottom: 0;
    margin-top: 0;
    margin-bottom: 0;
  }
  #header .header-nav .mobile .material-icons {
    line-height: 1;
    vertical-align: middle;
  }
  #header .header-nav .mobile .user-info a { margin-top: 0; padding: 0; }

  /* classic impose #header .header-nav{max-height:50px} et
     #header .top-logo img{max-height:2rem} : on neutralise les deux
     avec la même spécificité pour laisser la place au logo */
  #header .header-nav {
    max-height: none;
    height: auto;
  }
  #header .top-logo {
    order: 3;
    width: 100%;
    display: block;
    min-height: 0;
    text-align: center;
    line-height: 0;
    padding: 0.55rem 0 0.15rem;
    float: none;
  }
  #header .top-logo > h1 {
    width: 100%;
    margin: 0;
    display: block;
  }
  #header .top-logo a { display: inline-block; }
  #header .top-logo img {
    width: min(86vw, 360px);
    max-width: 100%;
    max-height: none;
    height: auto;
  }

  /* panier et compte : aucune bo?te de fond, ic?nes align?es */
  .header-nav .blockcart,
  .header-nav #_mobile_cart .blockcart {
    background: transparent !important;
    padding: 0;
    margin-left: 0;
    white-space: nowrap;
  }
  .header-nav .blockcart a,
  .header-nav #_mobile_user_info a {
    display: inline-flex;
    align-items: center;
    gap: 0.15rem;
  }

  /* recherche : fine et discr?te sous le logo */
  #header .header-top { padding: 0.45rem 0.9rem 0.6rem; }
  #header .search-widget,
  #header #search_widget {
    float: none;
    width: 100%;
    max-width: 430px;
    margin: 0 auto;
    padding: 0;
  }
  #header .search-widget form { margin: 0; }
  #header .search-widget form input[type="text"] {
    min-width: 0;
    width: 100%;
    height: 2.3rem;
    padding: 0.3rem 2.4rem 0.3rem 0.9rem;
    font-size: 0.85rem;
    -webkit-appearance: none;
    appearance: none;
    border-radius: 0;
    background: #fff;
    border: 1px solid var(--lum-filet);
  }
  #header .search-widget form input[type="text"]::placeholder {
    color: #b3a896;
    letter-spacing: 0.04em;
  }
  #header .search-widget form button[type="submit"] {
    bottom: 0.2rem;
    color: var(--lum-or-fonce);
  }

  /* menu d?pli? : fond ivoire, liens espac?s, filets fins */
  #mobile_top_menu_wrapper {
    background: var(--lum-ivoire) !important;
    padding-bottom: 0.8rem;
  }
  #mobile_top_menu_wrapper #top-menu a[data-depth="0"] {
    border-bottom: 1px solid var(--lum-filet);
    padding: 0.8rem 0.4rem;
  }
}

/* Recherche : champ discret, fin liser? */
#header .search-widget form input[type="text"] {
  background: #fff;
  border: 1px solid var(--lum-filet);
  color: var(--lum-encre);
  min-width: 12rem;
}
#header .search-widget form input[type="text"]:focus {
  outline: none;
  border-color: var(--lum-or);
}
#header .search-widget form button[type="submit"] { color: var(--lum-encre-douce); }

/* --------------------------------------------------------------------------
   5a. H?ro ?ditorial : image + panneau texte (remplace le carrousel)
   -------------------------------------------------------------------------- */
@keyframes lumRise {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: none; }
}

.lum-hero {
  position: relative;
  overflow: hidden;
  background: var(--lum-encre);
  margin-bottom: 0;
  min-height: clamp(440px, 72vh, 720px);
}
.lum-hero__media { position: absolute; inset: 0; }
.lum-hero__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 60%; /* leger recadrage bas */
}
/* calque superpose : voile degrade + texte clair ancre en bas (bouton a la lisiere) */
.lum-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end; /* desktop : kicker + titre groupes en bas */
  text-align: center;
  padding: clamp(1.5rem, 4vw, 2.6rem) clamp(2rem, 5vw, 4.5rem);
  padding-bottom: clamp(1.5rem, 3.5vw, 2.6rem);
  background: linear-gradient(to bottom, rgba(20,15,10,0.26) 0%, rgba(20,15,10,0.08) 20%, rgba(20,15,10,0.13) 42%, rgba(20,15,10,0.42) 68%, rgba(20,15,10,0.60) 100%);
}
.lum-hero__panel {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 40rem;
}
.lum-hero__panel > * { animation: lumRise 0.7s ease both; }
.lum-hero__panel > *:nth-child(2) { animation-delay: 0.12s; }
.lum-hero__panel > *:nth-child(3) { animation-delay: 0.24s; }
.lum-hero__panel > *:nth-child(4) { animation-delay: 0.36s; }

@media (prefers-reduced-motion: reduce) {
  .lum-hero__panel > *, .lum-hero__kicker { animation: none !important; }
}

.lum-hero__kicker {
  font-family: var(--lum-sans);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.26em;
  font-size: 0.72rem;
  color: #f6ecd8;
  margin-bottom: 0.6rem;
  text-shadow: 0 1px 10px rgba(20, 15, 10, 0.6), 0 0 3px rgba(20, 15, 10, 0.45);
  animation: lumRise 0.7s ease both;
}
.lum-hero__title {
  font-family: var(--lum-serif);
  font-weight: 500;
  font-size: clamp(2.4rem, 5.2vw, 4rem);
  line-height: 1.0;
  color: #fbf7ef;
  margin-bottom: 0.6rem;
  text-shadow: 0 2px 24px rgba(20,15,10,0.35);
}
.lum-hero__text {
  color: rgba(251,247,239,0.94);
  font-size: 1.02rem;
  max-width: 30rem;
  margin: 0 auto;
  text-shadow: 0 1px 14px rgba(20,15,10,0.30);
}

/* Bouton sorti SOUS l'image, sur fond ivoire : style fonce */
.lum-hero__cta-wrap {
  text-align: center;
  padding: clamp(1.6rem, 3.5vw, 2.4rem) 1rem 0;
  animation: lumRise 0.7s ease 0.30s both;
}
@media (prefers-reduced-motion: reduce) {
  .lum-hero__cta-wrap { animation: none !important; }
}
.lum-hero__cta {
  padding: 0.85rem 2.2rem;
  background: transparent;
  border: 1px solid var(--lum-encre);
  color: var(--lum-encre);
  letter-spacing: 0.04em;
  transition: background 0.3s ease, color 0.3s ease;
}
.lum-hero__cta:hover,
.lum-hero__cta:focus {
  background: var(--lum-encre);
  color: #fbf7ef;
}

/* --------------------------------------------------------------------------
   5b. Mosa?que des collections
   -------------------------------------------------------------------------- */
.lum-collections {
  max-width: 1320px;
  margin: 0 auto;
  padding: clamp(2rem, 4vw, 3.2rem) clamp(0.9rem, 2.5vw, 2rem) 0.6rem;
}
.lum-collections__title {
  font-family: var(--lum-serif);
  font-weight: 500;
  font-size: clamp(1.7rem, 4.5vw, 2.4rem);
  text-align: center;
  margin-bottom: 1.8rem;
  position: relative;
  padding-bottom: 1.1rem;
}
.lum-collections__title::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 56px;
  height: 1px;
  background: var(--lum-or);
}
.lum-collections__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(0.8rem, 2vw, 1.4rem);
}
.lum-tile {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 1 / 1;
}
.lum-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}
.lum-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(28, 22, 16, 0.55), transparent 45%);
  transition: background 0.3s ease;
}
.lum-tile:hover img { transform: scale(1.05); }
.lum-tile__label {
  position: absolute;
  left: 50%;
  bottom: 1.1rem;
  transform: translateX(-50%);
  z-index: 2;
  font-family: var(--lum-serif);
  font-weight: 500;
  font-size: clamp(1.2rem, 2.4vw, 1.6rem);
  color: #fdfaf4;
  white-space: nowrap;
  letter-spacing: 0.04em;
  text-shadow: 0 1px 12px rgba(20, 15, 10, 0.4);
}
.lum-tile:hover .lum-tile__label { color: #fff; }

/* Mobile : hero carre (tient en entier a l'ecran au chargement, image bien cadree) */
@media (max-width: 767px) {
  .lum-hero {
    min-height: 0;
    aspect-ratio: 4 / 3; /* paysage : image + bouton tiennent a l'ecran au chargement */
  }
  .lum-hero__media img { object-position: center; }
  .lum-hero__overlay {
    justify-content: space-between; /* mobile : kicker en haut, titre+sous-titre en bas */
    padding: 1.5rem 1.4rem 1.8rem;
  }
  .lum-hero__text {
    font-size: 0.8rem;
    line-height: 1.5;
    max-width: 21rem;
    opacity: 0.95;
  }
  .lum-collections__grid { grid-template-columns: 1fr; }
  .lum-tile { aspect-ratio: 4 / 3; }

  /* Zoom a l'apparition au scroll (mobile) : l'image grossit en arrivant a l'ecran.
     !important : indispensable pour battre la transition de base 0.9s (sinon duree ignoree). */
  .product-miniature .thumbnail-container img {
    transition: transform 1.7s cubic-bezier(0.22, 0.61, 0.36, 1) !important;
  }
  .product-miniature.is-in .thumbnail-container img { transform: scale(1.25) !important; }
}

/* --------------------------------------------------------------------------
   5c. Reveal au scroll (sections sous le hero) facon Cartier
   -------------------------------------------------------------------------- */
.lum-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s ease, transform 0.7s ease;
  will-change: opacity, transform;
}
.lum-reveal.is-in {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion: reduce) {
  .lum-reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* --------------------------------------------------------------------------
   5c. (Ancien carrousel ? conserv? si le module est r?activ? un jour)
   -------------------------------------------------------------------------- */
#carousel { margin-bottom: 0; box-shadow: none; }
/* l'image garde son ratio naturel : aucun recadrage CSS, donc aucun zoom */
#carousel .carousel-item img {
  width: 100%;
  height: auto;
}
#carousel .carousel-item figure { position: relative; margin-bottom: 0; }
#carousel .carousel-item figure::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(28, 22, 16, 0.55) 0%, rgba(28, 22, 16, 0.08) 45%, transparent 70%);
  pointer-events: none;
}
#carousel .caption {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: clamp(1.4rem, 5vw, 3.4rem);
  top: auto;
  width: min(92%, 720px);
  text-align: center;
  color: #fdfaf4;
  z-index: 2;
}
#carousel .caption .display-1,
#carousel .caption h2 {
  font-family: var(--lum-serif);
  font-weight: 500;
  font-size: clamp(1.6rem, 5.5vw, 3.1rem);
  color: #fdfaf4;
  text-shadow: 0 1px 18px rgba(20, 15, 10, 0.45);
  margin-bottom: 0.4rem;
}
#carousel .caption .caption-description,
#carousel .caption p {
  font-size: clamp(0.85rem, 2.4vw, 1.05rem);
  letter-spacing: 0.04em;
  color: #f3ecdf;
  text-shadow: 0 1px 12px rgba(20, 15, 10, 0.5);
}
#carousel .direction { z-index: 3; }
#carousel .carousel-control .icon-prev::before,
#carousel .carousel-control .icon-next::before { color: #fdfaf4; }
#carousel .carousel-control { opacity: 0.65; }
#carousel .carousel-control:hover { opacity: 1; }

/* Sur t?l?phone : la l?gende passe SOUS l'image (jamais coup?e),
   pos?e sur l'ivoire avec un petit filet dor? */
@media (max-width: 767px) {
  #carousel .carousel-item figure::after { display: none; }
  #carousel .caption {
    position: static;
    transform: none;
    width: 100%;
    padding: 0.9rem 1.1rem 1.2rem;
    text-align: center;
    color: var(--lum-encre);
  }
  #carousel .caption .display-1,
  #carousel .caption h2 {
    color: var(--lum-encre);
    text-shadow: none;
    font-size: 1.45rem;
    margin-bottom: 0.25rem;
    position: relative;
    padding-bottom: 0.55rem;
  }
  #carousel .caption .display-1::after,
  #carousel .caption h2::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 40px;
    height: 1px;
    background: var(--lum-or);
  }
  #carousel .caption .caption-description,
  #carousel .caption p {
    color: var(--lum-encre-douce);
    text-shadow: none;
    font-size: 0.85rem;
    margin-bottom: 0;
  }
  #carousel .caption .caption-description p { color: var(--lum-encre-douce); margin-bottom: 0; }
}

/* --------------------------------------------------------------------------
   6. Vitrines produits : cartes ?pur?es, prix dor?
   -------------------------------------------------------------------------- */
.featured-products { padding-bottom: 1rem; }

.product-miniature .thumbnail-container {
  background: #fff;
  border: 1px solid var(--lum-filet);
  box-shadow: none;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
  overflow: hidden;
}
.product-miniature .thumbnail-container:hover,
.product-miniature .thumbnail-container:focus-within {
  border-color: var(--lum-or);
  box-shadow: 0 10px 28px rgba(43, 37, 32, 0.08);
}
.product-miniature .thumbnail-container img {
  transition: transform 0.9s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.product-miniature .thumbnail-container:hover img {
  transform: scale(1.12);
}
.product-miniature .product-title a {
  font-family: var(--lum-serif);
  font-size: 1.12rem;
  font-weight: 500;
  color: var(--lum-encre);
}
.product-miniature .product-title a:hover { color: var(--lum-or-fonce); }
.product-miniature .price {
  color: var(--lum-or-fonce);
  font-weight: 600;
  letter-spacing: 0.03em;
}
.product-miniature .regular-price { color: var(--lum-encre-douce); }

/* masque le ? Aper?u rapide ? qui alourdit les cartes */
.product-miniature .highlighted-informations { display: none; }

/* cartes compactes : image carree pleine largeur, plus de vide
   (classic reserve 70px et une hauteur fixe dans la vignette) */
.product-miniature .thumbnail-container { height: auto; margin-bottom: 0; }
.product-miniature .thumbnail-container .product-thumbnail {
  height: auto;
  display: block;
}
.product-miniature .thumbnail-container img {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
}
.product-miniature .product-description {
  height: auto;
  padding: 0.8rem 0.5rem 1rem;
}

/* badge Promo/Nouveau : petite etiquette posee sur la photo,
   fini le bandeau pleine largeur */
.product-flags li.product-flag {
  width: -moz-fit-content;
  width: fit-content;
  min-width: 0;
  min-height: 0;
  padding: 0.3rem 0.6rem;
  margin: 0.55rem 0 0 0.55rem;
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fdfaf4;
  background: var(--lum-encre);
}
.product-flags li.product-flag.on-sale,
.product-flags li.product-flag.discount,
.product-flags li.product-flag.discount-percentage,
.product-flags li.product-flag.discount-amount {
  width: -moz-fit-content;
  width: fit-content;
  margin-left: 0.55rem;
  text-align: left;
  background: var(--lum-or-fonce);
}

/* coeur "liste d'envies" : plus discret */
.wishlist-button-add {
  width: 34px;
  height: 34px;
  min-width: 0;
  min-height: 0;
  background: rgba(250, 247, 241, 0.92);
  box-shadow: 0 1px 6px rgba(43, 37, 32, 0.18);
}
.wishlist-button-add i { font-size: 1.05rem; color: var(--lum-encre-douce); }
.wishlist-button-add:hover i,
.wishlist-button-add:focus i { color: var(--lum-or-fonce); }

.all-product-link {
  font-family: var(--lum-sans);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.8rem;
  color: var(--lum-or-fonce);
}
.all-product-link:hover { color: var(--lum-or); }
.all-product-link i { color: inherit; }

/* Pastilles ? Nouveau / Promo ? */
.product-flag {
  font-family: var(--lum-sans);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.62rem;
  background: var(--lum-encre);
}
.product-flag.discount, .product-flag.on-sale { background: var(--lum-or-fonce); }
.product-flag.new { background: var(--lum-encre); }

/* --------------------------------------------------------------------------
   7. Boutons & formulaires
   -------------------------------------------------------------------------- */
.btn-primary,
.btn-secondary,
.btn-tertiary {
  border-radius: 0;
  font-family: var(--lum-sans);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.8rem;
  box-shadow: none;
}
.btn-primary {
  background: var(--lum-encre);
  border: 1px solid var(--lum-encre);
  color: #fdfaf4;
  transition: background 0.25s ease, border-color 0.25s ease;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
  background: var(--lum-or-fonce);
  border-color: var(--lum-or-fonce);
  color: #fff;
}
.btn-primary:disabled { background: #b5aca1; border-color: #b5aca1; }
.btn-secondary {
  background: transparent;
  border: 1px solid var(--lum-encre);
  color: var(--lum-encre);
}
.btn-secondary:hover {
  background: var(--lum-encre);
  color: #fdfaf4;
}

.form-control {
  border-radius: 0;
  border: 1px solid var(--lum-filet);
  background: #fff;
}
.form-control:focus {
  border-color: var(--lum-or);
  box-shadow: none;
  outline: none;
}

/* --------------------------------------------------------------------------
   8. Bande ? r?assurance ? (paiement s?curis?, livraison?)
   -------------------------------------------------------------------------- */
#extra_block, .blockreassurance,
#blockreassurance {
  background: var(--lum-creme);
}
.blockreassurance span, .blockreassurance p,
#blockreassurance span, #blockreassurance p {
  color: var(--lum-encre);
  font-size: 0.85rem;
  letter-spacing: 0.04em;
}

/* --------------------------------------------------------------------------
   9. Page produit
   -------------------------------------------------------------------------- */
.product-prices .current-price,
.current-price-display {
  color: var(--lum-or-fonce);
  font-family: var(--lum-serif);
  font-size: 1.7rem;
  font-weight: 600;
}
h1.h1[itemprop="name"], .product-title-h1, #main .page-content h1 {
  font-family: var(--lum-serif);
}
.product-information { color: var(--lum-encre); }
.product-actions .add-to-cart {
  padding: 0.85rem 2.2rem;
}
.tabs { box-shadow: none; border: 1px solid var(--lum-filet); background: #fff; }
.tabs .nav-tabs .nav-link.active { border-bottom-color: var(--lum-or); color: var(--lum-encre); }
.tabs .nav-tabs .nav-link { color: var(--lum-encre-douce); }

/* --------------------------------------------------------------------------
   10. Listes / cat?gories
   -------------------------------------------------------------------------- */
#wrapper { background: var(--lum-ivoire); }
#wrapper .breadcrumb { background: transparent; }
#wrapper .breadcrumb li a { color: var(--lum-encre-douce); }
#wrapper .breadcrumb li:last-child { color: var(--lum-or-fonce); }

/* bloc arborescence : cache quand il n'a aucune sous-categorie a montrer
   (sinon il n'affiche qu'un titre redondant au-dessus du bandeau) */
.block-categories:not(:has(.category-sub-menu a)) { display: none; }

/* En-tete de categorie : bandeau photo + titre pose dessus */
.lum-cat-header { margin-bottom: 1.5rem; }
.lum-cat-header__media {
  position: relative;
  overflow: hidden;
}
.lum-cat-header__media img {
  width: 100%;
  height: auto;
  display: block;
}
.lum-cat-header__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(28, 22, 16, 0.5), transparent 55%);
  pointer-events: none;
}
.lum-cat-header__media .lum-cat-header__title {
  position: absolute;
  left: 50%;
  bottom: clamp(0.7rem, 2.5vw, 1.6rem);
  transform: translateX(-50%);
  z-index: 2;
  margin: 0;
  font-family: var(--lum-serif);
  font-weight: 500;
  font-size: clamp(1.6rem, 4vw, 2.6rem);
  color: #fdfaf4;
  text-shadow: 0 1px 16px rgba(20, 15, 10, 0.5);
  white-space: nowrap;
}
.lum-cat-header__title--plain {
  font-family: var(--lum-serif);
  font-weight: 500;
  font-size: clamp(1.7rem, 4vw, 2.4rem);
  text-align: center;
  margin: 1rem 0 0.4rem;
  position: relative;
  padding-bottom: 1rem;
}
.lum-cat-header__title--plain::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 56px;
  height: 1px;
  background: var(--lum-or);
}
.lum-cat-header__desc {
  max-width: 50rem;
  margin: 1.1rem auto 0;
  text-align: center;
  color: var(--lum-encre-douce);
  font-size: 0.9rem;
}
.lum-cat-header__desc p { margin-bottom: 0.5rem; }
.lum-cat-header__desc strong { color: var(--lum-encre); font-weight: 600; }

/* description repliee par defaut : les produits restent visibles tout de suite,
   le texte complet (SEO) reste dans la page pour Google */
.lum-cat-header__desc-wrap { position: relative; }
.lum-desc-toggle {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.lum-cat-header__desc {
  max-height: 6.8em;
  overflow: hidden;
  position: relative;
  transition: max-height 0.45s ease;
}
.lum-cat-header__desc::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2.6em;
  background: linear-gradient(to bottom, rgba(250, 247, 241, 0), var(--lum-ivoire));
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.lum-desc-toggle:checked ~ .lum-cat-header__desc { max-height: 500em; }
.lum-desc-toggle:checked ~ .lum-cat-header__desc::after { opacity: 0; }

.lum-desc-more {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0.6rem auto 0;
  padding: 0.35rem 0.9rem;
  font-family: var(--lum-sans);
  font-weight: 600;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--lum-or-fonce);
  border: 1px solid var(--lum-filet);
  cursor: pointer;
  user-select: none;
}
.lum-desc-more:hover { border-color: var(--lum-or); color: var(--lum-or); }
.lum-desc-more__less { display: none; }
.lum-desc-toggle:checked ~ .lum-desc-more .lum-desc-more__more { display: none; }
.lum-desc-toggle:checked ~ .lum-desc-more .lum-desc-more__less { display: inline; }
@media (max-width: 575px) {
  /* bandeau un peu plus haut sur telephone pour rester immersif */
  .lum-cat-header__media img {
    aspect-ratio: 16 / 8;
    object-fit: cover;
  }
  .lum-cat-header__desc { font-size: 0.85rem; }
}

#search_filters, .block-categories,
#category #left-column > div {
  background: #fff;
  border: 1px solid var(--lum-filet);
  box-shadow: none;
}
.block-categories .category-top-menu a { color: var(--lum-encre); }
#search_filters .facet .facet-title { color: var(--lum-encre-douce); }

/* Filtre Couleur : la pastille selectionnee etait indiscernable. Anneau or autour de la pastille cochee
   (selecteur frere direct = compatible partout) + texte du filtre couleur actif en gras/or (:has, en bonus). */
#search_filters_wrapper .facet .custom-checkbox input[type="checkbox"]:checked + .color,
#search_filters .facet .custom-checkbox input[type="checkbox"]:checked + .color {
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--lum-or-fonce);
}
#search_filters_wrapper .facet:has(.color) .facet-label:has(input:checked) .search-link,
#search_filters .facet:has(.color) .facet-label:has(input:checked) .search-link {
  color: var(--lum-or-fonce);
  font-weight: 600;
}

/* Pages categories : ne garder QUE les filtres Prix, Disponibilite (stock) et Selections (promo).
   On masque les facettes d'attributs (Couleur/Dimension/Plaquage/Personnalisation) et de caracteristiques.
   Masquage CSS = sur et reversible (pour une suppression au niveau config : modele de filtres BO ps_facetedsearch). */
#search_filters .facet[data-type="attribute_group"],
#search_filters .facet[data-type="feature"],
#search_filters_wrapper .facet[data-type="attribute_group"],
#search_filters_wrapper .facet[data-type="feature"] {
  display: none !important;
}

#js-product-list-top {
  background: #fff;
  border: 1px solid var(--lum-filet);
  box-shadow: none;
}

/* Pagination : la page courante etait bleue (rgb 36,185,215) et 20px via classic.
   Markup reel = <li class="current"><a class="disabled">1</a> (pas de .page-link). */
.pagination .page-list a { font-weight: 400; }   /* numeros non courants en poids normal */
.pagination .page-list li.current a,
.pagination .page-list .current a {
  color: var(--lum-or-fonce) !important;
  font-size: inherit !important;   /* meme taille que les autres numeros */
  font-weight: 700 !important;     /* page courante en gras (contraste avec les autres) */
}
.pagination .page-list a:hover { color: var(--lum-or-fonce); }

/* --------------------------------------------------------------------------
   11. Bloc texte d'accueil (notre atelier)
   -------------------------------------------------------------------------- */
#custom-text {
  background: var(--lum-creme);
  border: none;
  border-radius: 0;
  padding: clamp(2rem, 6vw, 4rem) clamp(1.2rem, 8vw, 6rem);
  text-align: center;
  margin-bottom: 0;
}
#custom-text h2, #custom-text h3 {
  font-family: var(--lum-serif);
  font-weight: 500;
  font-size: clamp(1.5rem, 4vw, 2.1rem);
}
#custom-text p {
  color: var(--lum-encre-douce);
  font-size: 0.95rem;
  max-width: 46rem;
  margin-left: auto;
  margin-right: auto;
}

/* --------------------------------------------------------------------------
   12. Pied de page : ?crin de nuit
   -------------------------------------------------------------------------- */
.footer-container {
  background: var(--lum-nuit);
  color: #cfc6b8;
  box-shadow: none;
  margin-top: 0;
  padding-top: 2.4rem;
  overflow: hidden;
}
.footer-container .h3, .footer-container .h4,
.footer-container p.h4, .footer-container .footer__title {
  font-family: var(--lum-serif);
  font-weight: 500;
  color: #efe7d8;
  font-size: 1.15rem;
  letter-spacing: 0.03em;
}
/* Titre "Votre compte" : c'est un <a class="text-uppercase"> DANS le <p class="h3 myaccount-title">.
   Le <a> gardait sa couleur de lien #232323 (noir sur fond noir) + 16px => invisible. On force le lien. */
.footer-container .myaccount-title,
.footer-container .myaccount-title a {
  font-family: var(--lum-serif) !important;
  font-weight: 500 !important;
  font-size: 1.15rem !important;
  color: #efe7d8 !important;
  -webkit-text-fill-color: #efe7d8 !important;
  opacity: 1 !important;
  visibility: visible !important;
  letter-spacing: 0.03em;
}
.footer-container .myaccount-title a:hover {
  color: var(--lum-or) !important;
  -webkit-text-fill-color: var(--lum-or) !important;
}
.footer-container li a,
.footer-container .account-list a {
  color: #b4a995;
  font-size: 0.86rem;
}
.footer-container li a:hover { color: var(--lum-or); }
.footer-container .block-contact { color: #b4a995; font-size: 0.86rem; }
.footer-container .block-contact .block-contact-title { color: #efe7d8; }
.footer-container .copyright,
.footer-container .copyright a { color: #8d8270; font-size: 0.78rem; }

/* Newsletter : bande cr?me contrast?e au-dessus du pied de page */
.block_newsletter {
  background: var(--lum-creme);
  margin: 0 -15px;
  padding: 2.2rem 15px 2.4rem;
  border-bottom: 1px solid var(--lum-filet);
}
.block_newsletter p.h4, .block_newsletter .h4 {
  font-family: var(--lum-serif);
  color: var(--lum-encre);
  font-size: 1.35rem;
}
.block_newsletter form input[type="email"] {
  border: 1px solid var(--lum-filet);
  background: #fff;
  color: var(--lum-encre);
}
.block_newsletter form input[type="email"]:focus { border-color: var(--lum-or); }
.block_newsletter p { color: var(--lum-encre-douce); font-size: 0.82rem; }

/* R?seaux sociaux */
.block-social li { background-color: #3a3329; }
.block-social li:hover { background-color: var(--lum-or-fonce); }

/* --------------------------------------------------------------------------
   13. Mobile & tablette d'abord : la majorit? des visiteurs
   -------------------------------------------------------------------------- */
@media (max-width: 991px) {
  /* En-t?te mobile : logo centr?, fond ivoire, burger encr? */
  #header .header-top { padding-top: 0.5rem; }
  #menu-icon .material-icons { color: var(--lum-encre); }
  #mobile_top_menu_wrapper {
    background: var(--lum-ivoire);
  }
  #mobile_top_menu_wrapper #top-menu a[data-depth="0"] {
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.85rem;
    color: var(--lum-encre);
  }

  /* Produits : 2 colonnes aerees — c'est la colonne Bootstrap
     (.js-product, col-xs-12 par defaut) qu'il faut redimensionner */
  .products > .js-product.product {
    flex: 0 0 50%;
    max-width: 50%;
    padding: 0 0.4rem;
    margin-bottom: 0.9rem;
  }
  .product-miniature { width: 100%; min-width: 0; margin: 0; }
  .product-miniature .product-title a { font-size: 1rem; }
}

@media (max-width: 575px) {
  body { font-size: 0.9375rem; }
  .product-miniature .product-title a { font-size: 0.95rem; }
  .btn-primary, .btn-secondary { letter-spacing: 0.1em; }
  /* Bandes moins ?paisses sur petit ?cran */
  #custom-text { padding: 1.8rem 1.2rem; }
}

/* Cibles tactiles confortables (doigt ? 44px) */
@media (pointer: coarse) {
  #header .top-menu a[data-depth="0"],
  .footer-container li a,
  .btn-primary, .btn-secondary {
    padding-top: 0.6rem;
    padding-bottom: 0.6rem;
  }
}

/* --------------------------------------------------------------------------
   13. Bandeau cookies (consentement CNIL) — injecte par custom.js
   -------------------------------------------------------------------------- */
.lum-cookie {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 1050;
  background: var(--lum-encre); color: #f1eadd;
  padding: 1rem clamp(1rem, 4vw, 2.5rem);
  display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap;
  box-shadow: 0 -6px 24px rgba(20, 15, 10, 0.28);
  font-family: var(--lum-sans); font-size: 0.85rem;
  transform: translateY(120%); transition: transform 0.4s ease;
}
.lum-cookie.is-visible { transform: none; }
.lum-cookie__text { flex: 1 1 320px; line-height: 1.5; color: rgba(241, 234, 221, 0.9); margin: 0; }
.lum-cookie__text a { color: var(--lum-or); text-decoration: underline; }
.lum-cookie__actions { display: flex; gap: 0.6rem; flex: 0 0 auto; }
.lum-cookie__btn {
  font-family: var(--lum-sans); text-transform: uppercase; letter-spacing: 0.08em;
  font-size: 0.72rem; padding: 0.6rem 1.3rem; cursor: pointer; border: 1px solid transparent;
  transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}
.lum-cookie__btn--accept { background: var(--lum-or); color: var(--lum-encre); border-color: var(--lum-or); }
.lum-cookie__btn--accept:hover { background: var(--lum-or-fonce); border-color: var(--lum-or-fonce); color: #fff; }
.lum-cookie__btn--refuse { background: transparent; color: #f1eadd; border-color: rgba(241, 234, 221, 0.5); }
.lum-cookie__btn--refuse:hover { border-color: #f1eadd; }
@media (max-width: 600px) {
  .lum-cookie__actions { flex: 1 1 100%; }
  .lum-cookie__btn { flex: 1; text-align: center; }
}

/* --------------------------------------------------------------------------
   13b. Tunnel de commande : pastilles d'etape aux couleurs de la charte
   (le defaut classic est vert #00C062, hors charte)
   -------------------------------------------------------------------------- */
.checkout-step.-current .step-number { background: var(--lum-encre) !important; color: #fff !important; }
.checkout-step.-complete .step-number { background: var(--lum-or) !important; color: #fff !important; }
.checkout-step.-complete .step-title .done { color: var(--lum-or) !important; } /* coche eventuelle */

/* --------------------------------------------------------------------------
   12. Fiche produit : corrections de detail
   -------------------------------------------------------------------------- */
/* Bouton "Ajouter au panier" : icone panier centree verticalement + espace propre */
.product-actions .add-to-cart {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
}
.product-actions .add-to-cart .material-icons {
  line-height: 1;
  margin: 0;
  vertical-align: middle;
}

/* Champ de personnalisation : plus haut (plusieurs lignes) et pleine largeur */
.product-customization .product-message,
textarea.product-message {
  width: 100%;
  min-height: 120px;
  resize: vertical;
}

@media (max-width: 767px) {
  /* Variantes Dimension/Plaquage : selects en pleine largeur (sinon petites boites collees a gauche) */
  .product-variants .product-variants-item select,
  .product-variants-item select.form-control {
    width: 100%;
    max-width: 100%;
  }
  /* Quantite : retirer les fleches +/- (trop petites et decalees sous le champ sur mobile) */
  .product-quantity .input-group-btn-vertical { display: none !important; }
  .product-quantity input[type="number"]::-webkit-inner-spin-button,
  .product-quantity input[type="number"]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
  .product-quantity #quantity_wanted,
  .product-quantity .bootstrap-touchspin .form-control { width: 72px; text-align: center; }
}

/* Desktop : galerie photo "sticky" -> elle suit le scroll au lieu de laisser
   toute la colonne gauche vide pendant qu'on lit la longue colonne droite.
   La ligne produit est en display:block (col gauche courte) -> on la passe en flex
   pour que la colonne gauche s'etire et donne de la marge au sticky. */
@media (min-width: 768px) {
  .product-container {
    display: flex;
    flex-wrap: wrap;
    /* align-items: stretch (defaut) => la colonne gauche s'etire a la hauteur de la droite,
       ce qui donne la marge necessaire au sticky de la galerie. */
  }
  .product-container #content.page-content {
    position: -webkit-sticky;
    position: sticky !important; /* bat la regle classic #wrapper #content (2 ID) qui force relative */
    top: 1.5rem;
  }
}

/* Description longue (onglet) : repliee avec bouton "Lire la suite" (fond blanc -> fondu blanc) */
.lum-clamp {
  position: relative;
  max-height: var(--clamp-h, 240px); /* hauteur repliee dynamique (ex: GIF entiere + accroche) */
  overflow: hidden;
  transition: max-height 0.45s ease;
}
.lum-clamp::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0; height: 70px;
  background: linear-gradient(to bottom, rgba(255,255,255,0), #fff 92%);
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.lum-clamp.is-open { max-height: 4000px; }
.lum-clamp.is-open::after { opacity: 0; }
/* variante fondu ivoire (description courte sur fond #faf7f1) */
.lum-clamp--cream::after { background: linear-gradient(to bottom, rgba(250,247,241,0), #faf7f1 92%); }
.lum-readmore {
  display: inline-block;
  margin-top: 0.9rem;
  background: transparent;
  border: 1px solid var(--lum-or);
  color: var(--lum-or-fonce);
  font-family: var(--lum-sans);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  padding: 0.5rem 1.4rem;
  cursor: pointer;
  transition: background 0.3s ease, color 0.3s ease;
}
.lum-readmore:hover { background: var(--lum-or); color: #fff; }

/* Bloc reassurance (Mentions legales / Livraison / Retour) : icones cassees (URL //modules)
   -> restaurees en CSS via le bon chemin, + presentation en liste epuree on-brand. */
.blockreassurance_product { margin-top: 1.6rem; }
.blockreassurance_product > div[onclick] {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.7rem 0.2rem;
  border-top: 1px solid var(--lum-filet);
  cursor: pointer;
  transition: color 0.25s ease;
}
.blockreassurance_product > div[onclick]:nth-of-type(3) { border-bottom: 1px solid var(--lum-filet); }
.blockreassurance_product > div[onclick]:hover { color: var(--lum-or-fonce); }
.blockreassurance_product .item-product {
  flex: 0 0 auto; width: 24px; height: 24px;
  background: no-repeat center / contain;
  opacity: 0.8;
}
.blockreassurance_product .item-product img { display: none; } /* img cassee masquee */
.blockreassurance_product > div[onclick]:nth-of-type(1) .item-product { background-image: url('/modules/blockreassurance/views/img/reassurance/pack2/security.svg'); }
.blockreassurance_product > div[onclick]:nth-of-type(2) .item-product { background-image: url('/modules/blockreassurance/views/img/reassurance/pack2/carrier.svg'); }
.blockreassurance_product > div[onclick]:nth-of-type(3) .item-product { background-image: url('/modules/blockreassurance/views/img/reassurance/pack2/parcel.svg'); }
.blockreassurance_product .block-title {
  margin: 0;
  font-family: var(--lum-sans); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.78rem;
  color: var(--lum-encre) !important;
}
.blockreassurance_product p:not(.block-title) {
  margin: 0; font-size: 0.8rem; color: var(--lum-encre-douce) !important;
}
.blockreassurance_product > div[onclick]::after {
  content: "\203A"; /* chevron > */
  margin-left: auto; color: var(--lum-or); font-size: 1.15rem; line-height: 1;
}

/* --------------------------------------------------------------------------
   14. Eradication du bleu classic (#24b9d7 = "brand-primary") -> charte or/encre
   classic l'utilise partout : liens, PRIX produit, boutons, focus, radios,
   onglets, pagination, filtres... custom.css charge APRES classic, donc on
   l'emporte a specificite egale ; !important seulement la ou classic est plus
   specifique ou en pseudo-etat. (Le header garde son creme : ses regles
   #header ... !important sont plus fortes que ces selecteurs.)
   -------------------------------------------------------------------------- */
/* Liens */
a { color: var(--lum-encre); }
a:hover { color: var(--lum-or); }

/* Prix produit (etait bleu) -> encre */
.product-price,
.product-price *,
.product-prices .current-price,
.current-price-value { color: var(--lum-encre); }

/* Boutons primaires (fond bleu) -> encre, survol or */
.btn-primary,
.btn-primary:focus { background-color: var(--lum-encre); border-color: var(--lum-encre); color: #f3ecdd; }
.btn-primary:hover,
.btn-primary:active { background-color: var(--lum-or); border-color: var(--lum-or); color: #fff; }
.btn-outline-primary { color: var(--lum-or); border-color: var(--lum-or); }
.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active { background-color: var(--lum-or); border-color: var(--lum-or); color: #fff; }
.btn-link { color: var(--lum-or-fonce); }

/* Utilitaires Bootstrap colores */
.text-primary { color: var(--lum-or-fonce) !important; }
.bg-primary { background-color: var(--lum-encre) !important; }
.tag-primary { background-color: var(--lum-or); }

/* Focus / contours bleus -> or */
.form-control:focus { outline-color: var(--lum-or) !important; border-color: var(--lum-or); }
.input-group.focus { outline-color: var(--lum-or) !important; }
.search-widget form input[type="text"]:focus { outline-color: var(--lum-or) !important; }

/* Boutons +/- quantite (fond bleu) */
.bootstrap-touchspin .btn-touchspin,
.group-span-filestyle .btn-default { background: var(--lum-encre) !important; }

/* Radios cochees (livraison / paiement au checkout) -> encre */
.custom-radio input[type="radio"]:checked + span { background-color: var(--lum-encre) !important; }

/* Onglets fiche produit actifs -> or */
.tabs .nav-tabs .nav-link.active { color: var(--lum-encre); }
.tabs .nav-tabs .nav-link.active,
.tabs .nav-tabs .nav-link:hover { border-bottom-color: var(--lum-or) !important; }

/* Pagination */
.page-link,
.pagination .current a { color: var(--lum-encre); }
.page-item.active .page-link,
.page-item.active .page-link:hover,
.page-item.active .page-link:focus { background-color: var(--lum-encre) !important; border-color: var(--lum-encre) !important; color: #fff; }

/* Filtres / tris (hover bleu) -> or */
.facet-dropdown.open > .select-title,
.facet-dropdown .select-list:hover,
.brands-sort .select-list:hover,
.products-sort-order .select-list:hover,
.suppliers-sort .select-list:hover { background-color: var(--lum-or) !important; border-color: var(--lum-or) !important; }

/* Survols divers (quick-view, sous-categories, menu deroulant) */
.product-miniature .highlighted-informations .quick-view:hover,
#subcategories ul li .subcategory-name:hover,
.top-menu .sub-menu a:hover,
.dropdown-item:focus,
.dropdown-item:hover { color: var(--lum-or); }
.dropdown-item.active,
.dropdown-item.active:hover { background-color: var(--lum-encre); }

/* Bordures de selection bleues (images, adresses checkout) -> or */
#subcategories ul li:hover .subcategory-image a,
#product-modal .modal-content .modal-body .product-images img:hover,
body#checkout section.checkout-step .address-item.selected { border-color: var(--lum-or) !important; }

/* --------------------------------------------------------------------------
   15. Categorie mobile : barre tri / filtre
   La case de tri ("Pertinence") faisait ~62px de haut, ~1,5x le bouton
   "Filtrer" (41px) a cote -> on harmonise les deux a 44px (cible tactile),
   contenu centre verticalement.
   -------------------------------------------------------------------------- */
@media (max-width: 991px) {
  .products-sort-order .select-title {
    min-height: 44px !important;
    height: 44px !important;
    padding: 0 12px !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: space-between;
  }
  .products-sort-order .select-title .material-icons { margin-left: 6px; }
  .js-search-toggler,
  #search_filter_toggler {
    min-height: 44px !important;
    height: 44px !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    padding: 0 14px !important;
  }
}

