/* =========================================================================
   MAISON VOLUPTÉ — Thème PrestaShop 8
   Design system mobile-first. Single-file pour performance (1 requête CSS).
   ========================================================================= */

/* Imports typographiques + Material Icons (utilisée par les templates natifs
   PS classic : checkout, compte…). DOIVENT rester en tête du fichier — un
   @import placé après une règle CSS est ignoré par les navigateurs. */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Inter:wght@300;400;500;600;700&family=Marcellus&display=swap');
@import url('https://fonts.googleapis.com/icon?family=Material+Icons');

/* ----- 1. DESIGN TOKENS --------------------------------------------------- */
:root {
  /* Couleurs — lingerie premium, féminin sensuel, luxe contemporain */
  --c-ink:          #0E0B10;     /* noir profond, presque charbon */
  --c-ink-soft:     #1A1418;     /* noir bleuté pour fonds */
  --c-cream:        #FAF6F0;     /* fond principal, blanc cassé */
  --c-blush:        #F4DCD2;     /* rose poudré, accent féminin */
  --c-nude:         #E8C9B8;     /* nude chaud */
  --c-rose-deep:    #6B1E2E;     /* bordeaux, intensité contenue */
  --c-gold:         #B8945A;     /* or vieilli, luxe */
  --c-gold-light:   #D9BF8E;
  --c-taupe:        #847268;     /* gris chaud, neutre */
  --c-line:         #E5DDD2;     /* séparateurs subtils */
  --c-muted:        #807975;
  --c-error:        #B23A48;
  --c-success:      #4F7A5F;

  /* Surface */
  --bg:             var(--c-cream);
  --text:           var(--c-ink);
  --text-muted:     var(--c-muted);
  --border:         var(--c-line);

  /* Typo */
  --font-display:   'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --font-body:      'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;
  --font-accent:    'Marcellus', 'Cormorant Garamond', serif;

  --fs-xs:    0.75rem;   /* 12px */
  --fs-sm:    0.875rem;  /* 14px */
  --fs-base:  1rem;      /* 16px */
  --fs-md:    1.125rem;  /* 18px */
  --fs-lg:    1.375rem;  /* 22px */
  --fs-xl:    1.75rem;   /* 28px */
  --fs-2xl:   clamp(1.875rem, 1.4rem + 2.1vw, 2.25rem);   /* 30 → 36px */
  --fs-3xl:   clamp(2.25rem, 1.6rem + 2.9vw, 3rem);       /* 36 → 48px */
  --fs-hero:  clamp(2.75rem, 1.6rem + 5.1vw, 3.75rem);    /* 44 → 60px */

  --lh-tight:  1.15;
  --lh-snug:   1.35;
  --lh-base:   1.6;

  --tracking-tight:   -0.01em;
  --tracking-normal:  0;
  --tracking-wide:    0.06em;
  --tracking-wider:   0.16em;

  /* Spacing scale (8pt grid) */
  --sp-1:  0.25rem;
  --sp-2:  0.5rem;
  --sp-3:  0.75rem;
  --sp-4:  1rem;
  --sp-5:  1.5rem;
  --sp-6:  2rem;
  --sp-7:  2.5rem;
  --sp-8:  3rem;
  --sp-9:  4rem;
  --sp-10: 5rem;
  --sp-12: 7rem;
  --sp-16: 10rem;

  /* Layout */
  --container:    1280px;
  --container-sm: 880px;
  --gutter:       1.25rem;
  --gutter-lg:    2rem;

  /* Radii */
  --r-sm:  2px;
  --r-md:  4px;
  --r-lg:  8px;
  --r-pill: 999px;

  /* Shadows */
  --shadow-1: 0 1px 2px rgba(14, 11, 16, 0.06), 0 1px 1px rgba(14, 11, 16, 0.04);
  --shadow-2: 0 4px 16px rgba(14, 11, 16, 0.08);
  --shadow-3: 0 12px 40px rgba(14, 11, 16, 0.12);
  --shadow-gold: 0 6px 24px rgba(184, 148, 90, 0.22);

  /* Motion */
  --ease:    cubic-bezier(.21, .61, .35, 1);
  --t-fast:  120ms;
  --t-base:  220ms;
  --t-slow:  360ms;

  /* Header */
  --header-h: 60px;
  --header-h-desktop: 84px;
  --usp-h: 36px;

  /* Z */
  --z-sticky: 30;
  --z-header: 40;
  --z-overlay: 80;
  --z-drawer: 90;
  --z-modal: 100;
}

@media (min-width: 768px) {
  :root {
    --fs-hero:  4.5rem;
    --fs-3xl:   3.5rem;
    --gutter:   2rem;
  }
}

/* ----- 2. RESET & BASE ---------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
  min-height: 100dvh;
  overflow-x: hidden;
}
img, picture, video, svg { display: block; max-width: 100%; height: auto; }
button { font: inherit; background: none; border: 0; cursor: pointer; color: inherit; }
input, select, textarea { font: inherit; color: inherit; }
a { color: var(--text); text-decoration: none; transition: color var(--t-base) var(--ease); }
a:hover { color: var(--c-rose-deep); }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); font-weight: 500; line-height: var(--lh-tight); letter-spacing: var(--tracking-tight); color: var(--c-ink); overflow-wrap: break-word; }
h1 { font-size: var(--fs-3xl); }
h2 { font-size: var(--fs-2xl); }
h3 { font-size: var(--fs-xl); }
h4 { font-size: var(--fs-lg); }
ul, ol { list-style: none; }

::selection { background: var(--c-ink); color: var(--c-cream); }
:focus-visible { outline: 2px solid var(--c-gold); outline-offset: 3px; border-radius: 2px; }

.material-icons {
  font-family: 'Material Icons';
  font-weight: normal; font-style: normal;
  font-size: 20px; line-height: 1;
  display: inline-block; vertical-align: middle;
  letter-spacing: normal; text-transform: none; white-space: nowrap;
  -webkit-font-feature-settings: 'liga'; font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased; direction: ltr;
  color: var(--c-ink);
}
.material-icons.rtl-no-flip { transform: none; }
/* GLOBAL : cacher tous les <i.material-icons> VIDES (sinon doublon avec mes ::before).
   PS met du texte dans les <i> qu'il veut afficher (rendu via ligature). */
i.material-icons:empty { display: none !important; }
/* …et ceux qui contiennent un texte de ligature (mode_edit, done, delete, edit…) :
   sans la police 'Material Icons' chargée (RGPD/consentement/réseau) ils s'affichent
   en toutes lettres. Le thème utilise des libellés texte → on les masque aussi. */
i.material-icons:not(:empty) { display: none !important; }

/* ----- 3. LAYOUT UTILITIES ----------------------------------------------- */
.container { width: 100%; max-width: var(--container); margin: 0 auto; padding-left: var(--gutter); padding-right: var(--gutter); }
.container-sm { max-width: var(--container-sm); }
.section { padding: var(--sp-8) 0; }
.section-tight { padding: var(--sp-6) 0; }
@media (min-width: 768px) { .section { padding: var(--sp-10) 0; } }

.eyebrow {
  font-family: var(--font-body); font-size: var(--fs-xs); font-weight: 500;
  letter-spacing: var(--tracking-wider); text-transform: uppercase;
  color: var(--c-gold); display: inline-block; margin-bottom: var(--sp-3);
}
.divider-gold {
  width: 32px; height: 1px; background: var(--c-gold); margin: var(--sp-3) auto;
}
.text-center { text-align: center; }
.text-muted { color: var(--text-muted); }
.muted-link { color: var(--text-muted); font-size: var(--fs-sm); }

/* ----- 4. COMPONENTS — buttons, badges, inputs --------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--sp-2); min-height: 48px; padding: 0 var(--sp-6);
  font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 500;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  border-radius: var(--r-sm); transition: all var(--t-base) var(--ease);
  cursor: pointer; user-select: none; white-space: nowrap; line-height: 1;
}
.btn-primary { background: var(--c-ink); color: var(--c-cream); }
.btn-primary:hover { background: var(--c-rose-deep); color: var(--c-cream); transform: translateY(-1px); }
.btn-secondary { background: transparent; color: var(--c-ink); border: 1px solid var(--c-ink); }
.btn-secondary:hover { background: var(--c-ink); color: var(--c-cream); }
.btn-gold { background: var(--c-gold); color: var(--c-ink); }
.btn-gold:hover { background: var(--c-ink); color: var(--c-gold); }
.btn-ghost { background: transparent; color: var(--text); border: 1px solid var(--border); }
.btn-block { width: 100%; white-space: normal; }
.btn-lg { min-height: 56px; padding: 0 var(--sp-7); font-size: var(--fs-base); }
.btn-sm { min-height: 36px; padding: 0 var(--sp-4); font-size: var(--fs-xs); }

.badge {
  display: inline-flex; align-items: center; gap: var(--sp-1);
  padding: 4px 10px; font-size: var(--fs-xs); font-weight: 500;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  border-radius: var(--r-pill);
}
.badge-new { background: var(--c-ink); color: var(--c-cream); }
.badge-promo { background: var(--c-rose-deep); color: var(--c-cream); }
.badge-bestseller { background: var(--c-gold); color: var(--c-ink); }
.badge-stock-low { background: var(--c-blush); color: var(--c-rose-deep); }
.badge-soft { background: var(--c-blush); color: var(--c-rose-deep); }

.input, .form-control {
  display: block; width: 100%; min-height: 48px;
  padding: 0 var(--sp-4); background: #fff;
  border: 1px solid var(--border); border-radius: var(--r-sm);
  font-size: var(--fs-base); transition: border-color var(--t-base) var(--ease);
}
.input:focus, .form-control:focus { outline: none; border-color: var(--c-ink); }

/* ----- 5. HEADER --------------------------------------------------------- */
.usp-strip {
  background: var(--c-ink); color: var(--c-cream);
  height: var(--usp-h); display: flex; align-items: center; overflow: hidden;
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase;
}
.usp-strip__track {
  display: flex; gap: var(--sp-8); animation: usp-marquee 35s linear infinite;
  white-space: nowrap; padding-inline: var(--sp-4);
}
.usp-strip__item { display: inline-flex; align-items: center; gap: var(--sp-2); }
.usp-strip__item svg { width: 14px; height: 14px; color: var(--c-gold); }
@keyframes usp-marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.site-header {
  position: sticky; top: 0; z-index: var(--z-header);
  background: var(--c-cream); border-bottom: 1px solid var(--border);
  transition: box-shadow var(--t-base) var(--ease);
}
.site-header.is-scrolled { box-shadow: var(--shadow-1); }
.site-header__inner {
  height: var(--header-h); display: grid;
  grid-template-columns: auto 1fr auto; align-items: center; gap: var(--sp-2);
}
@media (min-width: 992px) {
  .site-header__inner { height: var(--header-h-desktop); grid-template-columns: 1fr auto 1fr; gap: var(--sp-4); }
}
.burger { margin-left: calc(var(--sp-2) * -1); }
@media (min-width: 992px) { .burger { margin-left: 0; } }
.site-header__brand { display: flex; align-items: center; gap: var(--sp-3); }
.site-header__brand svg { height: 34px; }
@media (min-width: 992px) { .site-header__brand { justify-content: center; } .site-header__brand svg { height: 48px; } }

/* ----- Marque Lola Intima (mark image + wordmark) ----- */
.brand { display: inline-flex; align-items: center; gap: var(--sp-2); }
.brand__mark { height: 40px; width: auto; display: block; }
.brand__word { display: inline-flex; align-items: baseline; gap: .42em; line-height: 1; white-space: nowrap; }
.brand__word i { font-family: var(--font-display); font-style: italic; font-weight: 500; font-size: 1.55rem; color: inherit; }
.brand__word b { font-family: var(--font-body); font-weight: 500; font-size: .7rem; letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--c-gold); }
@media (min-width: 992px) {
  .brand__mark { height: 54px; }
  .brand__word i { font-size: 2rem; }
  .brand__word b { font-size: .8rem; }
}
/* Contexte sombre (footer + drawer éventuel) : mark en version claire */
.site-footer .brand__mark { content: url("../img/logo/logo-mark-light.png"); }

.site-header__nav { display: none; }
@media (min-width: 992px) {
  .site-header__nav { display: flex; gap: var(--sp-6); align-items: center; }
  .site-header__nav a {
    font-size: var(--fs-sm); letter-spacing: var(--tracking-wide);
    text-transform: uppercase; font-weight: 500; padding: var(--sp-3) 0;
    position: relative;
  }
  .site-header__nav a::after {
    content: ''; position: absolute; left: 50%; bottom: 0; height: 1px;
    width: 0; background: var(--c-gold); transition: all var(--t-base) var(--ease);
  }
  .site-header__nav a:hover::after { left: 0; width: 100%; }
}

.site-header__tools { display: flex; align-items: center; gap: 2px; justify-content: flex-end; margin-right: calc(var(--sp-2) * -1); }
@media (min-width: 992px) { .site-header__tools { gap: var(--sp-1); margin-right: 0; } }
.icon-btn {
  width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--r-pill); color: var(--c-ink); position: relative;
  transition: background var(--t-base) var(--ease);
}
.icon-btn:hover { background: var(--c-blush); color: var(--c-rose-deep); }
.icon-btn svg { width: 21px; height: 21px; }
@media (min-width: 992px) { .icon-btn { width: 44px; height: 44px; } .icon-btn svg { width: 22px; height: 22px; } }
.icon-btn .cart-count,
.icon-btn .wishlist-count {
  position: absolute; top: 6px; right: 6px; min-width: 18px; height: 18px;
  background: var(--c-rose-deep); color: var(--c-cream); border-radius: var(--r-pill);
  font-size: 10px; font-weight: 600; display: inline-flex; align-items: center; justify-content: center;
  padding: 0 4px; letter-spacing: 0;
}
.icon-btn .wishlist-count.is-empty { display: none; }
.burger { display: inline-flex; }
@media (min-width: 992px) { .burger { display: none; } }

/* Mobile drawer */
.drawer-backdrop {
  position: fixed; inset: 0; background: rgba(14,11,16,.5);
  opacity: 0; pointer-events: none; z-index: var(--z-overlay);
  transition: opacity var(--t-base) var(--ease);
}
.drawer-backdrop.is-open { opacity: 1; pointer-events: auto; }
.drawer {
  position: fixed; top: 0; bottom: 0; left: 0; width: min(86vw, 380px);
  background: var(--c-cream); z-index: var(--z-drawer);
  transform: translateX(-100%); transition: transform var(--t-slow) var(--ease);
  display: flex; flex-direction: column; box-shadow: var(--shadow-3);
}
.drawer.is-open { transform: translateX(0); }
.drawer__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-4); border-bottom: 1px solid var(--border);
}
.drawer__body { flex: 1; overflow-y: auto; padding: var(--sp-4); }
.drawer__nav a {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-4) 0; border-bottom: 1px solid var(--border);
  font-family: var(--font-display); font-size: var(--fs-lg);
}
.drawer__nav a:hover { color: var(--c-rose-deep); }
.drawer__foot {
  padding: var(--sp-4); border-top: 1px solid var(--border);
  font-size: var(--fs-sm); color: var(--text-muted);
}

/* Search overlay */
.search-overlay {
  position: fixed; top: 0; left: 0; right: 0; z-index: var(--z-modal);
  background: var(--c-cream); transform: translateY(-100%);
  transition: transform var(--t-slow) var(--ease); box-shadow: var(--shadow-2);
}
.search-overlay.is-open { transform: translateY(0); }
.search-overlay__inner { padding: var(--sp-6) var(--gutter); display: flex; gap: var(--sp-3); align-items: center; }
.search-overlay input { flex: 1; min-height: 56px; font-size: var(--fs-lg); border: 0; border-bottom: 1px solid var(--c-ink); background: transparent; padding: 0; }
.search-overlay input:focus { outline: none; border-bottom-color: var(--c-gold); }

/* ----- 6. HERO ----------------------------------------------------------- */
.hero {
  position: relative; min-height: 70vh; min-height: 70dvh; display: flex; align-items: center;
  background: var(--c-ink-soft); color: var(--c-cream); overflow: hidden;
}
.hero__media {
  position: absolute; inset: 0;
  background-image: linear-gradient(135deg, rgba(14,11,16,.85) 0%, rgba(107,30,46,.55) 60%, rgba(14,11,16,.85) 100%),
                    radial-gradient(ellipse at 30% 40%, rgba(184,148,90,.18) 0%, transparent 60%);
  background-size: cover; background-position: center;
}
.hero__media::after {
  content: ''; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200' viewBox='0 0 200 200'><defs><radialGradient id='g'><stop offset='0' stop-color='%23B8945A' stop-opacity='.04'/><stop offset='1' stop-color='%23B8945A' stop-opacity='0'/></radialGradient></defs><circle cx='100' cy='100' r='80' fill='url(%23g)'/></svg>");
  background-size: 600px 600px; opacity: .6;
}
.hero__content { position: relative; z-index: 1; padding: var(--sp-9) var(--gutter); max-width: 720px; }
/* Plus d'air autour du texte hero sur mobile (le padding horizontal était à 0). */
@media (max-width: 767px) {
  .hero__content { padding: var(--sp-8) var(--sp-5); }
}
.hero__eyebrow { color: var(--c-gold); font-size: var(--fs-xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; margin-bottom: var(--sp-4); display: inline-block; }
.hero h1 {
  color: var(--c-cream); font-size: var(--fs-hero); font-style: italic;
  font-weight: 400; line-height: .98; margin-bottom: var(--sp-5);
}
.hero h1 em { font-style: italic; color: var(--c-gold); }
.hero__intro { font-size: var(--fs-md); color: rgba(250,246,240,.86); max-width: 520px; margin-bottom: var(--sp-6); }
.hero__cta-row { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.hero__cta-row .btn-primary { background: var(--c-cream); color: var(--c-ink); }
.hero__cta-row .btn-primary:hover { background: var(--c-gold); }
.hero__cta-row .btn-secondary { border-color: var(--c-cream); color: var(--c-cream); }
.hero__cta-row .btn-secondary:hover { background: var(--c-cream); color: var(--c-ink); }

/* ----- 7. SECTIONS HOME -------------------------------------------------- */
.section-head { text-align: center; margin-bottom: var(--sp-8); }
.section-head h2 { font-style: italic; font-weight: 400; }
.section-head p { color: var(--text-muted); max-width: 560px; margin: var(--sp-3) auto 0; }

/* USP cards */
.usp-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-3);
  padding: var(--sp-6) 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
}
@media (min-width: 768px) { .usp-grid { grid-template-columns: repeat(4, 1fr); gap: var(--sp-5); } }
.usp-card { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--sp-2); }
.usp-card svg { width: 28px; height: 28px; color: var(--c-gold); }
.usp-card__title { font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; }
.usp-card__sub { font-size: var(--fs-xs); color: var(--text-muted); }

/* Catégories — grille éditoriale */
.cat-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--sp-3);
}
@media (min-width: 768px) {
  .cat-grid { grid-template-columns: repeat(12, 1fr); grid-auto-rows: 280px; gap: var(--sp-4); }
  .cat-card--lg { grid-column: span 7; grid-row: span 2; }
  .cat-card--sm { grid-column: span 5; }
  .cat-card--md { grid-column: span 5; }
}
.cat-card {
  position: relative; overflow: hidden; border-radius: var(--r-sm);
  background: var(--c-ink); color: var(--c-cream); min-height: 320px;
  display: flex; align-items: flex-end; padding: var(--sp-5);
  transition: transform var(--t-slow) var(--ease);
}
.cat-card:hover { transform: scale(1.005); }
.cat-card__bg {
  position: absolute; inset: 0; background-size: cover; background-position: center;
  transition: transform var(--t-slow) var(--ease);
}
.cat-card:hover .cat-card__bg { transform: scale(1.04); }
.cat-card__bg::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(0deg, rgba(14,11,16,.7) 0%, rgba(14,11,16,.1) 60%);
}
.cat-card__content { position: relative; z-index: 1; color: var(--c-cream); }
.cat-card__content h3 { color: var(--c-cream); font-style: italic; font-weight: 400; font-size: var(--fs-2xl); margin-bottom: var(--sp-2); }
.cat-card__content p { font-size: var(--fs-sm); opacity: .85; margin-bottom: var(--sp-3); }
.cat-card__link { display: inline-flex; align-items: center; gap: var(--sp-2); color: var(--c-gold); font-size: var(--fs-xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; font-weight: 500; }
.cat-card__link svg { width: 14px; height: 14px; transition: transform var(--t-base) var(--ease); }
.cat-card:hover .cat-card__link svg { transform: translateX(4px); }

/* Catégories — visuels par défaut (gradients placeholders) */
.cat-card--soie .cat-card__bg { background-image: linear-gradient(135deg, #4A1D2C 0%, #1A1418 100%); }
.cat-card--dentelle .cat-card__bg { background-image: linear-gradient(135deg, #2A1A1F 0%, #6B1E2E 100%); }
.cat-card--ensemble .cat-card__bg { background-image: linear-gradient(135deg, #1A1418 0%, #847268 100%); }
.cat-card--bas .cat-card__bg { background-image: linear-gradient(135deg, #B8945A 0%, #4A1D2C 100%); }
.cat-card--nuit .cat-card__bg { background-image: linear-gradient(160deg, #1A1418 0%, #2A1A1F 50%, #4A1D2C 100%); }

/* Product cards */
.product-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-4);
}
@media (min-width: 768px) { .product-grid { grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); } }
@media (min-width: 1100px) { .product-grid { grid-template-columns: repeat(4, 1fr); } }

.pcard {
  display: flex; flex-direction: column; background: #fff;
  position: relative; border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden;
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.pcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); border-color: transparent; }
.pcard__media {
  position: relative; aspect-ratio: 3/4; overflow: hidden; background: var(--c-blush); display: block;
}
.pcard__media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform var(--t-slow) var(--ease), opacity var(--t-base) var(--ease);
}
.pcard:hover .pcard__media img { transform: scale(1.04); }
.pcard__media .pcard__img-alt { position: absolute; inset: 0; opacity: 0; }
.pcard:hover .pcard__img-alt { opacity: 1; }
.pcard__placeholder { position: absolute; inset: 0; opacity: .18; mix-blend-mode: overlay; transition: transform var(--t-slow) var(--ease); }
.pcard:hover .pcard__placeholder { transform: scale(1.04); }
.pcard__badges { position: absolute; top: var(--sp-2); left: var(--sp-2); display: flex; flex-direction: column; gap: var(--sp-1); z-index: 1; }
.pcard__wish {
  position: absolute; top: var(--sp-2); right: var(--sp-2); z-index: 1;
  width: 36px; height: 36px; background: rgba(250,246,240,.92);
  border-radius: var(--r-pill); display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-ink); transition: all var(--t-base) var(--ease);
}
.pcard__wish:hover { color: var(--c-rose-deep); background: var(--c-cream); }
.pcard__wish svg { width: 18px; height: 18px; transition: transform var(--t-fast) var(--ease); }
.pcard__wish.is-active { color: var(--c-rose-deep); }
.pcard__wish.is-active svg path { fill: currentColor; }
.pcard__wish.is-active svg { animation: wish-pop var(--t-base) var(--ease); }
@keyframes wish-pop { 0% { transform: scale(.7); } 50% { transform: scale(1.18); } 100% { transform: scale(1); } }
.pcard__body { padding: var(--sp-4); flex: 1; display: flex; flex-direction: column; }
.pcard__cat { font-size: var(--fs-xs); color: var(--text-muted); letter-spacing: var(--tracking-wide); text-transform: uppercase; }
.pcard__name {
  font-family: var(--font-display); font-style: italic; font-weight: 400; font-size: var(--fs-md);
  margin: var(--sp-1) 0 var(--sp-2); line-height: 1.25;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  min-height: calc(1.25em * 2);
}
.pcard__name a { transition: color var(--t-base) var(--ease); }
.pcard:hover .pcard__name a { color: var(--c-rose-deep); }
.pcard__price { display: flex; align-items: baseline; flex-wrap: wrap; gap: var(--sp-2); margin-bottom: var(--sp-3); }
.pcard__price-now { font-weight: 600; font-size: var(--fs-md); color: var(--c-ink); }
.pcard__price-old { font-size: var(--fs-sm); color: var(--text-muted); text-decoration: line-through; }
.pcard__price-save { font-size: var(--fs-xs); color: var(--c-rose-deep); font-weight: 600; }

/* Bouton panier toujours visible */
.pcard__form { margin-top: auto; }
.pcard__add {
  width: 100%; min-height: 46px; gap: var(--sp-2);
  /* En grille 2 colonnes sur mobile, la carte est étroite : on autorise le
     retour à la ligne et on réduit le padding pour ne pas tronquer le libellé. */
  white-space: normal; padding-inline: var(--sp-3); text-align: center;
}
.pcard__add svg { width: 17px; height: 17px; flex-shrink: 0; }
.pcard__add[disabled] { opacity: .45; cursor: not-allowed; pointer-events: none; }
.pcard__colors { display: flex; gap: 6px; margin-top: var(--sp-2); }
.pcard__colors span { width: 12px; height: 12px; border-radius: var(--r-pill); display: inline-block; border: 1px solid rgba(0,0,0,.1); }

/* Storytelling block */
.story {
  display: grid; grid-template-columns: 1fr; gap: var(--sp-6); align-items: center;
}
@media (min-width: 768px) { .story { grid-template-columns: 1fr 1fr; gap: var(--sp-9); } }
.story__visual {
  aspect-ratio: 4/5;
  background: linear-gradient(160deg, rgba(42,26,31,.15) 0%, rgba(107,30,46,.10) 100%),
              url('../img/lookbook/silk-03.svg') center / cover no-repeat,
              linear-gradient(160deg, #2A1A1F 0%, #6B1E2E 50%, #B8945A 100%);
  border-radius: var(--r-sm); position: relative; overflow: hidden;
}
.story__visual::after {
  content: ''; position: absolute; inset: 8%; border: 1px solid rgba(216,191,142,.4);
}
.story__content .eyebrow { color: var(--c-gold); }
.story__content h2 { font-style: italic; font-weight: 400; margin-bottom: var(--sp-4); }
.story__content p { color: var(--text-muted); margin-bottom: var(--sp-3); }
.story__sig { margin-top: var(--sp-5); font-family: var(--font-display); font-style: italic; font-size: var(--fs-md); color: var(--c-ink); }
.story__sig small { display: block; font-family: var(--font-body); font-size: var(--fs-xs); color: var(--text-muted); letter-spacing: var(--tracking-wide); text-transform: uppercase; margin-top: var(--sp-1); }

/* Reviews */
.reviews { background: var(--c-ink); color: var(--c-cream); padding: var(--sp-9) 0; }
.reviews h2 { color: var(--c-cream); font-style: italic; font-weight: 400; }
.reviews .eyebrow { color: var(--c-gold); }
.review-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--sp-4); margin-top: var(--sp-7);
}
@media (min-width: 768px) { .review-grid { grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); } }
/* Carte avis — variante CLAIRE par défaut (onglet « Avis » des fiches produit,
   fond blanc/crème). La variante sombre est gérée plus bas dans .reviews. */
.review-card {
  background: #fff; padding: var(--sp-5); border-radius: var(--r-sm);
  border: 1px solid var(--border); display: flex; flex-direction: column; gap: var(--sp-3);
}
.review-card__stars { color: var(--c-gold); letter-spacing: 2px; font-size: var(--fs-md); }
.review-card__quote { font-family: var(--font-display); font-style: italic; font-size: var(--fs-md); line-height: var(--lh-snug); color: var(--c-ink); }
.review-card__author { display: flex; align-items: center; gap: var(--sp-3); margin-top: auto; }
.review-card__avatar { width: 40px; height: 40px; border-radius: var(--r-pill); background: var(--c-gold); color: var(--c-ink); display: inline-flex; align-items: center; justify-content: center; font-weight: 600; font-size: var(--fs-sm); flex-shrink: 0; }
.review-card__meta { font-size: var(--fs-xs); }
.review-card__name { color: var(--c-ink); font-weight: 500; }
.review-card__date { color: var(--text-muted); }
.review-card__product { font-size: var(--fs-xs); color: var(--text-muted); margin-top: var(--sp-2); }
.review-card__product strong { color: var(--c-gold); font-weight: 500; }

/* Variante SOMBRE — section avis de l'accueil (fond encre). */
.reviews .review-card { background: rgba(250,246,240,.04); border-color: rgba(250,246,240,.08); }
.reviews .review-card__quote,
.reviews .review-card__name { color: var(--c-cream); }
.reviews .review-card__date { color: rgba(250,246,240,.5); }
.reviews .review-card__product { color: rgba(250,246,240,.6); }

/* Newsletter */
.newsletter {
  background: var(--c-blush); padding: var(--sp-9) 0;
}
.newsletter__inner { display: grid; grid-template-columns: 1fr; gap: var(--sp-5); align-items: center; text-align: center; }
@media (min-width: 768px) { .newsletter__inner { grid-template-columns: 1.2fr 1fr; text-align: left; gap: var(--sp-8); } }
.newsletter h2 { font-style: italic; font-weight: 400; color: var(--c-rose-deep); }
.newsletter p { color: var(--c-rose-deep); opacity: .8; margin-top: var(--sp-3); }
.newsletter__form {
  display: flex; gap: var(--sp-2); flex-wrap: wrap;
  width: 100%; max-width: 460px;
}
@media (max-width: 767px) { .newsletter__form { margin-inline: auto; } }
.newsletter__form input {
  flex: 1 1 200px; min-width: 0; width: auto;
  min-height: 56px; padding: 0 var(--sp-4);
  background: var(--c-cream); border: 1px solid var(--c-cream); border-radius: 0;
  font-size: var(--fs-base); font-family: var(--font-body); color: var(--c-ink);
  transition: border-color var(--t-base) var(--ease);
}
.newsletter__form input::placeholder { color: var(--c-taupe); }
.newsletter__form input:focus { outline: none; border-color: var(--c-rose-deep); background: #fff; }
.newsletter__form button {
  flex: 0 0 auto; min-height: 56px; border-radius: 0; white-space: nowrap;
}
@media (max-width: 420px) {
  .newsletter__form input, .newsletter__form button { flex-basis: 100%; }
}
.newsletter__tiny { font-size: var(--fs-xs); margin-top: var(--sp-4); opacity: .7; }

/* Reassurance bar */
.reassurance {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-4);
  padding: var(--sp-6) 0; border-top: 1px solid var(--border);
}
@media (min-width: 768px) { .reassurance { grid-template-columns: repeat(4, 1fr); } }
.reassurance__item { display: flex; gap: var(--sp-3); align-items: center; }
.reassurance__icon { width: 36px; height: 36px; color: var(--c-gold); flex-shrink: 0; }
.reassurance__title { font-size: var(--fs-sm); font-weight: 600; }
.reassurance__sub { font-size: var(--fs-xs); color: var(--text-muted); margin-top: 2px; }

/* ----- 8. PRODUCT PAGE --------------------------------------------------- */
.product-page { padding-top: var(--sp-5); padding-bottom: 100px; }
@media (min-width: 992px) { .product-page { padding-bottom: var(--sp-10); } }
.product-grid-main {
  display: grid; grid-template-columns: 1fr; gap: var(--sp-6);
}
@media (min-width: 992px) { .product-grid-main { grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr); gap: var(--sp-9); } }

.gallery { display: flex; flex-direction: column; gap: var(--sp-3); }
.gallery__main {
  aspect-ratio: 3/4; background: var(--c-blush); position: relative; overflow: hidden;
}
.gallery__main img { width: 100%; height: 100%; object-fit: cover; }
.gallery__thumbs { display: flex; gap: var(--sp-2); overflow-x: auto; scrollbar-width: none; }
.gallery__thumbs::-webkit-scrollbar { display: none; }
.gallery__thumb {
  flex: 0 0 72px; aspect-ratio: 3/4; background: var(--c-blush); cursor: pointer;
  border: 2px solid transparent; transition: border-color var(--t-base) var(--ease);
}
.gallery__thumb.is-active { border-color: var(--c-ink); }
.gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }

.product-info { display: flex; flex-direction: column; gap: var(--sp-4); }
.product-info__brand { font-size: var(--fs-xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--c-gold); font-weight: 500; }
.product-info__name { font-family: var(--font-display); font-style: italic; font-weight: 400; font-size: var(--fs-3xl); margin: var(--sp-1) 0; line-height: 1; }
.product-info__rating { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-sm); }
.product-info__stars { color: var(--c-gold); letter-spacing: 2px; }

.price-row { display: flex; align-items: baseline; gap: var(--sp-3); flex-wrap: wrap; margin: var(--sp-2) 0; }
.price-now { font-size: var(--fs-2xl); font-weight: 600; color: var(--c-ink); }
.price-old { font-size: var(--fs-md); color: var(--text-muted); text-decoration: line-through; }
.price-save { background: var(--c-rose-deep); color: var(--c-cream); padding: 4px 10px; border-radius: var(--r-sm); font-size: var(--fs-xs); font-weight: 600; letter-spacing: var(--tracking-wide); }
.price-installments { font-size: var(--fs-xs); color: var(--text-muted); }

.color-picker { display: flex; flex-direction: column; gap: var(--sp-2); }
.color-picker__label { display: flex; justify-content: space-between; font-size: var(--fs-sm); }
.color-picker__label .selected { color: var(--text-muted); }
.color-picker__swatches { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.swatch {
  width: 32px; height: 32px; border-radius: var(--r-pill); border: 2px solid var(--c-cream);
  outline: 1px solid var(--border); cursor: pointer;
  transition: outline-color var(--t-base) var(--ease);
}
.swatch.is-selected { outline-color: var(--c-ink); outline-offset: 2px; }
.swatch.is-disabled { opacity: .35; cursor: not-allowed; position: relative; }
.swatch.is-disabled::after { content: ''; position: absolute; inset: -2px; background: linear-gradient(45deg, transparent 47%, var(--c-error) 48%, var(--c-error) 52%, transparent 53%); border-radius: var(--r-pill); }

.size-picker__label { display: flex; justify-content: space-between; font-size: var(--fs-sm); margin-bottom: var(--sp-2); }
.size-picker__label a { font-size: var(--fs-xs); color: var(--text-muted); text-decoration: underline; }
.size-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--sp-2); }
@media (min-width: 768px) { .size-grid { grid-template-columns: repeat(6, 1fr); } }
.size-btn {
  min-height: 48px; border: 1px solid var(--border); background: var(--c-cream);
  font-size: var(--fs-sm); font-weight: 500; transition: all var(--t-base) var(--ease);
}
.size-btn:hover { border-color: var(--c-ink); }
.size-btn.is-selected { background: var(--c-ink); color: var(--c-cream); border-color: var(--c-ink); }
.size-btn.is-low { position: relative; }
.size-btn.is-low::after {
  content: '•'; position: absolute; top: 2px; right: 6px; color: var(--c-rose-deep);
  font-size: 18px; line-height: 1;
}
.size-btn.is-out { color: var(--text-muted); text-decoration: line-through; cursor: not-allowed; }

.stock-indicator { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-sm); }
.stock-dot { width: 8px; height: 8px; border-radius: var(--r-pill); }
.stock-in .stock-dot { background: var(--c-success); }
.stock-low .stock-dot { background: var(--c-rose-deep); animation: pulse 2s infinite; }
.stock-out .stock-dot { background: var(--text-muted); }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: .4; } }

.cta-row { display: flex; gap: var(--sp-2); margin-top: var(--sp-3); }
.cta-row .btn-primary { flex: 1; }
.cta-row .icon-btn { border: 1px solid var(--border); }

.urgency {
  background: var(--c-blush); color: var(--c-rose-deep); padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-sm); font-size: var(--fs-sm); display: flex; align-items: center; gap: var(--sp-2);
}
.urgency svg { width: 18px; height: 18px; flex-shrink: 0; }

.delivery-block {
  border: 1px solid var(--border); border-radius: var(--r-sm); padding: var(--sp-4);
}
.delivery-row { display: flex; align-items: flex-start; gap: var(--sp-3); padding: var(--sp-2) 0; }
.delivery-row svg { width: 22px; height: 22px; color: var(--c-gold); flex-shrink: 0; margin-top: 2px; }
.delivery-row__main { font-size: var(--fs-sm); font-weight: 500; }
.delivery-row__sub { font-size: var(--fs-xs); color: var(--text-muted); margin-top: 2px; }

/* Tabs (description, composition, livraison, avis) */
.tabs { margin-top: var(--sp-9); border-top: 1px solid var(--border); }
.tab-list { display: flex; gap: var(--sp-3); overflow-x: auto; border-bottom: 1px solid var(--border); margin-bottom: var(--sp-6); }
.tab-list::-webkit-scrollbar { display: none; }
.tab-btn {
  padding: var(--sp-4) var(--sp-2); font-size: var(--fs-sm); font-weight: 500;
  letter-spacing: var(--tracking-wide); text-transform: uppercase; white-space: nowrap;
  border-bottom: 2px solid transparent; transition: all var(--t-base) var(--ease); cursor: pointer;
}
.tab-btn.is-active { color: var(--c-ink); border-bottom-color: var(--c-gold); }
.tab-panel { display: none; }
.tab-panel.is-active { display: block; }
.tab-panel h3 { margin-bottom: var(--sp-3); }
.tab-panel p { margin-bottom: var(--sp-3); color: var(--text-muted); }
.tab-panel ul { padding-left: var(--sp-4); list-style: disc; color: var(--text-muted); }
.tab-panel ul li { margin-bottom: var(--sp-1); }

/* Sticky mobile CTA */
.sticky-cta {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: var(--z-sticky);
  background: var(--c-cream); border-top: 1px solid var(--border);
  padding: var(--sp-3) var(--gutter); box-shadow: 0 -4px 12px rgba(14,11,16,.06);
  display: flex; gap: var(--sp-2); align-items: center;
  transform: translateY(100%); transition: transform var(--t-base) var(--ease);
}
.sticky-cta.is-visible { transform: translateY(0); }
.sticky-cta__price { font-size: var(--fs-md); font-weight: 600; min-width: 80px; }
.sticky-cta__btn { flex: 1; }
@media (min-width: 992px) { .sticky-cta { display: none; } }

/* ----- 9. FOOTER --------------------------------------------------------- */
.site-footer { background: var(--c-ink); color: var(--c-cream); padding: var(--sp-10) 0 var(--sp-6); }
.site-footer h4 { color: var(--c-cream); font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 600; letter-spacing: var(--tracking-wider); text-transform: uppercase; margin-bottom: var(--sp-4); }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-6); }
@media (min-width: 768px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr; gap: var(--sp-8); } }
.footer-grid a, .footer-grid li { color: rgba(250,246,240,.7); font-size: var(--fs-sm); }
.footer-grid li { padding: var(--sp-1) 0; }
.footer-grid a:hover { color: var(--c-gold); }
.footer-brand__logo { margin-bottom: var(--sp-4); }
.footer-brand__logo svg { height: 32px; }
.footer-brand p { color: rgba(250,246,240,.6); font-size: var(--fs-sm); max-width: 360px; }
.footer-social { display: flex; gap: var(--sp-3); margin-top: var(--sp-4); }
.footer-social a { width: 40px; height: 40px; border: 1px solid rgba(250,246,240,.2); border-radius: var(--r-pill); display: inline-flex; align-items: center; justify-content: center; color: var(--c-cream); }
.footer-social a:hover { background: var(--c-gold); border-color: var(--c-gold); color: var(--c-ink); }
.footer-payments { display: flex; gap: var(--sp-2); align-items: center; flex-wrap: wrap; margin-top: var(--sp-4); }
.footer-payments img, .footer-payments svg { height: 22px; opacity: .8; }
.footer-bottom {
  margin-top: var(--sp-8); padding-top: var(--sp-5); border-top: 1px solid rgba(250,246,240,.1);
  display: flex; flex-direction: column; gap: var(--sp-3); align-items: center; text-align: center;
  font-size: var(--fs-xs); color: rgba(250,246,240,.5);
}
@media (min-width: 768px) { .footer-bottom { flex-direction: row; justify-content: space-between; text-align: left; } }

/* ----- Bandeau cookies ----- */
.cookie-banner {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: var(--z-header, 1000);
  background: var(--c-ink); color: var(--c-cream);
  border-top: 1px solid rgba(216,191,142,.3);
  box-shadow: 0 -6px 24px rgba(0,0,0,.25);
  padding: var(--sp-4) 0; transform: translateY(110%);
  transition: transform .4s var(--ease);
}
.cookie-banner.is-visible { transform: translateY(0); }
.cookie-banner[hidden] { display: none; }
.cookie-banner__inner {
  width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter);
  display: flex; flex-direction: column; gap: var(--sp-3); align-items: flex-start;
}
@media (min-width: 768px) { .cookie-banner__inner { flex-direction: row; align-items: center; justify-content: space-between; gap: var(--sp-6); } }
.cookie-banner__text { font-size: var(--fs-sm); color: rgba(250,246,240,.82); margin: 0; max-width: 760px; }
.cookie-banner__text a { color: var(--c-gold); text-decoration: underline; }
.cookie-banner__actions { display: flex; gap: var(--sp-3); flex-shrink: 0; }
.btn-sm { padding: var(--sp-2) var(--sp-4); font-size: var(--fs-sm); }

/* ----- 10. UTILS --------------------------------------------------------- */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
.no-scroll { overflow: hidden; }
[data-reveal] { opacity: 0; transform: translateY(20px); transition: opacity 600ms var(--ease), transform 600ms var(--ease); }
[data-reveal].is-visible { opacity: 1; transform: translateY(0); }

/* ----- 11. AUTH / REGISTRATION / ACCOUNT ---------------------------------- */
.auth-page { min-height: calc(100vh - var(--header-h)); min-height: calc(100dvh - var(--header-h)); padding: var(--sp-7) 0 var(--sp-9); background: var(--c-cream); }
@media (min-width: 768px) { .auth-page { padding: var(--sp-10) 0; } }

.auth-grid {
  display: grid; grid-template-columns: 1fr; gap: 0; max-width: 980px; margin: 0 auto;
  background: #fff; box-shadow: var(--shadow-2); overflow: hidden;
}
@media (min-width: 768px) { .auth-grid { grid-template-columns: 1fr 1fr; min-height: 620px; } }

.auth-visual {
  display: none; position: relative; padding: var(--sp-8);
  background: linear-gradient(160deg, #1A1418 0%, #6B1E2E 60%, #B8945A 110%);
  color: var(--c-cream);
}
.auth-visual::after {
  content: ''; position: absolute; inset: var(--sp-4); border: 1px solid rgba(216,191,142,.3); pointer-events: none;
}
@media (min-width: 768px) { .auth-visual { display: flex; flex-direction: column; justify-content: space-between; } }
.auth-visual__head { font-family: var(--font-display); font-style: italic; font-weight: 500; font-size: var(--fs-2xl); line-height: 1.1; color: var(--c-cream); margin-bottom: var(--sp-3); position: relative; z-index: 1; }
.auth-visual__intro { color: rgba(250,246,240,.86); font-size: var(--fs-md); position: relative; z-index: 1; max-width: 320px; }
.auth-visual__quote { position: relative; z-index: 1; font-family: var(--font-display); font-style: italic; font-size: var(--fs-md); color: rgba(250,246,240,.9); border-top: 1px solid rgba(216,191,142,.25); padding-top: var(--sp-5); }
.auth-visual__quote small { display: block; font-family: var(--font-body); font-size: var(--fs-xs); color: rgba(250,246,240,.55); letter-spacing: var(--tracking-wide); text-transform: uppercase; margin-top: var(--sp-2); }

.auth-pane { padding: var(--sp-7) var(--sp-5); }
@media (min-width: 768px) { .auth-pane { padding: var(--sp-9) var(--sp-7); } }
.auth-pane h1 { font-style: italic; font-weight: 400; font-size: var(--fs-2xl); margin-bottom: var(--sp-2); }
.auth-pane__sub { color: var(--text-muted); margin-bottom: var(--sp-6); font-size: var(--fs-sm); }
.auth-pane__switch { font-size: var(--fs-sm); color: var(--text-muted); margin-top: var(--sp-5); text-align: center; }
.auth-pane__switch a { color: var(--c-ink); text-decoration: underline; }
/* Zone modules de connexion (Google, etc.) injectés via les hooks */
.auth-social { margin-top: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-3); }
.auth-social:empty { display: none; }

/* Habillage des formulaires rendus par PrestaShop ({render ...}) dans le panneau auth */
.auth-pane .form-group { margin-bottom: var(--sp-4); }
.auth-pane .form-group.row { display: block; margin-inline: 0; }
.auth-pane [class*="col-md"],
.auth-pane [class*="col-sm"] { flex: 0 0 100%; max-width: 100%; padding-inline: 0; }
.auth-pane .form-control-label,
.auth-pane label.col-md-3,
.auth-pane .form-group > label {
  display: block; width: 100%; max-width: none; text-align: left; padding: 0;
  font-size: var(--fs-xs); font-weight: 500; letter-spacing: var(--tracking-wider);
  text-transform: uppercase; margin-bottom: var(--sp-2); color: var(--c-ink);
}
.auth-pane .form-control-comment { font-size: var(--fs-xs); color: var(--text-muted); margin-top: 6px; }
.auth-pane .form-control-comment.text-danger,
.auth-pane .help-block,
.auth-pane .js-invalid-feedback { color: var(--c-error); font-size: var(--fs-xs); margin-top: 6px; }
.auth-pane .checkbox label,
.auth-pane .custom-checkbox label,
.auth-pane .ps-shown-by-js label { font-size: var(--fs-sm); line-height: 1.45; color: var(--text-muted); }
.auth-pane .form-footer { margin-top: var(--sp-5); }
.auth-pane .form-footer .btn { width: 100%; }

.form-field { margin-bottom: var(--sp-4); }
.form-field__label {
  display: block; font-size: var(--fs-xs); font-weight: 500;
  letter-spacing: var(--tracking-wider); text-transform: uppercase;
  margin-bottom: var(--sp-2); color: var(--c-ink);
}
.form-field__label .req { color: var(--c-rose-deep); }
.form-field input, .form-field select, .form-field textarea {
  width: 100%; max-width: 100%; min-height: 52px; padding: 0 var(--sp-4);
  background: #fff; border: 1px solid var(--c-line); border-radius: var(--r-sm);
  font-size: var(--fs-base); color: var(--c-ink);
  transition: border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
  -webkit-appearance: none; appearance: none;
}
.form-field textarea { padding: var(--sp-3) var(--sp-4); }
.form-field input::placeholder, .form-field textarea::placeholder { color: var(--c-muted); }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus {
  outline: none; border-color: var(--c-ink);
  box-shadow: 0 0 0 3px rgba(184, 148, 90, .16);
}
/* Flèche custom sur les <select> */
.form-field select {
  padding-right: var(--sp-8);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%230E0B10' stroke-width='1.6'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right var(--sp-4) center;
  cursor: pointer;
}
.form-field input[type="checkbox"], .form-field input[type="radio"] { width: 18px; height: 18px; min-height: 0; flex-shrink: 0; margin-right: var(--sp-2); accent-color: var(--c-ink); -webkit-appearance: auto; appearance: auto; box-shadow: none; }
.form-field__hint { font-size: var(--fs-xs); color: var(--text-muted); margin-top: 6px; }
.form-field__error { font-size: var(--fs-xs); color: var(--c-error); margin-top: 6px; }
.form-field--check { display: flex; align-items: flex-start; gap: var(--sp-2); }
.form-field--check label { font-size: var(--fs-sm); line-height: 1.45; color: var(--text-muted); cursor: pointer; }
.form-field--check input { margin-top: 3px; }
/* Newsletter retirée : on masque la case d'inscription newsletter des formulaires */
.form-field--check:has(#field-newsletter) { display: none; }

.form-row { display: grid; grid-template-columns: 1fr; gap: var(--sp-3); }
@media (min-width: 768px) { .form-row { grid-template-columns: 1fr 1fr; gap: var(--sp-4); } }

.password-strength {
  display: flex; gap: 4px; margin-top: 8px;
}
.password-strength span { flex: 1; height: 3px; background: var(--border); border-radius: var(--r-pill); }
.password-strength.is-weak span:nth-child(1) { background: var(--c-error); }
.password-strength.is-medium span:nth-child(-n+2) { background: var(--c-gold); }
.password-strength.is-strong span { background: var(--c-success); }

.auth-actions { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--sp-2) var(--sp-3); margin-top: var(--sp-4); }
.auth-forgot { font-size: var(--fs-sm); color: var(--text-muted); text-decoration: underline; }

.social-auth {
  display: flex; flex-direction: column; gap: var(--sp-2); margin: var(--sp-5) 0;
  padding-top: var(--sp-5); border-top: 1px solid var(--border);
}
.social-auth__head { text-align: center; font-size: var(--fs-xs); color: var(--text-muted); letter-spacing: var(--tracking-wider); text-transform: uppercase; margin-bottom: var(--sp-3); }
.social-btn {
  display: flex; align-items: center; justify-content: center; gap: var(--sp-3);
  min-height: 48px; padding: 0 var(--sp-5); background: #fff; border: 1px solid var(--border); border-radius: var(--r-sm);
  font-size: var(--fs-sm); font-weight: 500; transition: all var(--t-base) var(--ease); cursor: pointer;
}
.social-btn:hover { border-color: var(--c-ink); background: var(--c-cream); }
.social-btn svg { width: 18px; height: 18px; }

/* My account dashboard */
.account-page { padding: var(--sp-7) 0 var(--sp-10); }
.account-head { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-7); }
.account-head h1 { font-style: italic; font-weight: 400; font-size: var(--fs-2xl); }
.account-head__sub { color: var(--text-muted); }

.account-grid { display: grid; grid-template-columns: repeat(1, 1fr); gap: var(--sp-3); }
@media (min-width: 640px) { .account-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); } }
@media (min-width: 992px) { .account-grid { grid-template-columns: repeat(3, 1fr); } }
.account-tile {
  display: flex; flex-direction: column; gap: var(--sp-2);
  padding: var(--sp-5); border: 1px solid var(--border); background: #fff;
  transition: all var(--t-base) var(--ease); position: relative;
}
.account-tile:hover { border-color: var(--c-ink); transform: translateY(-2px); box-shadow: var(--shadow-2); }
.account-tile__icon { width: 32px; height: 32px; color: var(--c-gold); margin-bottom: var(--sp-2); }
.account-tile__title { font-family: var(--font-display); font-style: italic; font-size: var(--fs-lg); font-weight: 500; color: var(--c-ink); }
.account-tile__sub { color: var(--text-muted); font-size: var(--fs-sm); }
.account-tile__arrow { position: absolute; top: var(--sp-5); right: var(--sp-5); color: var(--c-gold); }

/* Liens injectés par les modules dans l'espace compte (hook displayCustomerAccount :
   liste d'envies, données personnelles/RGPD, retours…). Markup Bootstrap brut
   (.col-*, .link-item) non habillé → on leur donne le look "tuile". */
.account-page [id$="-link"] {
  display: flex !important; float: none !important;
  width: 100% !important; max-width: 100%;
  align-items: center; gap: var(--sp-3);
  margin-top: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  background: #fff; border: 1px solid var(--border);
  transition: all var(--t-base) var(--ease);
}
.account-page [id$="-link"]:hover { border-color: var(--c-ink); transform: translateY(-2px); box-shadow: var(--shadow-2); }
.account-page [id$="-link"] .link-item {
  display: flex; align-items: center; gap: var(--sp-3);
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: var(--fs-lg); color: var(--c-ink);
}
.account-page [id$="-link"]::after {
  content: ''; width: 16px; height: 16px; margin-left: auto; flex-shrink: 0;
  background: var(--c-gold);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8'%3E%3Cpath d='M5 12h14M13 6l6 6-6 6'/%3E%3C/svg%3E") center/contain no-repeat;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8'%3E%3Cpath d='M5 12h14M13 6l6 6-6 6'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* ----- 12. CART --------------------------------------------------------- */
.cart-page { padding: var(--sp-6) 0 var(--sp-10); }
.cart-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: var(--sp-6); flex-wrap: wrap; gap: var(--sp-2); }
.cart-head h1 { font-style: italic; font-weight: 400; font-size: var(--fs-2xl); }
.cart-head__count { color: var(--text-muted); font-size: var(--fs-sm); }

.cart-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-7); }
@media (min-width: 992px) { .cart-grid { grid-template-columns: 1.6fr 1fr; gap: var(--sp-8); align-items: start; } }

.cart-lines { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--border); }
.cart-line {
  display: grid; grid-template-columns: 96px 1fr; gap: var(--sp-4);
  padding: var(--sp-5) 0; border-bottom: 1px solid var(--border);
}
@media (min-width: 640px) { .cart-line { grid-template-columns: 120px 1fr auto; gap: var(--sp-5); } }
.cart-line__img { aspect-ratio: 3/4; background: var(--c-blush); position: relative; overflow: hidden; }
.cart-line__img img { width: 100%; height: 100%; object-fit: cover; }
.cart-line__body { display: flex; flex-direction: column; gap: var(--sp-1); }
.cart-line__cat { font-size: var(--fs-xs); color: var(--text-muted); letter-spacing: var(--tracking-wide); text-transform: uppercase; }
.cart-line__name { font-family: var(--font-display); font-style: italic; font-size: var(--fs-md); font-weight: 500; }
.cart-line__variant { font-size: var(--fs-sm); color: var(--text-muted); }
.cart-line__price-mobile { font-weight: 600; margin-top: var(--sp-2); }
@media (min-width: 640px) { .cart-line__price-mobile { display: none; } }
.cart-line__controls { display: flex; align-items: center; gap: var(--sp-3); margin-top: var(--sp-3); }
.cart-line__qty {
  display: inline-flex; align-items: center; height: 36px; padding: 0 var(--sp-3);
  border: 1px solid var(--border); border-radius: var(--r-pill); background: var(--c-cream);
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--c-taupe);
}
.cart-line__remove { font-size: var(--fs-xs); color: var(--text-muted); text-decoration: underline; cursor: pointer; }
.cart-line__remove:hover { color: var(--c-rose-deep); }
.cart-line__price { display: none; }
@media (min-width: 640px) {
  .cart-line__price { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; min-width: 110px; text-align: right; }
  .cart-line__price-now { font-size: var(--fs-md); font-weight: 600; }
  .cart-line__price-old { font-size: var(--fs-sm); color: var(--text-muted); text-decoration: line-through; }
}

.cart-empty {
  text-align: center; padding: var(--sp-10) var(--sp-5);
  max-width: 480px; margin: 0 auto;
}
.cart-empty svg { width: 64px; height: 64px; color: var(--c-gold); margin: 0 auto var(--sp-4); display: block; }
.cart-empty h2 { font-style: italic; font-weight: 400; margin-bottom: var(--sp-3); }
.cart-empty p { color: var(--text-muted); margin-bottom: var(--sp-5); }

.cart-summary {
  background: #fff; padding: var(--sp-5); border: 1px solid var(--border);
}
@media (min-width: 992px) { .cart-summary { position: sticky; top: calc(var(--header-h-desktop) + var(--sp-3)); } }
.cart-summary h2 { font-style: italic; font-weight: 400; font-size: var(--fs-lg); margin-bottom: var(--sp-4); padding-bottom: var(--sp-3); border-bottom: 1px solid var(--border); }
.cart-summary__row { display: flex; justify-content: space-between; padding: var(--sp-2) 0; font-size: var(--fs-sm); }
.cart-summary__row--total {
  font-size: var(--fs-md); font-weight: 600; padding: var(--sp-4) 0 0;
  border-top: 1px solid var(--border); margin-top: var(--sp-3);
}
.cart-summary__shipping-free { color: var(--c-success); font-weight: 500; }
.cart-summary__free-bar {
  background: var(--c-blush); padding: var(--sp-3); margin: var(--sp-3) 0;
  font-size: var(--fs-sm); color: var(--c-rose-deep); text-align: center; border-radius: var(--r-sm);
}
.cart-summary__free-bar progress {
  display: block; width: 100%; height: 4px; appearance: none; margin: var(--sp-2) 0 0; border: 0;
}
.cart-summary__free-bar progress::-webkit-progress-bar { background: rgba(107,30,46,.15); border-radius: var(--r-pill); }
.cart-summary__free-bar progress::-webkit-progress-value { background: var(--c-rose-deep); border-radius: var(--r-pill); }
.cart-summary__cta { margin-top: var(--sp-5); }
.cart-summary__guarantees {
  margin-top: var(--sp-5); padding-top: var(--sp-4); border-top: 1px solid var(--border);
  display: flex; flex-direction: column; gap: var(--sp-2);
}
.cart-summary__guarantees div {
  display: flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-xs); color: var(--text-muted);
}
.cart-summary__guarantees svg { width: 14px; height: 14px; color: var(--c-gold); flex-shrink: 0; }
.cart-summary__payments {
  display: flex; gap: 6px; margin-top: var(--sp-3); justify-content: center;
}
.cart-summary__payments img, .cart-summary__payments svg { height: 18px; opacity: .85; }

.promo-code {
  display: flex; gap: var(--sp-2); margin: var(--sp-3) 0;
}
.promo-code input { flex: 1; min-width: 0; min-height: 44px; padding: 0 var(--sp-3); border: 1px solid var(--border); background: var(--c-cream); border-radius: var(--r-sm); font-size: var(--fs-base); }
.promo-code button { min-height: 44px; padding: 0 var(--sp-4); background: transparent; border: 1px solid var(--c-ink); border-radius: var(--r-sm); font-size: var(--fs-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; cursor: pointer; }
.promo-code button:hover { background: var(--c-ink); color: var(--c-cream); }

/* Upsell strip dans le panier */
.cart-upsell { padding-top: var(--sp-7); border-top: 1px solid var(--border); margin-top: var(--sp-7); }
.cart-upsell h3 { font-style: italic; font-weight: 400; margin-bottom: var(--sp-4); font-size: var(--fs-lg); }
.cart-upsell__strip { display: flex; gap: var(--sp-3); overflow-x: auto; scrollbar-width: none; padding-bottom: var(--sp-2); }
.cart-upsell__strip::-webkit-scrollbar { display: none; }
.cart-upsell__strip .pcard { flex: 0 0 200px; }

/* ----- 13. CHECKOUT ------------------------------------------------------ */
.checkout-page { padding: var(--sp-6) 0 var(--sp-10); background: var(--c-cream); }
.checkout-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-7); }
@media (min-width: 992px) { .checkout-grid { grid-template-columns: 1.4fr 1fr; gap: var(--sp-8); } }

.checkout-steps { display: flex; flex-direction: column; gap: 0; }
.checkout-step {
  background: #fff; border: 1px solid var(--border); margin-bottom: var(--sp-3);
}
.checkout-step__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-4) var(--sp-5); cursor: pointer;
  border-bottom: 1px solid transparent;
}
.checkout-step.is-open .checkout-step__head { border-bottom-color: var(--border); }
.checkout-step__title { display: flex; align-items: center; gap: var(--sp-3); font-family: var(--font-display); font-style: italic; font-size: var(--fs-lg); font-weight: 500; }
.checkout-step__num {
  width: 28px; height: 28px; border-radius: var(--r-pill); background: var(--c-cream); border: 1px solid var(--c-ink);
  display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-body);
  font-size: var(--fs-sm); font-weight: 600; font-style: normal;
}
.checkout-step.is-done .checkout-step__num { background: var(--c-ink); color: var(--c-cream); border-color: var(--c-ink); }
.checkout-step.is-current .checkout-step__num { background: var(--c-gold); color: var(--c-ink); border-color: var(--c-gold); }
.checkout-step.is-locked .checkout-step__title { color: var(--text-muted); }
.checkout-step.is-locked .checkout-step__num { opacity: .4; }
.checkout-step__edit { font-size: var(--fs-xs); color: var(--text-muted); text-decoration: underline; cursor: pointer; }
.checkout-step__body { padding: var(--sp-5); display: none; }
.checkout-step.is-open .checkout-step__body { display: block; }
.checkout-step__done-preview { padding: 0 var(--sp-5) var(--sp-4); font-size: var(--fs-sm); color: var(--text-muted); }

.shipping-choices, .payment-choices { display: flex; flex-direction: column; gap: var(--sp-2); }
.choice-card {
  display: flex; gap: var(--sp-3); padding: var(--sp-4); border: 1px solid var(--border);
  border-radius: var(--r-sm); cursor: pointer; transition: all var(--t-base) var(--ease);
}
.choice-card:hover { border-color: var(--c-ink); }
.choice-card.is-selected { border-color: var(--c-ink); background: var(--c-cream); }
.choice-card__radio {
  width: 18px; height: 18px; border: 1px solid var(--text-muted); border-radius: var(--r-pill);
  flex-shrink: 0; margin-top: 2px; position: relative;
}
.choice-card.is-selected .choice-card__radio { border-color: var(--c-ink); }
.choice-card.is-selected .choice-card__radio::after { content: ''; position: absolute; inset: 3px; background: var(--c-ink); border-radius: var(--r-pill); }
.choice-card__body { flex: 1; }
.choice-card__title { font-weight: 500; font-size: var(--fs-sm); display: flex; justify-content: space-between; gap: var(--sp-3); }
.choice-card__title strong { font-weight: 600; }
.choice-card__sub { font-size: var(--fs-xs); color: var(--text-muted); margin-top: 4px; }
.choice-card__badge { display: inline-block; padding: 2px 6px; background: var(--c-blush); color: var(--c-rose-deep); border-radius: var(--r-sm); font-size: 10px; letter-spacing: var(--tracking-wide); text-transform: uppercase; margin-left: var(--sp-2); }

.checkout-mini {
  background: #fff; padding: var(--sp-5); border: 1px solid var(--border);
}
@media (min-width: 992px) { .checkout-mini { position: sticky; top: calc(var(--header-h-desktop) + var(--sp-3)); } }
.checkout-mini h2 { font-style: italic; font-weight: 400; font-size: var(--fs-lg); margin-bottom: var(--sp-4); }
.checkout-mini__lines { display: flex; flex-direction: column; gap: var(--sp-3); margin-bottom: var(--sp-4); padding-bottom: var(--sp-4); border-bottom: 1px solid var(--border); }
.checkout-mini__line { display: grid; grid-template-columns: 56px 1fr auto; gap: var(--sp-3); align-items: center; }
.checkout-mini__img { aspect-ratio: 3/4; background: var(--c-blush); overflow: hidden; position: relative; }
.checkout-mini__img img { width: 100%; height: 100%; object-fit: cover; }
.checkout-mini__img-qty {
  position: absolute; top: -6px; right: -6px; width: 20px; height: 20px;
  border-radius: var(--r-pill); background: var(--c-ink); color: var(--c-cream);
  font-size: 10px; font-weight: 600; display: flex; align-items: center; justify-content: center;
}
.checkout-mini__name { font-size: var(--fs-sm); }
.checkout-mini__variant { font-size: var(--fs-xs); color: var(--text-muted); margin-top: 2px; }
.checkout-mini__price { font-size: var(--fs-sm); font-weight: 600; text-align: right; }
.checkout-reassurance {
  list-style: none; margin: var(--sp-5) 0 0; padding: var(--sp-5) 0 0;
  border-top: 1px solid var(--border); display: flex; flex-direction: column; gap: var(--sp-4);
}
.checkout-reassurance li { display: flex; gap: var(--sp-3); align-items: flex-start; font-size: var(--fs-xs); color: var(--text-muted); line-height: var(--lh-snug); }
.checkout-reassurance li strong { color: var(--c-ink); font-weight: 600; }
.checkout-reassurance svg { width: 20px; height: 20px; flex-shrink: 0; color: var(--c-gold); }

/* Order confirmation */
.confirm-page { padding: var(--sp-9) 0; text-align: center; min-height: 60vh; min-height: 60dvh; }
.confirm-page__icon {
  width: 80px; height: 80px; border-radius: var(--r-pill); background: var(--c-blush);
  display: flex; align-items: center; justify-content: center; margin: 0 auto var(--sp-5);
  color: var(--c-rose-deep);
}
.confirm-page__icon svg { width: 36px; height: 36px; }
.confirm-page h1 { font-style: italic; font-weight: 400; font-size: var(--fs-2xl); margin-bottom: var(--sp-3); }
.confirm-page__sub { color: var(--text-muted); margin-bottom: var(--sp-6); max-width: 520px; margin-inline: auto; }
.confirm-page__ref {
  display: inline-flex; align-items: center; gap: var(--sp-2); padding: var(--sp-3) var(--sp-5);
  background: var(--c-cream); border: 1px solid var(--border); border-radius: var(--r-pill); margin-bottom: var(--sp-7); font-size: var(--fs-sm);
}
.confirm-page__ref strong { font-family: var(--font-display); font-style: italic; font-size: var(--fs-md); color: var(--c-rose-deep); }
.confirm-actions { display: flex; gap: var(--sp-3); justify-content: center; flex-wrap: wrap; }

/* ----- Combo picker (déclinaisons radio) -------------------------------- */
.combo-pick { cursor: pointer; display: block; }
.combo-pick input { position: absolute; opacity: 0; pointer-events: none; }
.combo-pick span {
  display: block; min-height: 48px; padding: var(--sp-3) var(--sp-3);
  border: 1px solid var(--border); background: var(--c-cream);
  font-size: var(--fs-sm); font-weight: 500; text-align: center;
  transition: all var(--t-base) var(--ease); border-radius: var(--r-sm);
  line-height: 1.3; display: flex; align-items: center; justify-content: center;
}
.combo-pick:hover span { border-color: var(--c-gold); }
.combo-pick input:checked + span { background: var(--c-gold); color: var(--c-ink); border-color: var(--c-gold); }
.combo-pick input:focus-visible + span { outline: 2px solid var(--c-gold); outline-offset: 2px; }
.combo-pick input:disabled + span { opacity: .4; cursor: not-allowed; }

/* ----- 14. CONTACT ------------------------------------------------------ */
.contact-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--sp-6); max-width: 1100px; margin: 0 auto;
}
@media (min-width: 992px) { .contact-grid { grid-template-columns: 1.3fr 1fr; gap: var(--sp-8); align-items: start; } }

.contact-pane { background: #fff; padding: var(--sp-6) var(--sp-5); border: 1px solid var(--border); }
@media (min-width: 768px) { .contact-pane { padding: var(--sp-7) var(--sp-7); } }

.contact-form select, .contact-form input, .contact-form textarea {
  width: 100%; max-width: 100%; min-height: 52px; padding: var(--sp-3) var(--sp-4);
  background: #fff; border: 1px solid var(--c-line); border-radius: var(--r-sm);
  font-size: var(--fs-base); font-family: var(--font-body); color: var(--c-ink);
  transition: border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
  -webkit-appearance: none; appearance: none;
}
.contact-form input::placeholder, .contact-form textarea::placeholder { color: var(--c-muted); }
.contact-form textarea { min-height: 140px; padding: var(--sp-3) var(--sp-4); line-height: var(--lh-snug); resize: vertical; }
.contact-form select {
  padding-right: var(--sp-8); cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%230E0B10' stroke-width='1.6'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right var(--sp-4) center;
}
.contact-form select:focus, .contact-form input:focus, .contact-form textarea:focus {
  outline: none; border-color: var(--c-ink);
  box-shadow: 0 0 0 3px rgba(184, 148, 90, .16);
}
/* champs spéciaux : on garde le rendu natif (sinon appearance:none les casse) */
.contact-form input[type="file"], .contact-form input[type="checkbox"], .contact-form input[type="radio"] {
  -webkit-appearance: auto; appearance: auto;
}
.contact-form input[type="checkbox"], .contact-form input[type="radio"] {
  width: 18px; height: 18px; min-height: 0; accent-color: var(--c-ink);
}

.contact-notice {
  padding: var(--sp-3) var(--sp-4); margin-bottom: var(--sp-4); border-radius: var(--r-sm);
  font-size: var(--fs-sm);
}
.contact-notice ul { list-style: none; padding: 0; margin: 0; }
.contact-notice li { padding: 2px 0; }
.contact-notice--success { background: rgba(79,122,95,.12); color: var(--c-success); border: 1px solid rgba(79,122,95,.3); }
.contact-notice--error   { background: rgba(178,58,72,.12); color: var(--c-error); border: 1px solid rgba(178,58,72,.3); }

.contact-aside { display: flex; flex-direction: column; gap: 0; }

.faq-item {
  border-bottom: 1px solid var(--border); padding: var(--sp-3) 0;
}
.faq-item summary {
  list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-display); font-style: italic; font-size: var(--fs-md); color: var(--c-ink);
  padding: var(--sp-2) 0;
  transition: color var(--t-base) var(--ease);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: '+'; font-family: var(--font-body); font-size: var(--fs-xl); color: var(--c-gold);
  transition: transform var(--t-base) var(--ease); font-style: normal;
}
.faq-item[open] summary::after { content: '−'; }
.faq-item summary:hover { color: var(--c-rose-deep); }
.faq-item p {
  padding: var(--sp-2) 0 var(--sp-3); color: var(--text-muted); font-size: var(--fs-sm); line-height: var(--lh-snug);
}

/* État de succès du formulaire */
.contact-success {
  text-align: center;
  padding: var(--sp-7) var(--sp-5);
  animation: contact-success-in var(--t-slow) var(--ease) both;
}
@media (min-width: 768px) { .contact-success { padding: var(--sp-8) var(--sp-7); } }
.contact-success__icon {
  width: 72px; height: 72px; margin: 0 auto var(--sp-5);
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%; color: var(--c-success);
  background: rgba(79, 122, 95, .12); border: 1px solid rgba(79, 122, 95, .3);
}
.contact-success__title {
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: var(--fs-xl); color: var(--c-ink); margin-bottom: var(--sp-3);
}
.contact-success__lead {
  max-width: 46ch; margin: 0 auto var(--sp-6);
  color: var(--text-muted); font-size: var(--fs-base); line-height: var(--lh-snug);
}
.contact-success__steps {
  list-style: none; padding: 0; margin: 0 auto; max-width: 420px;
  text-align: left; display: flex; flex-direction: column; gap: var(--sp-3);
}
.contact-success__steps li {
  display: flex; gap: var(--sp-3); align-items: flex-start;
  padding: var(--sp-3) var(--sp-4); background: var(--c-cream);
  border: 1px solid var(--border); border-radius: var(--r-sm);
  font-size: var(--fs-sm); color: var(--c-ink); line-height: var(--lh-snug);
}
.contact-success__steps svg {
  width: 20px; height: 20px; flex-shrink: 0; margin-top: 1px; color: var(--c-gold);
}
@keyframes contact-success-in {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Encarts de réassurance (colonne latérale) */
.contact-card {
  margin-top: var(--sp-4); padding: var(--sp-4);
  border-radius: var(--r-sm); display: flex; gap: var(--sp-3); align-items: flex-start;
}
.contact-card:first-of-type { margin-top: var(--sp-7); }
.contact-card svg { flex-shrink: 0; margin-top: 2px; }
.contact-card__title { display: block; font-size: var(--fs-sm); font-weight: 600; }
.contact-card__text { font-size: var(--fs-xs); margin-top: 4px; line-height: var(--lh-snug); }
.contact-card--blush { background: var(--c-blush); color: var(--c-rose-deep); }
.contact-card--blush svg { color: var(--c-rose-deep); }
.contact-card--blush .contact-card__text { opacity: .85; }
.contact-card--ink { background: var(--c-ink); color: var(--c-cream); }
.contact-card--ink svg { color: var(--c-gold); }
.contact-card--ink .contact-card__text { color: rgba(250, 246, 240, .7); }

/* ----- Bootstrap tabs (checkout step identity utilise data-toggle="tab") - */
.nav-inline {
  display: flex; gap: var(--sp-4); list-style: none; padding: 0; margin: 0 0 var(--sp-5);
  border-bottom: 1px solid var(--border);
}
.nav-inline .nav-item { padding: 0; }
.nav-inline .nav-separator { color: var(--border); align-self: center; }
.nav-inline .nav-link {
  display: inline-block; padding: var(--sp-3) 0; cursor: pointer;
  font-size: var(--fs-sm); font-weight: 500; letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--text-muted); text-decoration: none;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: all var(--t-base) var(--ease);
}
.nav-inline .nav-link:hover { color: var(--c-ink); }
.nav-inline .nav-link.active { color: var(--c-ink); border-bottom-color: var(--c-gold); }

.tab-content .tab-pane { display: none; }
.tab-content .tab-pane.active { display: block; }

/* ============================================================
   CHECKOUT NATIF PS — design Lola Intima
   ============================================================ */

.checkout-process { display: flex; flex-direction: column; gap: var(--sp-3); }

.checkout-step {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: var(--sp-5) var(--sp-5);
  transition: border-color var(--t-base) var(--ease);
}
@media (min-width: 768px) { .checkout-step { padding: var(--sp-6) var(--sp-7); } }
.checkout-step.-current { border-color: var(--c-ink); box-shadow: var(--shadow-2); }
.checkout-step.-unreachable { opacity: .5; }
.checkout-step.-unreachable .step-title { color: var(--text-muted); }
.checkout-step.-clickable .step-title { cursor: pointer; }

/* Step title */
.step-title, .checkout-step .step-title.h3 {
  display: flex; align-items: center; gap: var(--sp-3);
  flex-wrap: wrap; min-width: 0;
  font-family: var(--font-display) !important;
  font-style: italic !important;
  font-weight: 500 !important;
  font-size: var(--fs-lg) !important;
  margin: 0;
  color: var(--c-ink);
}
/* Anti-débordement global du tunnel sur petits écrans */
.checkout-process, .checkout-steps, .checkout-step { min-width: 0; max-width: 100%; }
.checkout-step { overflow-wrap: break-word; }
.step-number {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: var(--r-pill);
  background: var(--c-cream); color: var(--c-ink); border: 1px solid var(--c-ink);
  font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 600; font-style: normal;
  flex-shrink: 0;
}
.checkout-step.-current .step-number { background: var(--c-gold); color: var(--c-ink); border-color: var(--c-gold); }
.checkout-step.-complete .step-number { background: var(--c-ink); color: var(--c-cream); border-color: var(--c-ink); }

/* Icône "done" native PS — masquée (.step-number colorée signale déjà l'état) */
.step-title .material-icons.done { display: none !important; }

/* Step edit (link "Modifier") */
.step-edit, .step-edit.text-muted {
  margin-left: auto;
  font-family: var(--font-body); font-style: normal; font-weight: 400;
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase;
  color: var(--text-muted) !important; cursor: pointer;
  display: inline-flex; align-items: center; gap: 4px;
  text-decoration: none;
}
.step-edit:hover { color: var(--c-ink) !important; }
.step-edit .material-icons { font-size: 16px; }

/* Step content padding */
.checkout-step .content { margin-top: var(--sp-4); }
.checkout-step.-unreachable .content,
.checkout-step.-complete:not(.-current) .content { display: none; }

/* Identity paragraph (étape 1 connecté) */
.checkout-step .identity {
  font-size: var(--fs-base); margin: 0 0 var(--sp-2);
}
.checkout-step .identity a { color: var(--c-ink); text-decoration: underline; }

/* Address cards (étape 2) */
.address-selector { display: grid; grid-template-columns: 1fr; gap: var(--sp-3); margin-top: var(--sp-2); }
@media (min-width: 768px) { .address-selector { grid-template-columns: repeat(2, 1fr); } }

.address-item {
  border: 1px solid var(--border) !important;
  border-radius: var(--r-sm); padding: var(--sp-5);
  background: var(--c-cream);
  transition: border-color var(--t-base) var(--ease);
}
.address-item.selected { border-color: var(--c-ink) !important; background: #fff; }
.address-item header { margin-bottom: var(--sp-3); }
.address-item .radio-block {
  display: grid; grid-template-columns: auto 1fr;
  column-gap: var(--sp-3); row-gap: var(--sp-2);
  align-items: center; cursor: pointer;
}
.address-item .radio-block .custom-radio { grid-column: 1; grid-row: 1 / 3; align-self: center; }
.address-item .address-alias {
  grid-column: 2; grid-row: 1; display: block;
  font-family: var(--font-display) !important; font-style: italic !important; font-weight: 500 !important;
  font-size: var(--fs-md) !important; color: var(--c-ink); margin: 0; white-space: nowrap;
}
.address-item .address {
  grid-column: 2; grid-row: 2;
  font-family: var(--font-body); font-size: var(--fs-sm); color: var(--text-muted); line-height: 1.55;
  /* annule l'encadré de la règle globale .address (page « Adresses ») */
  background: none !important; border: 0 !important; padding: 0 !important; margin: 0 !important;
}
.address-item hr { display: none; }
.address-item .address-footer {
  display: flex; gap: var(--sp-4); padding-top: var(--sp-4);
  border-top: 1px solid var(--border); margin-top: var(--sp-4);
}
.address-item .edit-address, .address-item .delete-address {
  font-size: var(--fs-xs); color: var(--text-muted) !important;
  text-decoration: none; display: inline-flex; align-items: center; gap: 4px;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
}
.address-item .edit-address:hover { color: var(--c-ink) !important; }
.address-item .delete-address:hover { color: var(--c-error) !important; }
/* Pas de ::before sur material-icons — les <i> vides sont cachés globalement.
   Les liens "Modifier"/"Supprimer" affichent juste le texte, ce qui est très bien. */

/* "Ajouter une nouvelle adresse" link */
.add-address {
  margin-top: var(--sp-4); padding: var(--sp-3) 0;
}
.add-address a {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-size: var(--fs-sm); color: var(--c-ink); font-weight: 500;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  border: 1px dashed var(--border); padding: var(--sp-3) var(--sp-4); border-radius: var(--r-sm);
}
.add-address a:hover { border-color: var(--c-ink); }

/* "L'adresse de facturation est différente..." */
[data-link-action="different-invoice-address"] {
  display: inline-block; margin-top: var(--sp-3);
  font-size: var(--fs-sm); color: var(--text-muted); text-decoration: underline;
}

/* Custom radio PS */
.custom-radio {
  display: inline-block; width: 18px; height: 18px; flex-shrink: 0;
  border: 1px solid var(--text-muted); border-radius: var(--r-pill);
  position: relative; margin-top: 2px;
}
.custom-radio input { position: absolute; inset: 0; width: 100%; height: 100%; margin: 0; opacity: 0; cursor: pointer; }
.custom-radio > span {
  display: block; position: absolute; inset: 3px; border-radius: var(--r-pill);
  background: transparent; transition: background var(--t-base) var(--ease);
}
.custom-radio input:checked ~ span,
.address-item.selected .custom-radio > span { background: var(--c-ink); }
.address-item.selected .custom-radio { border-color: var(--c-ink); }

/* ===== DELIVERY OPTIONS (étape 3) — refonte propre, ignore Bootstrap row/col ===== */
.delivery-options-list { display: flex; flex-direction: column; gap: var(--sp-3); margin-top: var(--sp-2); }
.delivery-options { display: flex; flex-direction: column; gap: var(--sp-3); }

/* Chaque option = card cliquable */
.delivery-option, .delivery-option.row {
  display: grid !important;
  grid-template-columns: 28px 1fr !important;
  gap: var(--sp-4);
  align-items: center;
  margin: 0 !important;
  padding: var(--sp-4) var(--sp-5) !important;
  background: var(--c-cream);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  transition: border-color var(--t-base) var(--ease), background var(--t-base) var(--ease);
  position: relative;
}
.delivery-option:hover { border-color: var(--c-ink); }
.delivery-option:has(input:checked) { border-color: var(--c-ink); background: #fff; box-shadow: var(--shadow-1); }

/* Reset toutes les colonnes Bootstrap dans la delivery-option */
.delivery-option .col-sm-1,
.delivery-option .col-sm-3,
.delivery-option .col-sm-4,
.delivery-option .col-sm-5,
.delivery-option .col-sm-11,
.delivery-option .col-xs-9,
.delivery-option .col-xs-12,
.delivery-option .col-md-4,
.delivery-option .col-md-8 {
  padding: 0 !important;
  flex: none !important;
  width: auto !important;
  max-width: 100% !important;
}

/* Le label conteneur (le 2e enfant du grid) */
[class*="delivery-option-"] {
  display: block !important;
  cursor: pointer;
  padding: 0 !important;
  margin: 0 !important;
}
[class*="delivery-option-"] > .row {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 4px !important;
  margin: 0 !important;
  align-items: center;
}
@media (min-width: 768px) {
  [class*="delivery-option-"] > .row {
    grid-template-columns: 1.5fr 1fr auto !important;
    gap: var(--sp-5) !important;
    align-items: center;
  }
}

/* Carrier (nom + logo éventuel) */
.delivery-option .carrier, .delivery-option .carrier.row {
  display: flex !important;
  align-items: center;
  gap: var(--sp-3);
  margin: 0 !important;
  flex-wrap: nowrap;
}
.delivery-option .carrier-logo {
  flex: 0 0 40px !important;
  width: 40px !important;
  padding: 0 !important;
}
.delivery-option .carrier-logo img {
  width: 40px; height: 40px; object-fit: contain;
}
.delivery-option .carriere-name-container,
.delivery-option .carriere-name-container.col-md-8 {
  padding: 0 !important;
  flex: 1 1 auto !important;
  width: auto !important;
}
.carrier-name, .h6.carrier-name {
  font-family: var(--font-body) !important;
  font-style: normal !important;
  font-weight: 600 !important;
  font-size: var(--fs-base) !important;
  letter-spacing: var(--tracking-wide);
  color: var(--c-ink) !important;
  margin: 0 !important;
  display: block;
}
.carrier-delay {
  color: var(--text-muted);
  font-size: var(--fs-sm);
  font-family: var(--font-body);
  font-style: normal;
}
.carrier-price {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--c-ink);
  font-size: var(--fs-md);
  display: block;
  white-space: nowrap;
}
@media (min-width: 768px) { .carrier-price { text-align: right; } }

/* Custom radio dans delivery-option (1ère colonne du grid) */
.delivery-option > .col-sm-1 { margin: 0; padding: 0 !important; display: flex; justify-content: center; }
.delivery-option .custom-radio.float-xs-left { float: none !important; margin: 0; }

/* Cacher les divs vides "carrier-extra-content" qui prennent de la place */
.carrier-extra-content:empty,
.row.carrier-extra-content:empty { display: none !important; }
.carrier-extra-content { padding: 0; margin: 0; }

/* Responsive : empêcher le débordement horizontal des options de livraison.
   Les pistes grid/flex ont min-width:auto par défaut → le contenu ne peut pas
   rétrécir et déborde sur mobile. On force min-width:0 + retour à la ligne. */
.delivery-option { max-width: 100%; }
.delivery-option [class*="delivery-option-"],
.delivery-option [class*="delivery-option-"] > .row,
.delivery-option [class*="delivery-option-"] > .row > *,
.delivery-option .carrier,
.delivery-option .carriere-name-container { min-width: 0 !important; }
.carrier-name, .h6.carrier-name { overflow-wrap: anywhere; }

/* Order options (textarea message) */
.order-options { margin-top: var(--sp-5); padding-top: var(--sp-5); border-top: 1px solid var(--border); }
#delivery label {
  display: block; font-size: var(--fs-xs); font-weight: 500;
  letter-spacing: var(--tracking-wider); text-transform: uppercase; margin-bottom: var(--sp-2);
}
#delivery textarea {
  width: 100%; min-height: 90px; padding: var(--sp-3) var(--sp-4);
  background: var(--c-cream); border: 1px solid var(--border); border-radius: var(--r-sm);
  font-family: var(--font-body); font-size: var(--fs-sm); line-height: 1.5; resize: vertical;
}
#delivery textarea:focus { outline: none; border-color: var(--c-ink); background: #fff; }

/* Bouton "Continuer" */
.btn.continue, .btn.continue.btn-primary {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 52px; padding: 0 var(--sp-7);
  font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 500;
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
  background: var(--c-ink); color: var(--c-cream); border: 0; border-radius: var(--r-sm);
  cursor: pointer; transition: background var(--t-base) var(--ease);
  margin-top: var(--sp-5); float: none !important;
}
.btn.continue:hover { background: var(--c-rose-deep); color: var(--c-cream); }

/* Form footer général */
.clearfix { clear: both; }
.clearfix::after { content: ''; display: table; clear: both; }

/* Float bootstrap reset */
.float-xs-right { float: none !important; }
.float-xs-left { float: none !important; }

/* Hide bootstrap row decoration on checkout */
.checkout-step .row { display: flex; flex-wrap: wrap; gap: var(--sp-3); margin: 0; }
.checkout-step .col-sm-1, .checkout-step .col-sm-3, .checkout-step .col-sm-4,
.checkout-step .col-sm-5, .checkout-step .col-sm-11,
.checkout-step .col-xs-9, .checkout-step .col-xs-12,
.checkout-step .col-md-4, .checkout-step .col-md-8 { padding: 0; }

/* Error message (adresse incomplète) */
.alert-danger {
  background: rgba(178,58,72,.08); color: var(--c-error);
  padding: var(--sp-3) var(--sp-4); border-radius: var(--r-sm);
  border: 1px solid rgba(178,58,72,.25); font-size: var(--fs-sm); margin: var(--sp-3) 0;
}

/* Conditions to approve (CGV checkbox dans le checkout — étape paiement) */
#conditions-to-approve { margin: var(--sp-5) 0; padding: var(--sp-4); background: var(--c-cream); border-radius: var(--r-sm); border: 1px solid var(--border); }
#conditions-to-approve ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--sp-3); }
#conditions-to-approve li {
  display: flex; align-items: flex-start; gap: var(--sp-3);
  font-size: var(--fs-sm); line-height: 1.5;
}
#conditions-to-approve li .float-xs-left { float: none !important; flex-shrink: 0; }
#conditions-to-approve .condition-label label { cursor: pointer; color: var(--text); }
#conditions-to-approve .condition-label a { color: var(--c-ink); text-decoration: underline; }
#conditions-to-approve .condition-label a:hover { color: var(--c-rose-deep); }

/* Custom checkbox PS (utilisé partout : CGV, options, etc.) */
.custom-checkbox {
  display: inline-flex; align-items: center; cursor: pointer;
  position: relative; width: 20px; height: 20px;
}
.custom-checkbox input[type="checkbox"] {
  position: absolute; opacity: 0; width: 100%; height: 100%; margin: 0; cursor: pointer;
}
.custom-checkbox > span {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px;
  background: #fff; border: 1px solid var(--text-muted); border-radius: 3px;
  transition: all var(--t-base) var(--ease);
}
.custom-checkbox input[type="checkbox"]:checked + span,
.custom-checkbox input[type="checkbox"]:checked ~ span {
  background: var(--c-ink); border-color: var(--c-ink);
}
.custom-checkbox .checkbox-checked, .custom-checkbox > span > i {
  font-size: 14px; color: transparent;
  transition: color var(--t-base) var(--ease);
}
.custom-checkbox input[type="checkbox"]:checked + span .checkbox-checked,
.custom-checkbox input[type="checkbox"]:checked ~ span .checkbox-checked,
.custom-checkbox input[type="checkbox"]:checked + span > i,
.custom-checkbox input[type="checkbox"]:checked ~ span > i { color: #fff; }
.custom-checkbox .checkbox-checked::before, .custom-checkbox > span > i::before {
  content: '\2713'; font-family: inherit; font-weight: 700;
}

/* ----- 99. PRESTASHOP RESETS + FALLBACK CONTAINERS ---------------------- */
.product-cover img { width: 100%; }
.notifications-container { z-index: var(--z-modal); padding: var(--sp-3) var(--gutter); max-width: var(--container); margin: 0 auto; }

/* Notifications / alertes (panier, connexion, erreurs PS). Sans ce style,
   PrestaShop affiche des listes brutes non habillées. */
.notification {
  padding: var(--sp-3) var(--sp-4); margin-bottom: var(--sp-3);
  border: 1px solid transparent; border-radius: var(--r-sm); font-size: var(--fs-sm);
}
.notification ul { list-style: none; margin: 0; padding: 0; }
.notification li { padding: 2px 0; }
.notification li + li { border-top: 1px solid rgba(14, 11, 16, .06); }
.notification-success { background: rgba(79, 122, 95, .12); color: var(--c-success); border-color: rgba(79, 122, 95, .3); }
.notification-danger,
.notification-error   { background: rgba(178, 58, 72, .12); color: var(--c-error); border-color: rgba(178, 58, 72, .3); }
.notification-warning { background: rgba(184, 148, 90, .14); color: #8a6a2f; border-color: rgba(184, 148, 90, .4); }
.notification-info    { background: rgba(14, 11, 16, .05); color: var(--c-ink); border-color: var(--border); }

/* Décalage des ancres internes (#story, #produits…) sous le header sticky. */
[id] { scroll-margin-top: calc(var(--header-h) + var(--sp-3)); }
@media (min-width: 992px) { [id] { scroll-margin-top: calc(var(--header-h-desktop) + var(--sp-3)); } }

/* Fallback container universel pour les pages internes (account, checkout, cms…).
   Wrappe automatiquement les enfants directs de <main> qui ne sont pas déjà
   en .container ou en <section> avec leur propre container interne. */
body:not(#index):not(.page-product):not(.page-category) main {
  padding: var(--sp-6) 0 var(--sp-9);
}
body:not(#index):not(.page-product):not(.page-category) main > div:not(.container),
body:not(#index):not(.page-product):not(.page-category) main > section:not(.section):not(.cart-page):not(.checkout-page):not(.auth-page):not(.account-page):not(.contact-page):not(.confirm-page) {
  max-width: var(--container);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

/* Étapes natives PS checkout (classes générées par checkout-process module) */
.checkout-process { display: flex; flex-direction: column; gap: var(--sp-3); }
.checkout-step {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: var(--sp-5);
}
.checkout-step .step-title {
  font-family: var(--font-display) !important;
  font-style: italic !important;
  font-weight: 500 !important;
  font-size: var(--fs-lg) !important;
  margin: 0;
  display: flex; align-items: center; gap: var(--sp-3);
}
.checkout-step .step-edit {
  font-size: var(--fs-xs); color: var(--text-muted);
  text-decoration: underline; cursor: pointer;
  margin-left: auto;
}
.checkout-step.-unreachable .step-title,
.checkout-step.-unreachable .step-number { color: var(--text-muted); opacity: .55; }
.checkout-step .step-number {
  background: var(--c-cream); color: var(--c-ink); border: 1px solid var(--c-ink);
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: var(--r-pill);
  font-family: var(--font-body); font-size: var(--fs-sm); font-weight: 600; font-style: normal;
  flex-shrink: 0;
}
.checkout-step.-current .step-number { background: var(--c-gold); color: var(--c-ink); border-color: var(--c-gold); }
.checkout-step.-complete .step-number { background: var(--c-ink); color: var(--c-cream); border-color: var(--c-ink); }
.checkout-step.-current { border-color: var(--c-ink); }
.checkout-step .content { margin-top: var(--sp-4); }
.checkout-step .step-done-content { color: var(--text-muted); font-size: var(--fs-sm); margin-top: var(--sp-2); }

/* Formulaires natifs du checkout (invité / connexion) — normalisation des marges */
.checkout-step .auth-form .form-field { margin-bottom: var(--sp-4); }
.checkout-step .nav-inline {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-2);
  list-style: none; padding: 0; margin: 0 0 var(--sp-5);
}
.checkout-step .nav-inline .nav-item { margin: 0; }
.checkout-step .nav-inline .nav-link {
  font-size: var(--fs-sm); letter-spacing: var(--tracking-wide); text-transform: uppercase;
  color: var(--text-muted); padding: 0 0 3px; border-bottom: 1px solid transparent;
}
.checkout-step .nav-inline .nav-link.active { color: var(--c-ink); border-bottom-color: var(--c-gold); }
.checkout-step .nav-separator { color: var(--border); }
.checkout-step .form-informations {
  margin: var(--sp-5) 0 var(--sp-4); padding: var(--sp-3) var(--sp-4);
  background: var(--c-cream); border: 1px solid var(--border); border-radius: var(--r-sm);
  font-size: var(--fs-sm); line-height: var(--lh-snug);
}
.checkout-step .form-informations-subtitle { color: var(--text-muted); }
.checkout-step .field-password-policy { margin: 0 0 var(--sp-4); }
.checkout-step .form-field--check em { display: block; margin-top: 2px; font-size: var(--fs-xs); color: var(--text-muted); font-style: italic; }
/* Bouton « Continuer » : on neutralise le float Bootstrap et on l'aligne proprement */
.checkout-step .continue,
.checkout-step .float-xs-right { float: none !important; }
.checkout-step .auth-form .continue { width: 100%; margin-top: var(--sp-5); }

/* Delivery & payment options natifs */
.delivery-options-list, .payment-options { display: flex; flex-direction: column; gap: var(--sp-2); margin-top: var(--sp-3); }
.payment-option {
  border: 1px solid var(--border) !important;
  padding: var(--sp-4) !important;
  border-radius: var(--r-sm);
  background: var(--c-cream);
  transition: border-color var(--t-base) var(--ease);
  display: flex; gap: var(--sp-3); align-items: flex-start;
}
.payment-option:hover { border-color: var(--c-ink) !important; }
.payment-option label { display: flex; gap: var(--sp-3); cursor: pointer; flex: 1; }

/* Mini-cart-summary natif */
.cart-summary, .cart-detailed-totals { background: #fff; padding: var(--sp-5); border: 1px solid var(--border); }
.cart-summary-line { display: flex; justify-content: space-between; padding: var(--sp-2) 0; font-size: var(--fs-sm); }
.cart-summary-line.cart-total { font-weight: 600; font-size: var(--fs-md); border-top: 1px solid var(--border); padding-top: var(--sp-4); margin-top: var(--sp-3); }
.cart-summary-products img { max-width: 60px; aspect-ratio: 3/4; object-fit: cover; }

/* My account natif PS — grille tuiles */
.account-link, .links {
  display: grid; grid-template-columns: repeat(1, 1fr); gap: var(--sp-3);
  margin-top: var(--sp-5);
}
@media (min-width: 640px) { .account-link, .links { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .account-link, .links { grid-template-columns: repeat(3, 1fr); } }
.links a, .my-account-link, .link-item {
  display: flex; flex-direction: column; gap: var(--sp-2);
  padding: var(--sp-5); border: 1px solid var(--border); background: #fff;
  font-family: var(--font-body); color: var(--c-ink);
  transition: all var(--t-base) var(--ease); text-align: center;
}
.links a:hover, .my-account-link:hover, .link-item:hover {
  border-color: var(--c-ink); transform: translateY(-2px); box-shadow: var(--shadow-2);
}

/* Native Bootstrap form-group fallback (form_field plugin output) */
.form-group, .js-input-column { margin-bottom: var(--sp-4); }
.form-control, .form-control-select {
  width: 100%; min-height: 52px; padding: 0 var(--sp-4);
  background: var(--c-cream); border: 1px solid var(--border); border-radius: var(--r-sm);
  font-size: var(--fs-base); font-family: var(--font-body);
}
.form-control:focus, .form-control-select:focus { outline: none; border-color: var(--c-ink); background: #fff; }
.form-control-label {
  display: block; font-size: var(--fs-xs); font-weight: 500;
  letter-spacing: var(--tracking-wider); text-transform: uppercase;
  margin-bottom: var(--sp-2);
}
.form-control-label.required::after { content: ' *'; color: var(--c-rose-deep); }
.form-control-comment { font-size: var(--fs-xs); color: var(--text-muted); margin-top: 6px; }
.has-error .form-control { border-color: var(--c-error); }
.help-block { font-size: var(--fs-xs); color: var(--c-error); margin-top: 6px; }

/* Custom checkbox/radio native */
.custom-checkbox, .custom-radio {
  display: inline-flex; align-items: flex-start; gap: var(--sp-2);
  font-size: var(--fs-sm); cursor: pointer; line-height: 1.4;
}
.custom-checkbox input, .custom-radio input { margin-top: 3px; accent-color: var(--c-ink); }

/* Page bottom buttons natif (footer.form-footer, .pull-xs-right, etc.) */
.form-footer { margin-top: var(--sp-5); padding-top: var(--sp-4); border-top: 1px solid var(--border); }
.form-footer .btn-primary { min-height: 52px; }

/* Lookbook / matières (home) */
.lookbook-section { background: var(--c-cream); }
.lookbook { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-3); }
@media (min-width: 768px) { .lookbook { grid-template-columns: repeat(4, 1fr); gap: var(--sp-4); margin-bottom: var(--sp-6); } }
.lookbook__item {
  position: relative; display: block; aspect-ratio: 3/4; overflow: hidden;
  border-radius: var(--r-sm); background: var(--c-blush);
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
}
.lookbook__item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform var(--t-slow) var(--ease); }
.lookbook__item::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(14,11,16,.45) 0%, transparent 45%);
  transition: opacity var(--t-base) var(--ease);
}
.lookbook__item:hover { box-shadow: var(--shadow-2); transform: translateY(-4px); }
.lookbook__item:hover img { transform: scale(1.06); }
.lookbook__label {
  position: absolute; left: var(--sp-4); bottom: var(--sp-3); z-index: 1;
  color: var(--c-cream); font-family: var(--font-display); font-style: italic; font-size: var(--fs-lg);
}
.lookbook__label::before {
  content: ''; display: block; width: 22px; height: 2px; background: var(--c-gold);
  margin-bottom: var(--sp-2); transition: width var(--t-base) var(--ease);
}
.lookbook__item:hover .lookbook__label::before { width: 44px; }
@media (min-width: 768px) {
  .lookbook__item:nth-child(even) { transform: translateY(var(--sp-6)); }
  .lookbook__item:nth-child(even):hover { transform: translateY(calc(var(--sp-6) - 4px)); }
}

/* ----- 100. TABLEAUX & PAGES NATIVES PS (commandes, adresses, retours) --- */
/* Ces pages ne sont pas surchargées par le thème : on garantit qu'elles
   restent lisibles et sans débordement horizontal sur mobile. */
.table-responsive { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
table, .table {
  width: 100%; max-width: 100%; border-collapse: collapse;
  font-size: var(--fs-sm); margin-bottom: var(--sp-4);
}
.table th, .table td { padding: var(--sp-3); text-align: left; border-bottom: 1px solid var(--border); vertical-align: top; }
.table thead th {
  font-family: var(--font-body); font-size: var(--fs-xs); font-weight: 600;
  letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--c-ink);
  white-space: nowrap;
}
.table img { max-width: 56px; height: auto; }

/* Blocs natifs (order detail, address card) — habillage léger + empilage mobile */
.page-order-detail .box,
.address, .order-confirmation-table, .order-detail-content,
#addresses .address, .addresses-footer {
  background: #fff; border: 1px solid var(--border); border-radius: var(--r-sm);
  padding: var(--sp-5); margin-bottom: var(--sp-4);
}
#addresses ul, .address-list { display: grid; grid-template-columns: 1fr; gap: var(--sp-4); }
@media (min-width: 768px) { #addresses ul, .address-list { grid-template-columns: repeat(2, 1fr); } }

/* ----- 101. AJUSTEMENTS PETITS ÉCRANS (≤ 480px) ------------------------- */
@media (max-width: 480px) {
  /* CTA empilés en pleine largeur pour éviter tout débordement / clipping. */
  .hero__cta-row .btn,
  .cart-empty .btn,
  .confirm-actions .btn { width: 100%; white-space: normal; }
  .hero__cta-row { flex-direction: column; align-items: stretch; }

  /* Récap & total restent confortables même quand les libellés sont longs. */
  .cart-summary__row, .cart-summary-line { gap: var(--sp-3); }

  /* Pickers déclinaisons : 4 tailles par ligne suffisent sur très petit écran. */
  .size-grid { grid-template-columns: repeat(4, 1fr); }
}

/* ----- 102. UTILITAIRES NATIFS PS (visibilité responsive Bootstrap) ------ */
/* Le thème n'embarque pas Bootstrap : on réimplémente les classes de
   visibilité utilisées par les templates natifs (mot de passe, compte,
   adresses, commande…) pour qu'ils s'affichent correctement sur mobile.
   Breakpoints Bootstrap 4 : sm 576 · md 768 · lg 992 · xl 1200. */
.hidden-xs-up                 { display: none !important; }
@media (max-width: 575px)  { .hidden-xs-down { display: none !important; } }
@media (min-width: 576px)  { .hidden-sm-up   { display: none !important; } }
@media (max-width: 767px)  { .hidden-sm-down { display: none !important; } }
@media (min-width: 768px)  { .hidden-md-up   { display: none !important; } }
@media (max-width: 991px)  { .hidden-md-down { display: none !important; } }
@media (min-width: 992px)  { .hidden-lg-up   { display: none !important; } }
@media (max-width: 1199px) { .hidden-lg-down { display: none !important; } }
@media (min-width: 1200px) { .hidden-xl-up   { display: none !important; } }

/* Boutons submit natifs : jamais de débordement, libellé qui peut passer
   à la ligne plutôt que de pousser la page. */
.form-control-submit { max-width: 100%; white-space: normal; }

/* Champ fichier natif (bootstrap-filestyle) : l'input réel est en
   position:absolute + clip mais garde une largeur => +45px de scroll.
   On le neutralise (pattern sr-only) et on cadre le widget visible. */
input.filestyle {
  position: absolute !important; width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: 0 !important; overflow: hidden !important;
  clip: rect(0 0 0 0) !important; left: 0 !important; top: 0 !important;
}
.bootstrap-filestyle.input-group { display: flex; flex-wrap: wrap; gap: var(--sp-2); max-width: 100%; }
.bootstrap-filestyle .form-control { flex: 1 1 160px; min-width: 0; }
.bootstrap-filestyle .group-span-filestyle { display: inline-flex; }
.bootstrap-filestyle .btn-default {
  min-height: 48px; padding: 0 var(--sp-4); display: inline-flex; align-items: center; gap: var(--sp-2);
  border: 1px solid var(--c-ink); background: transparent; color: var(--c-ink);
  font-size: var(--fs-sm); letter-spacing: var(--tracking-wide); text-transform: uppercase;
  border-radius: var(--r-sm); white-space: nowrap; cursor: pointer;
}
.bootstrap-filestyle .btn-default:hover { background: var(--c-ink); color: var(--c-cream); }
.bootstrap-filestyle .glyphicon { width: auto; }
