/* ==========================================================================
   BELICAM — Système de design centralisé
   Toutes les valeurs visuelles sont des tokens (--color-*, --font-*, --space-*).
   Aucun composant ne doit redéclarer un hex, un px ou un font-family.
   ========================================================================== */

:root {
  /* ----- COULEURS ----- */
  --color-bg-primary:   #F2EAD9;                    /* crème sable */
  --color-bg-secondary: #E8DCC4;                    /* crème ombré */
  --color-bg-deep:      #2A2118;                    /* fond nuit */
  --color-accent-warm:  #C9A86A;                    /* ocre herbe brûlée */
  --color-accent-cool:  #7C9AA6;                    /* bleu Méditerranée désaturé */
  --color-accent-green: #7D8466;                    /* vert sauge olivier */
  --color-text-primary: #3A2E22;                    /* brun écorce */
  --color-text-muted:   #8A7A6A;
  --color-text-onDark:  #F2EAD9;
  --color-border-subtle: rgba(58, 46, 34, 0.12);
  --color-border-onDark: rgba(242, 234, 217, 0.16);

  /* ----- TYPOGRAPHIES ----- */
  --font-display: "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --font-body:    "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;

  --font-size-hero:    clamp(3rem, 8.4vw, 8.25rem);  /* 48px → 132px */
  --font-size-display: clamp(2.25rem, 5vw, 5rem);    /* 36px → 80px */
  --font-size-h1:      clamp(2rem, 4vw, 3.5rem);
  --font-size-h2:      clamp(1.5rem, 2.6vw, 2.5rem);
  --font-size-h3:      1.375rem;                     /* 22px */
  --font-size-body:    1rem;                         /* 16px */
  --font-size-small:   0.8125rem;                    /* 13px */
  --font-size-eyebrow: 0.6875rem;                    /* 11px */
  --font-size-caps:    0.75rem;                      /* 12px */

  --font-weight-light:   300;
  --font-weight-regular: 400;
  --font-weight-medium:  500;

  --line-height-tight:   1.05;
  --line-height-snug:    1.2;
  --line-height-normal:  1.45;
  --line-height-relaxed: 1.6;

  --letter-spacing-display: -0.01em;
  --letter-spacing-caps:    0.24em;
  --letter-spacing-eyebrow: 0.28em;

  /* ----- ESPACEMENT ----- */
  --space-xs:      0.5rem;     /*  8px */
  --space-sm:      1rem;       /* 16px */
  --space-md:      2rem;       /* 32px */
  --space-lg:      4rem;       /* 64px */
  --space-xl:      8rem;       /* 128px */
  --space-section: 6rem;       /* séparation entre sections — mobile */
  --space-section-d: 10rem;    /* séparation entre sections — desktop */

  --container-max: 90rem;      /* 1440px */
  --gutter-mobile: 1.25rem;    /* 20px */
  --gutter-tablet: 1.75rem;    /* 28px */
  --gutter-desktop: 2.5rem;    /* 40px */

  /* ----- RAYONS & EFFETS ----- */
  --radius-card:   4px;
  --radius-button: 999px;
  --shadow-card:   0 10px 40px rgba(58, 46, 34, 0.18);
  --shadow-drawer: -10px 0 60px rgba(0, 0, 0, 0.18);
  --transition-default: 200ms ease;
  --transition-slow:    450ms cubic-bezier(.2,.7,.2,1);

  /* ----- IMAGES (chemins + cadrage) ----- */
  /* Modifier ces variables remplace l'image partout où elle est utilisée. */
  --img-hero-primary:        url("assets/hero.jpg");
  --img-hero-object-position: center 38%;
  --img-hero-scale:           1.0;   /* 1.0 = pas de zoom (image pleine, homogène) */
  --img-hero-aspect:          16 / 9;            /* indicatif */

  --img-jour:                 url("assets/look-2.jpg");
  --img-jour-object-position: center 40%;
  --img-nuit:                 url("assets/look-6.jpg");
  --img-nuit-object-position: center 30%;

  --img-ambiance:                 url("assets/look-1.jpg");
  --img-ambiance-object-position: center 50%;

  --img-product-card-position: center 35%;

  /* product page — modifier ces variables clone le template sur un autre produit */
  --img-product-main:        url("assets/product/nuit-blanc-main.jpg");
  --img-product-main-position: center 30%;
  --img-product-thumb-1:     url("assets/product/nuit-blanc-1.jpg");
  --img-product-thumb-2:     url("assets/product/nuit-blanc-2.jpg");
  --img-product-thumb-3:     url("assets/product/nuit-blanc-3.jpg");
  --img-product-thumb-4:     url("assets/product/nuit-blanc-4.jpg");
  --img-product-ambiance:    url("assets/product/nuit-ambiance.jpg");
  --img-product-ambiance-position: center 30%;
  --img-product-story:       url("assets/product/nuit-blanc-1.jpg");
  --img-product-story-position: center 40%;
}

/* ==========================================================================
   RESET / BASE
   ========================================================================== */

*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--color-bg-primary);
  color: var(--color-text-primary);
  font-family: var(--font-body);
  font-size: var(--font-size-body);
  line-height: var(--line-height-normal);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button {
  font-family: inherit; color: inherit; background: none;
  border: 0; cursor: pointer; padding: 0;
}
::selection { background: var(--color-accent-warm); color: var(--color-text-primary); }

.serif { font-family: var(--font-display); font-weight: var(--font-weight-regular); letter-spacing: .005em; }
.italic { font-style: italic; }

.no-scrollbar::-webkit-scrollbar { display: none; }
.no-scrollbar { scrollbar-width: none; }

/* ==========================================================================
   UTILITAIRES (rythme typographique réutilisable)
   ========================================================================== */

.eyebrow {
  font-size: var(--font-size-eyebrow);
  letter-spacing: var(--letter-spacing-eyebrow);
  text-transform: uppercase;
  font-weight: var(--font-weight-medium);
  opacity: .7;
  display: inline-block;
}
.caps {
  font-size: var(--font-size-caps);
  letter-spacing: var(--letter-spacing-caps);
  text-transform: uppercase;
  font-weight: var(--font-weight-medium);
}
.rule {
  height: 1px;
  background: var(--color-text-primary);
  opacity: .18;
  border: 0;
}

.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding-inline: var(--gutter-mobile);
}

/* Boutons CTA — pilule ghost / pilule solide */
.cta {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 15px 28px;
  font-size: var(--font-size-caps);
  letter-spacing: var(--letter-spacing-caps);
  text-transform: uppercase;
  font-weight: var(--font-weight-medium);
  border: 1px solid var(--color-text-primary);
  border-radius: 0;
  background: transparent;
  color: var(--color-text-primary);
  transition: background var(--transition-default), color var(--transition-default);
  cursor: pointer;
}
.cta__arrow { transition: transform var(--transition-default); }
.cta:hover { background: var(--color-text-primary); color: var(--color-text-onDark); }
.cta:hover .cta__arrow { transform: translateX(4px); }

.cta--onDark { border-color: var(--color-text-onDark); color: var(--color-text-onDark); }
.cta--onDark:hover { background: var(--color-text-onDark); color: var(--color-text-primary); }

.cta--solid {
  background: var(--color-text-primary);
  color: var(--color-text-onDark);
}
.cta--solid:hover {
  background: transparent;
  color: var(--color-text-primary);
}

/* ==========================================================================
   SECTION : HEADER  (commun à toutes les pages)
   ========================================================================== */

.section-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(242, 234, 217, 0);
  transition: background .35s, backdrop-filter .35s, border-color .35s;
  border-bottom: 1px solid transparent;
}
.section-header[data-scrolled="true"] {
  background: rgba(242, 234, 217, 0.92);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  border-bottom-color: var(--color-border-subtle);
}
.header-inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 1rem var(--gutter-mobile);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 1.5rem;
}
.header-logo { justify-self: start; }
.header-nav { display: none; }
.header-actions {
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.header-cart {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: var(--font-size-caps);
  letter-spacing: .2em;
  text-transform: uppercase;
}
.header-cart-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 20px; height: 20px; padding: 0 6px;
  border-radius: 999px;
  background: var(--color-text-primary);
  color: var(--color-text-onDark);
  font-size: 10px; font-weight: 600; letter-spacing: 0;
}
.header-menu-toggle { padding: 6px; }
.header-menu-toggle span {
  display: block;
  width: 22px; height: 1px;
  background: var(--color-text-primary);
  margin: 5px 0;
}

/* Logo (image PNG en mask, recoloriable via background-color) */
.logo-mark {
  display: inline-block;
  width: calc(var(--logo-height, 26px) * 3.47);
  height: var(--logo-height, 26px);
  background-color: var(--color-text-primary);
  -webkit-mask-image: url("assets/logo-mark.png");
          mask-image: url("assets/logo-mark.png");
  -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
  -webkit-mask-size: contain;   mask-size: contain;
  -webkit-mask-position: center; mask-position: center;
}
.logo-mark--onDark { background-color: var(--color-text-onDark); }

/* ==========================================================================
   SECTION : HERO
   ========================================================================== */

.section-hero { position: relative; }
.hero-frame {
  position: relative;
  height: min(92vh, 760px);
  overflow: hidden;
}
.hero-image {
  position: absolute;
  inset: 0;
  background-image: var(--img-hero-primary);
  background-size: cover;
  background-position: var(--img-hero-object-position);
  transform: scale(var(--img-hero-scale));
  transform-origin: center center;
  /* animation de zoom lent désactivée (image fixe, homogène) */
}
@keyframes heroDrift {
  0%   { transform: scale(var(--img-hero-scale))   translate3d(0, 0, 0); }
  100% { transform: scale(calc(var(--img-hero-scale) + .06)) translate3d(-1.2%, 1%, 0); }
}
.hero-vignette {
  position: absolute; inset: 0;
  background: linear-gradient(75deg, rgba(58,46,34,0) 35%, rgba(58,46,34,.55) 100%);
}
.hero-corners {
  position: absolute;
  top: 1rem; left: var(--gutter-mobile); right: var(--gutter-mobile);
  display: flex; justify-content: space-between;
  color: var(--color-text-onDark); opacity: .82;
  font-size: var(--font-size-eyebrow);
  letter-spacing: var(--letter-spacing-caps);
  text-transform: uppercase;
}
.hero-copy {
  position: absolute;
  left: var(--gutter-mobile); bottom: 3rem;
  max-width: 26rem;
  display: flex; flex-direction: column; gap: 1.125rem;
  color: var(--color-text-onDark);
}
.hero-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: var(--font-weight-regular);
  font-size: var(--font-size-hero);
  line-height: .96;
  letter-spacing: var(--letter-spacing-display);
}
.hero-title em { font-style: italic; font-weight: var(--font-weight-light); }
.hero-lede {
  margin: 0; max-width: 28rem;
  font-size: .9375rem;
  line-height: var(--line-height-relaxed);
  color: rgba(242, 234, 217, 0.86);
}

/* ==========================================================================
   SECTION : MANIFESTO
   ========================================================================== */

.section-manifesto {
  padding: var(--space-section) var(--gutter-mobile);
  text-align: center;
}
.manifesto-title {
  margin: 1.5rem auto 0;
  max-width: 58rem;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--font-weight-light);
  font-size: var(--font-size-display);
  line-height: 1.1;
  letter-spacing: var(--letter-spacing-display);
  text-align: center;
}
.manifesto-title__sub {
  display: block;
  margin-top: 0.6rem;
  font-size: 0.5em;
  line-height: 1.25;
  opacity: 0.85;
}
.manifesto-grid {
  margin: 4rem auto 0;
  max-width: 77.5rem;
  display: grid;
  grid-template-columns: 1fr;
  gap: 3.5rem;
}
.manifesto-pillar { text-align: center; padding-inline: 0; }
.manifesto-pillar__kicker {
  font-size: var(--font-size-eyebrow);
  letter-spacing: var(--letter-spacing-eyebrow);
  opacity: .5;
  margin-bottom: 1.5rem;
}
.manifesto-pillar__num {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  line-height: 1;
  color: var(--color-text-primary);
}
.manifesto-pillar__unit {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.25rem, 2vw, 1.75rem);
  color: var(--color-accent-warm);
  margin-top: 0.375rem;
}
.manifesto-pillar__body {
  margin: 1.5rem auto 0;
  max-width: 18.75rem;
  font-size: .875rem;
  line-height: 1.65;
  opacity: .78;
}

/* ==========================================================================
   SECTION : PRODUCTS GRID
   ========================================================================== */

.section-products-grid {
  padding: 3.75rem var(--gutter-mobile) 5rem;
}
.products-grid-inner { max-width: var(--container-max); margin: 0 auto; }
.products-grid-header {
  display: flex; flex-wrap: wrap; gap: 1.5rem;
  justify-content: space-between; align-items: flex-end;
  margin-bottom: 2.5rem;
}
.products-grid-title {
  margin: 1.125rem 0 0;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--font-weight-light);
  font-size: clamp(2.25rem, 8vw, 3.25rem);
  line-height: 1.02;
  letter-spacing: var(--letter-spacing-display);
}
.products-grid-link {
  font-size: var(--font-size-caps);
  letter-spacing: var(--letter-spacing-caps);
  text-transform: uppercase;
  border-bottom: 1px solid var(--color-text-primary);
  padding-bottom: 6px;
}
.products-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}

/* Product card */
.product-card { display: flex; flex-direction: column; gap: 14px; }
.product-card__media {
  position: relative;
  overflow: hidden;
  background: var(--color-bg-secondary);
}
.product-card__ratio { padding-top: 125%; position: relative; }
.product-card__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: var(--img-product-card-position);
  transition: transform 1.2s cubic-bezier(.2,.7,.2,1), filter .6s;
}
.product-card:hover .product-card__img { transform: scale(1.04); filter: brightness(1.02); }
.product-card__edition {
  position: absolute;
  top: 14px; left: 14px;
  background: rgba(242, 234, 217, .92);
  color: var(--color-text-primary);
  padding: 6px 10px;
  font-size: 10px; letter-spacing: .22em; text-transform: uppercase;
}
.product-card__add {
  position: absolute;
  bottom: -44px; left: 14px; right: 14px;
  background: var(--color-text-primary);
  color: var(--color-text-onDark);
  padding: 14px;
  font-size: var(--font-size-eyebrow);
  letter-spacing: var(--letter-spacing-caps);
  text-transform: uppercase;
  font-weight: var(--font-weight-medium);
  transition: bottom .35s cubic-bezier(.2,.7,.2,1);
}
.product-card:hover .product-card__add { bottom: 14px; }
.product-card__info {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 12px; padding: 4px 2px 0;
}
.product-card__name {
  font-family: var(--font-display);
  font-weight: var(--font-weight-medium);
  font-size: 1.375rem; line-height: 1;
}
.product-card__sub {
  font-family: var(--font-display);
  font-style: italic;
  font-size: .875rem;
  opacity: .62;
  margin-top: 4px;
}
.product-card__price { font-size: .875rem; font-weight: var(--font-weight-medium); text-align: right; }
.product-card__color {
  font-size: 10px; letter-spacing: .18em; text-transform: uppercase;
  opacity: .55; margin-top: 4px; text-align: right;
}

/* ==========================================================================
   SECTION : SPLIT DAY/NIGHT
   ========================================================================== */

.section-split-day-night {
  display: grid;
  grid-template-columns: 1fr;
  border-top: 1px solid var(--color-border-subtle);
  border-bottom: 1px solid var(--color-border-subtle);
}
.split-panel {
  position: relative;
  overflow: hidden;
  padding: 3.75rem 1.5rem;
  min-height: 32.5rem;
  display: flex; flex-direction: column; justify-content: flex-end;
}
.split-panel__image {
  position: absolute; inset: 0;
  background-size: cover;
}
.split-panel__overlay { position: absolute; inset: 0; }
.split-panel__content { position: relative; }
.split-panel__title {
  margin: 1.125rem 0 .875rem;
  font-family: var(--font-display);
  font-weight: var(--font-weight-regular);
  font-size: clamp(2.5rem, 5vw, 4.75rem);
  line-height: 1;
}
.split-panel__body {
  max-width: 23.75rem;
  font-size: .9375rem; line-height: 1.65;
  opacity: .82; margin: 0 0 1.75rem;
}

.split-panel--day { background: var(--color-bg-primary); color: var(--color-text-primary); }
.split-panel--day .split-panel__image {
  background-image: var(--img-jour);
  background-position: var(--img-jour-object-position);
  opacity: .92;
}
.split-panel--day .split-panel__overlay {
  background: linear-gradient(180deg, rgba(242,234,217,.05) 30%, rgba(242,234,217,.85) 100%);
}

.split-panel--night { background: var(--color-text-primary); color: var(--color-text-onDark); }
.split-panel--night .split-panel__image {
  background-image: var(--img-nuit);
  background-position: var(--img-nuit-object-position);
  opacity: .7;
}
.split-panel--night .split-panel__overlay {
  background: linear-gradient(180deg, rgba(58,46,34,.15) 30%, rgba(58,46,34,.92) 100%);
}

/* ==========================================================================
   SECTION : LOOKBOOK
   ========================================================================== */

.section-lookbook {
  padding: 5rem 0;
  background: var(--color-bg-secondary);
}
.lookbook-header {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter-mobile);
  display: flex; flex-wrap: wrap; gap: 1.5rem;
  justify-content: space-between; align-items: flex-end;
}
.lookbook-title {
  margin: 1.125rem 0 0;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--font-weight-light);
  font-size: clamp(2.5rem, 5.5vw, 5.25rem);
  line-height: 1.02;
  letter-spacing: var(--letter-spacing-display);
}
.lookbook-arrows { display: none; gap: 12px; }
.lookbook-arrow {
  width: 48px; height: 48px;
  border: 1px solid rgba(58,46,34,.4);
  font-size: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--color-text-primary);
}
.lookbook-scroller {
  margin-top: 2.5rem;
  display: flex; gap: 1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-inline: var(--gutter-mobile);
  padding-bottom: 1.5rem;
  cursor: grab;
}
.lookbook-item {
  margin: 0;
  flex: 0 0 auto;
  scroll-snap-align: start;
  width: 78vw;
}
.lookbook-item__media {
  aspect-ratio: 4 / 5;
  background: var(--color-bg-deep);
  overflow: hidden;
}
.lookbook-item:nth-child(odd) .lookbook-item__media { aspect-ratio: 3 / 4; }
.lookbook-item__img { width: 100%; height: 100%; object-fit: cover; }
.lookbook-item__caption {
  margin-top: 14px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: .875rem;
  color: var(--color-text-primary);
  opacity: .7;
}

/* ==========================================================================
   SECTION : QUALITY
   ========================================================================== */

.section-quality {
  padding: var(--space-section) 1.5rem;
  text-align: center;
}
.quality-inner { max-width: 57.5rem; margin: 0 auto; }
.quality-list {
  margin: 3rem 0 0;
  padding: 0; list-style: none;
  display: flex; flex-direction: column;
  gap: 2rem;
}
.quality-item {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--font-weight-light);
  font-size: clamp(1.375rem, 5.5vw, 1.875rem);
  line-height: 1.25;
}
.quality-item__num {
  display: inline-block;
  margin-right: 1.125rem;
  color: var(--color-accent-warm);
  font-size: .7em;
  vertical-align: middle;
  font-family: var(--font-body);
  font-style: normal;
  letter-spacing: .18em;
}
.quality-footer {
  margin-top: 2rem;
  font-family: var(--font-display);
  font-size: .875rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  opacity: .6;
}

/* ==========================================================================
   SECTION : FOOTER
   ========================================================================== */

.section-footer {
  background: var(--color-text-primary);
  color: var(--color-text-onDark);
  padding-top: 5rem;
}
.footer-inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter-mobile);
}
.footer-newsletter {
  display: grid; grid-template-columns: 1fr; gap: 2rem;
  padding-bottom: 3.75rem;
  border-bottom: 1px solid var(--color-border-onDark);
  align-items: end;
}
.footer-newsletter__title {
  margin: 1rem 0 0;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--font-weight-light);
  font-size: clamp(2rem, 8vw, 2.5rem);
  line-height: 1.08;
  letter-spacing: var(--letter-spacing-display);
}
.footer-newsletter form { display: flex; flex-direction: column; gap: 14px; }
.footer-newsletter__row {
  display: flex;
  border-bottom: 1px solid rgba(242, 234, 217, 0.4);
}
.footer-newsletter__input {
  flex: 1; background: transparent; border: 0; outline: none;
  padding: 14px 0; color: var(--color-text-onDark);
  font-size: .9375rem; font-family: inherit;
}
.footer-newsletter__submit {
  font-size: var(--font-size-caps);
  letter-spacing: var(--letter-spacing-caps);
  text-transform: uppercase;
  padding: 14px 4px;
  color: var(--color-accent-warm);
  font-weight: var(--font-weight-medium);
}
.footer-newsletter__legal {
  margin: 0;
  font-size: var(--font-size-eyebrow);
  opacity: .55; line-height: 1.6;
}
.footer-cols {
  padding: 3.5rem 0 3.75rem;
  display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem;
}
.footer-col__title {
  font-size: var(--font-size-eyebrow);
  letter-spacing: var(--letter-spacing-eyebrow);
  text-transform: uppercase;
  color: var(--color-accent-warm);
  margin-bottom: 1.375rem;
}
.footer-col__list {
  margin: 0; padding: 0; list-style: none;
  display: flex; flex-direction: column; gap: 12px;
}
.footer-col__list a { font-size: .8125rem; opacity: .78; }
.footer-logo-row {
  padding: 2.5rem 0 2rem;
  border-top: 1px solid var(--color-border-onDark);
  display: flex; flex-wrap: wrap; gap: 1.5rem;
  justify-content: space-between; align-items: center;
}
.footer-socials {
  display: flex; align-items: center; gap: 1.5rem;
  font-size: var(--font-size-eyebrow);
  letter-spacing: .22em; text-transform: uppercase;
  opacity: .6;
}
.footer-base {
  padding: 1.5rem 0 2.25rem;
  display: flex; flex-wrap: wrap; gap: 1rem;
  justify-content: space-between; align-items: center;
  font-size: var(--font-size-eyebrow);
  opacity: .5;
  letter-spacing: .18em; text-transform: uppercase;
}

/* ==========================================================================
   SECTION : COOKIE BANNER (overlay flottant)
   ========================================================================== */

.section-cookie-banner {
  position: fixed;
  left: 16px; right: 16px; bottom: 16px;
  z-index: 60;
  background: rgba(242, 234, 217, 0.96);
  color: var(--color-text-primary);
  border: 1px solid rgba(58, 46, 34, 0.18);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  box-shadow: var(--shadow-card);
  display: none;
}
.section-cookie-banner[data-visible="true"] { display: block; }
.cookie-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 18px 22px;
  display: flex; flex-wrap: wrap; gap: 1.5rem;
  align-items: center;
}
.cookie-text {
  flex: 1; min-width: 15rem; margin: 0;
  font-size: .8125rem; line-height: 1.55; opacity: .85;
}
.cookie-actions { display: flex; gap: 10px; flex-wrap: wrap; flex-shrink: 0; }
.cookie-btn {
  padding: 12px 20px;
  font-size: var(--font-size-eyebrow);
  letter-spacing: .22em; text-transform: uppercase;
  font-weight: var(--font-weight-medium);
}
.cookie-btn--solid { background: var(--color-text-primary); color: var(--color-text-onDark); }
.cookie-btn--ghost { border: 1px solid var(--color-text-primary); }
.cookie-btn--link  { text-decoration: underline; text-underline-offset: 4px; padding: 12px 6px; }

/* ==========================================================================
   CART DRAWER + MOBILE MENU (overlays)
   ========================================================================== */

.cart-scrim {
  position: fixed; inset: 0; z-index: 90;
  background: rgba(58, 46, 34, 0.45);
  backdrop-filter: blur(2px);
  opacity: 0; pointer-events: none;
  transition: opacity .35s;
}
.cart-scrim[data-open="true"] { opacity: 1; pointer-events: auto; }
.cart-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  z-index: 91;
  width: min(440px, 100vw);
  background: var(--color-bg-primary);
  color: var(--color-text-primary);
  transform: translateX(100%);
  transition: transform var(--transition-slow);
  display: flex; flex-direction: column;
  box-shadow: var(--shadow-drawer);
}
.cart-drawer[data-open="true"] { transform: translateX(0); }
.cart-drawer__head {
  padding: 22px 28px;
  display: flex; justify-content: space-between; align-items: center;
  border-bottom: 1px solid var(--color-border-subtle);
}
.cart-drawer__title { font-family: var(--font-display); font-size: 1.375rem; }
.cart-drawer__body { flex: 1; overflow-y: auto; padding: 8px 28px; }
.cart-empty { text-align: center; padding: 5rem 0; opacity: .6; }
.cart-empty p { margin: 1rem 0 0; }
.cart-empty .cart-empty__lede {
  font-family: var(--font-display);
  font-style: italic; font-size: 1.25rem;
}
.cart-drawer__foot {
  padding: 1.25rem 28px 1.75rem;
  border-top: 1px solid var(--color-border-subtle);
}

.mobile-menu {
  position: fixed; inset: 0; z-index: 80;
  background: var(--color-bg-primary);
  color: var(--color-text-primary);
  transform: translateY(-100%);
  transition: transform var(--transition-slow);
  display: flex; flex-direction: column;
  padding: 1rem var(--gutter-mobile) 2.5rem;
}
.mobile-menu[data-open="true"] { transform: translateY(0); }
.mobile-menu__head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 3.75rem;
}
.mobile-menu__nav {
  display: flex; flex-direction: column; gap: 1.125rem;
}
.mobile-menu__nav a {
  font-family: var(--font-display);
  font-size: 2.25rem; line-height: 1.1;
}

/* ==========================================================================
   SECTIONS PAGE PRODUIT
   ========================================================================== */

.section-breadcrumb {
  padding: 1.5rem var(--gutter-mobile) 0;
  max-width: var(--container-max);
  margin: 0 auto;
  font-size: var(--font-size-eyebrow);
  letter-spacing: .22em; text-transform: uppercase;
  opacity: .7;
}
.section-breadcrumb a:not(:last-child)::after {
  content: " / ";
  margin: 0 .5rem;
  opacity: .5;
}

.section-product-main {
  padding: 2rem var(--gutter-mobile) 4rem;
  max-width: var(--container-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}
/* Grid children must allow shrinking below their min-content (which the
   thumbnail strip can inflate via aspect-ratio + 4-track grid). */
.section-product-main > * { min-width: 0; }
.product-gallery {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1rem;
  min-width: 0;
}
.product-gallery__main {
  background: var(--color-bg-secondary);
  aspect-ratio: 4 / 5;
  background-image: var(--img-product-main);
  background-size: cover;
  background-position: var(--img-product-main-position);
  min-width: 0;
  cursor: zoom-in;
  transition: filter var(--transition-default);
}
.product-gallery__main:hover { filter: brightness(1.02); }
.product-gallery__thumbs {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: .75rem;
  min-width: 0;
}
.product-gallery__thumb {
  aspect-ratio: 1 / 1;
  background-size: cover;
  background-position: center;
  background-color: var(--color-bg-secondary);
  cursor: pointer;
  border: 1px solid transparent;
  transition: border-color var(--transition-default);
}
.product-gallery__thumb:hover { border-color: var(--color-text-primary); }
.product-gallery__thumb[aria-pressed="true"] { border-color: var(--color-text-primary); }
.product-gallery__thumb[data-image-role="thumb-1"] { background-image: var(--img-product-thumb-1); }
.product-gallery__thumb[data-image-role="thumb-2"] { background-image: var(--img-product-thumb-2); }
.product-gallery__thumb[data-image-role="thumb-3"] { background-image: var(--img-product-thumb-3); }
.product-gallery__thumb[data-image-role="thumb-4"] { background-image: var(--img-product-thumb-4); }
.product-gallery__thumb[data-image-role="main-thumb"] { background-image: var(--img-product-main); }

.product-info { display: flex; flex-direction: column; gap: 1.25rem; }
.product-info__edition {
  font-size: var(--font-size-eyebrow);
  letter-spacing: var(--letter-spacing-eyebrow);
  text-transform: uppercase;
  color: var(--color-accent-warm);
}
.product-info__name {
  margin: 0;
  font-family: var(--font-display);
  font-weight: var(--font-weight-regular);
  font-size: clamp(2.5rem, 8vw, 4rem);
  line-height: 1;
  letter-spacing: var(--letter-spacing-display);
}
.product-info__sub {
  margin: 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.125rem;
  color: var(--color-text-muted);
}
.product-info__price {
  font-size: 1.25rem;
  font-weight: var(--font-weight-medium);
  margin: .5rem 0 0;
}
.product-info__desc {
  margin: .5rem 0 0;
  font-size: .9375rem;
  line-height: 1.7;
  max-width: 32rem;
}
.product-info__group { display: flex; flex-direction: column; gap: .625rem; margin-top: .5rem; }
.product-info__label {
  font-size: var(--font-size-eyebrow);
  letter-spacing: var(--letter-spacing-eyebrow);
  text-transform: uppercase;
  opacity: .7;
}
.product-info__sizes { display: flex; flex-wrap: wrap; gap: .5rem; }
.product-info__size {
  width: 3rem; height: 3rem;
  border: 1px solid var(--color-border-subtle);
  font-size: .8125rem; font-weight: var(--font-weight-medium);
  display: inline-flex; align-items: center; justify-content: center;
  transition: border-color var(--transition-default), background var(--transition-default);
}
.product-info__size:hover { border-color: var(--color-text-primary); }
.product-info__size[aria-pressed="true"] {
  background: var(--color-text-primary);
  color: var(--color-text-onDark);
  border-color: var(--color-text-primary);
}
.product-info__colors { display: flex; gap: .625rem; }
.product-info__swatch {
  width: 2rem; height: 2rem;
  border-radius: 999px;
  border: 1px solid var(--color-border-subtle);
  position: relative;
  transition: transform var(--transition-default);
}
.product-info__swatch:hover { transform: scale(1.06); }
.product-info__swatch[aria-pressed="true"]::after {
  content: "";
  position: absolute; inset: -5px;
  border: 1px solid var(--color-text-primary);
  border-radius: 999px;
}
.product-info__size[disabled],
.product-info__size[aria-disabled="true"] {
  color: var(--color-text-muted);
  opacity: .45;
  cursor: not-allowed;
  text-decoration: line-through;
  text-decoration-thickness: 1px;
}
.product-info__size[disabled]:hover,
.product-info__size[aria-disabled="true"]:hover { border-color: var(--color-border-subtle); }

.product-info__sizes-head {
  display: flex; justify-content: space-between; align-items: baseline;
}
.product-info__size-guide {
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  text-decoration: underline; text-underline-offset: 4px; opacity: .7;
  transition: opacity var(--transition-default);
}
.product-info__size-guide:hover { opacity: 1; }

.product-info__buy {
  margin-top: 1.25rem;
  display: flex; flex-direction: column; gap: .75rem;
}
.product-info__edition-note {
  font-family: var(--font-display);
  font-style: italic;
  font-size: .9375rem;
  color: var(--color-text-muted);
  text-align: center;
  line-height: 1.5;
}
.product-info__edition-note b {
  color: var(--color-text-primary); font-weight: var(--font-weight-medium);
}

/* Accordéons produit */
.product-info__accordions {
  margin-top: 1.5rem;
  border-top: 1px solid var(--color-border-subtle);
}
.product-info__accordion {
  border-bottom: 1px solid var(--color-border-subtle);
}
.product-info__accordion-trigger {
  width: 100%;
  display: flex; justify-content: space-between; align-items: center;
  padding: 1.25rem 0;
  font-size: var(--font-size-caps);
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  text-align: left;
}
.product-info__accordion-icon {
  width: 12px; height: 12px; position: relative; flex-shrink: 0;
}
.product-info__accordion-icon::before,
.product-info__accordion-icon::after {
  content: ""; position: absolute; inset: 0;
  background: var(--color-text-primary);
  transition: transform var(--transition-default);
}
.product-info__accordion-icon::before { height: 1px; top: 50%; }
.product-info__accordion-icon::after  { width: 1px; left: 50%; }
.product-info__accordion[data-open="true"] .product-info__accordion-icon::after {
  transform: scaleY(0);
}
.product-info__accordion-body {
  max-height: 0; overflow: hidden;
  transition: max-height .4s cubic-bezier(.2,.7,.2,1);
}
.product-info__accordion[data-open="true"] .product-info__accordion-body {
  max-height: 400px;
}
.product-info__accordion-inner {
  padding: 0 0 1.25rem;
  font-size: .875rem;
  line-height: 1.7;
  color: var(--color-text-primary);
  opacity: .82;
}
.product-info__accordion-inner p { margin: 0 0 .75rem; }
.product-info__accordion-inner p:last-child { margin-bottom: 0; }

/* Story 2-col + cross-sell 4-col */
.section-story {
  padding: var(--space-section) var(--gutter-mobile);
}
.section-story__inner {
  max-width: 70rem; margin: 0 auto;
  display: grid; grid-template-columns: 1fr;
  gap: 2.5rem; align-items: center;
}
.section-story__visual {
  background: var(--color-bg-secondary);
  aspect-ratio: 4 / 5;
  background-image: var(--img-product-story);
  background-size: cover;
  background-position: var(--img-product-story-position);
}
.section-story__copy { text-align: left; }
.section-story__copy .eyebrow { color: var(--color-accent-warm); }
.section-story__title {
  text-align: left;
  margin: 1rem 0 1.5rem;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--font-weight-light);
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.1;
  letter-spacing: var(--letter-spacing-display);
}
.section-story__body {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--font-weight-light);
  font-size: 1.25rem;
  line-height: 1.55;
  max-width: 36rem;
  margin: 0;
  opacity: .85;
}

/* Size-guide modal */
.size-guide-overlay {
  position: fixed; inset: 0; z-index: 95;
  background: rgba(58, 46, 34, .55);
  backdrop-filter: blur(4px);
  display: none;
  align-items: center; justify-content: center;
  padding: 1rem;
}
.size-guide-overlay[data-open="true"] { display: flex; }
.size-guide {
  background: var(--color-bg-primary);
  color: var(--color-text-primary);
  width: min(640px, 100%);
  max-height: 92vh; overflow: auto;
  padding: 2.5rem;
  position: relative;
  box-shadow: var(--shadow-card);
}
.size-guide__close {
  position: absolute; top: 12px; right: 16px;
  font-size: 22px; line-height: 1; padding: 8px;
}
.size-guide__title {
  margin: 0 0 .5rem;
  font-family: var(--font-display);
  font-weight: var(--font-weight-regular);
  font-size: 1.75rem;
}
.size-guide__lede {
  margin: 0 0 1.5rem;
  font-size: .875rem; opacity: .75; line-height: 1.6;
}
.size-guide__table {
  width: 100%;
  border-collapse: collapse;
  font-size: .8125rem;
}
.size-guide__table th,
.size-guide__table td {
  padding: .875rem .5rem;
  text-align: left;
  border-bottom: 1px solid var(--color-border-subtle);
}
.size-guide__table th {
  font-size: var(--font-size-eyebrow);
  letter-spacing: var(--letter-spacing-eyebrow);
  text-transform: uppercase;
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
}
.size-guide__table tr:last-child td { border-bottom: 0; }
.size-guide__note {
  margin: 1.25rem 0 0;
  font-size: .8125rem; opacity: .65; line-height: 1.55;
}
.product-info__meta {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-border-subtle);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem 1.5rem;
  font-size: .8125rem;
}
.product-info__meta dt {
  font-size: var(--font-size-eyebrow);
  letter-spacing: var(--letter-spacing-eyebrow);
  text-transform: uppercase;
  opacity: .55;
  margin-bottom: .25rem;
}
.product-info__meta dd { margin: 0; line-height: 1.5; }

.section-ambiance {
  position: relative;
  height: min(90vh, 720px);
  overflow: hidden;
}
.section-ambiance__image {
  position: absolute; inset: 0;
  background-image: var(--img-ambiance);
  background-size: cover;
  background-position: var(--img-ambiance-object-position);
}
.section-ambiance__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(58,46,34,0) 40%, rgba(58,46,34,.55) 100%);
}
.section-ambiance__copy {
  position: absolute;
  left: var(--gutter-mobile); right: var(--gutter-mobile); bottom: 2.5rem;
  color: var(--color-text-onDark);
  max-width: 32rem;
}
.section-ambiance__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: var(--font-weight-regular);
  font-size: clamp(2rem, 6vw, 3.75rem);
  line-height: 1;
  letter-spacing: var(--letter-spacing-display);
}

.section-cross-sell {
  padding: 0 var(--gutter-mobile) 5rem;
}
.section-cross-sell__inner { max-width: var(--container-max); margin: 0 auto; }
.section-cross-sell__title {
  margin: 0 0 2.5rem;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: var(--font-weight-light);
  font-size: clamp(2rem, 5vw, 3rem);
  text-align: center;
}
.cross-sell-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}

/* ==========================================================================
   BREAKPOINTS — explicites
   - Mobile  : base (320–767)
   - Tablet  : ≥ 768
   - Desktop : ≥ 1280
   ========================================================================== */

/* ----- TABLET : grilles passent à 2 col, padding plus généreux ----- */
@media (min-width: 768px) {
  .container { padding-inline: var(--gutter-tablet); }
  .header-inner { padding: 1.25rem var(--gutter-tablet); }
  .hero-corners { top: 1.5rem; left: var(--gutter-tablet); right: var(--gutter-tablet); }
  .hero-copy { left: 2.5rem; bottom: 3.5rem; max-width: 32rem; gap: 1.25rem; }

  .section-manifesto { padding: 7rem var(--gutter-tablet); }
  .manifesto-grid { grid-template-columns: repeat(3, 1fr); gap: 0; }
  .manifesto-pillar { padding-inline: 2.5rem; }
  .manifesto-pillar + .manifesto-pillar { border-left: 1px solid var(--color-border-subtle); }

  .section-products-grid { padding: 4rem var(--gutter-tablet) 6rem; }
  .products-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 2.5rem; }
  .products-grid-header { margin-bottom: 3.5rem; }

  .section-split-day-night { grid-template-columns: 1fr 1fr; }
  .split-panel { padding: 5rem 2.5rem; min-height: 36rem; }

  .section-lookbook { padding: 7rem 0; }
  .lookbook-header { padding: 0 var(--gutter-tablet); }
  .lookbook-arrows { display: flex; }
  .lookbook-scroller { gap: 2rem; padding-inline: var(--gutter-tablet); margin-top: 3.5rem; }
  .lookbook-item { width: 28rem; }
  .lookbook-item:nth-child(odd) { width: 32.5rem; }

  .section-quality { padding: 7rem var(--gutter-tablet); }
  .quality-list { gap: 2.5rem; }

  .section-footer { padding-top: 6.5rem; }
  .footer-inner { padding: 0 var(--gutter-tablet); }
  .footer-newsletter { grid-template-columns: 1fr 1fr; gap: 5rem; padding-bottom: 5rem; }
  .footer-cols { grid-template-columns: repeat(4, 1fr); padding: 4.5rem 0; gap: 2rem; }
  .footer-logo-row { padding: 3rem 0 2.5rem; }

  /* Page produit : header + breadcrumb + main passent en 2 col */
  .section-breadcrumb { padding: 2rem var(--gutter-tablet) 0; }
  .section-product-main {
    grid-template-columns: 1.05fr 1fr;
    gap: 3rem;
    padding: 2.5rem var(--gutter-tablet) 6rem;
  }
  .section-ambiance { height: min(90vh, 820px); }
  .section-ambiance__copy { left: var(--gutter-tablet); right: var(--gutter-tablet); bottom: 4rem; }
  .section-story { padding: 7rem var(--gutter-tablet); }
  .section-story__inner { grid-template-columns: 1fr 1fr; gap: 4rem; }
  .section-cross-sell { padding: 0 var(--gutter-tablet) 7rem; }
  .cross-sell-grid { grid-template-columns: repeat(2, 1fr); gap: 2.5rem; }
}

/* ----- DESKTOP : nav inline, hero plein, grille produits 3 col, lookbook fluide ----- */
@media (min-width: 1280px) {
  .container { padding-inline: var(--gutter-desktop); }
  .header-inner { padding: 1.375rem var(--gutter-desktop); }
  .header-nav {
    display: flex; gap: 2.25rem; justify-content: center;
  }
  .header-nav a {
    font-size: var(--font-size-caps);
    letter-spacing: .2em; text-transform: uppercase;
    font-weight: var(--font-weight-medium);
    opacity: .78;
    transition: opacity var(--transition-default);
  }
  .header-nav a:hover { opacity: 1; }
  .header-menu-toggle { display: none; }
  .header-search { display: inline-block; }

  .hero-frame { height: min(94vh, 980px); }
  .hero-corners { left: var(--gutter-desktop); right: var(--gutter-desktop); top: 1.75rem; }
  .hero-copy { left: 3.75rem; bottom: 4.5rem; max-width: 35rem; gap: 1.5rem; }
  .hero-lede { font-size: .9375rem; }

  .section-manifesto { padding: var(--space-section-d) var(--gutter-desktop); }
  .manifesto-grid { margin-top: 7.5rem; }

  .section-products-grid { padding: 2.5rem var(--gutter-desktop) 7.5rem; }
  .products-grid { grid-template-columns: repeat(var(--product-cols, 3), minmax(0, 1fr)); gap: 2.5rem; }

  .split-panel { padding: 6.25rem 3.75rem; min-height: 42.5rem; }

  .section-lookbook { padding: 8.75rem 0; }
  .lookbook-header { padding: 0 var(--gutter-desktop); }
  .lookbook-scroller { padding-inline: var(--gutter-desktop); }

  .section-quality { padding: var(--space-section-d) var(--gutter-desktop); }

  .footer-inner { padding: 0 var(--gutter-desktop); }
  .footer-newsletter { padding-bottom: 6.25rem; }
  .footer-cols { padding: 5rem 0; }

  /* Page produit */
  .section-breadcrumb { padding: 2.5rem var(--gutter-desktop) 0; }
  .section-product-main {
    grid-template-columns: 1.1fr 1fr;
    gap: 5rem;
    padding: 3rem var(--gutter-desktop) 7.5rem;
  }
  .product-gallery {
    grid-template-columns: 80px 1fr;
    grid-template-areas: "thumbs main";
    gap: 1.25rem;
  }
  .product-gallery__main { grid-area: main; aspect-ratio: 4 / 5; }
  .product-gallery__thumbs {
    grid-area: thumbs;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: repeat(5, 80px);
    gap: 1rem;
  }
  .product-info { padding-top: 1rem; gap: 1.5rem; }
  .section-ambiance__copy { left: var(--gutter-desktop); right: var(--gutter-desktop); bottom: 5rem; }
  .section-story { padding: var(--space-section-d) var(--gutter-desktop); }
  .section-story__inner { gap: 5rem; }
  .section-cross-sell { padding: 0 var(--gutter-desktop) var(--space-section-d); }
  .cross-sell-grid { grid-template-columns: repeat(4, 1fr); gap: 2rem; }
}

/* ==========================================================================
   ÉDITION DES PHOTOS — barre d'outils + état d'édition
   ========================================================================== */
.pe-bar {
  position: fixed;
  right: var(--gutter-mobile);
  bottom: var(--gutter-mobile);
  z-index: 9999;
  font-family: var(--font-body);
}
.pe-toggle,
.pe-tools .pe-reset,
.pe-tools .pe-done {
  font-family: var(--font-body);
  font-size: var(--font-size-caps);
  letter-spacing: 0.1em;
  border: 1px solid var(--color-text-primary);
  background: var(--color-text-primary);
  color: var(--color-text-onDark);
  padding: 12px 18px;
  border-radius: var(--radius-button);
  cursor: pointer;
  transition: opacity var(--transition-default), background var(--transition-default);
}
.pe-toggle { box-shadow: var(--shadow-card); }
.pe-toggle:hover { opacity: .88; }

.pe-tools {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--color-text-primary);
  color: var(--color-text-onDark);
  padding: 10px 10px 10px 18px;
  border-radius: var(--radius-button);
  box-shadow: var(--shadow-card);
}
.pe-hint {
  font-size: var(--font-size-small);
  letter-spacing: 0.02em;
  opacity: .8;
}
.pe-tools .pe-reset {
  background: transparent;
  border-color: var(--color-border-onDark);
  color: var(--color-text-onDark);
  padding: 8px 14px;
}
.pe-tools .pe-reset:hover { background: rgba(242, 234, 217, 0.12); }
.pe-tools .pe-done {
  background: var(--color-accent-warm);
  border-color: var(--color-accent-warm);
  color: var(--color-text-primary);
  padding: 8px 16px;
}

/* Mise en évidence des images éditables */
body[data-photo-edit] [data-image-role] {
  cursor: pointer;
  outline: 2px dashed transparent;
  outline-offset: 3px;
  transition: outline-color var(--transition-default);
}
body[data-photo-edit] [data-image-role]:hover {
  outline-color: var(--color-accent-warm);
}
/* Empêche la navigation des cartes-produit pendant l'édition */
body[data-photo-edit] .product-card { pointer-events: auto; }

@media (max-width: 600px) {
  .pe-tools { flex-wrap: wrap; max-width: calc(100vw - 2 * var(--gutter-mobile)); }
  .pe-hint { flex-basis: 100%; }
}

/* Toast de confirmation "Enregistré ✓" */
.pe-toast {
  position: fixed;
  left: 50%;
  bottom: calc(var(--gutter-mobile) + 64px);
  transform: translate(-50%, 12px);
  z-index: 10000;
  font-family: var(--font-body);
  font-size: var(--font-size-small);
  letter-spacing: 0.04em;
  background: var(--color-accent-green);
  color: var(--color-text-onDark);
  padding: 11px 20px;
  border-radius: var(--radius-button);
  box-shadow: var(--shadow-card);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-default), transform var(--transition-default);
}
.pe-toast[data-show="true"] {
  opacity: 1;
  transform: translate(-50%, 0);
}

/* ==========================================================================
   OFFRE MYSTÈRE — pop-up de capture e-mail affichée avant l'intro (mystere.js)
   ========================================================================== */
.offre-overlay {
  position: fixed; inset: 0; z-index: 100001;       /* au-dessus de l'intro (100000) */
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .5s ease, visibility .5s ease;
}
.offre-overlay[data-visible="true"] { opacity: 1; visibility: visible; pointer-events: auto; }
.offre-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  transform: scale(1.05);
}
.offre-scrim {
  position: absolute; inset: 0;
  background: radial-gradient(120% 120% at 50% 28%, rgba(42,33,24,.42), rgba(42,33,24,.80));
}
.offre-card {
  position: relative;
  width: min(440px, 100%); box-sizing: border-box;
  background: var(--color-bg-primary);
  color: var(--color-text-primary);
  border-radius: 8px;
  padding: 40px 34px 28px;
  text-align: center;
  box-shadow: 0 30px 80px rgba(20, 14, 8, .45);
  transform: translateY(16px);
  transition: transform .5s ease;
}
.offre-overlay[data-visible="true"] .offre-card { transform: translateY(0); }
.offre-close {
  position: absolute; top: 12px; right: 14px;
  background: none; border: 0; cursor: pointer;
  font-size: 24px; line-height: 1; color: var(--color-text-muted);
}
.offre-eyebrow {
  font-size: var(--font-size-eyebrow);
  letter-spacing: .28em; text-transform: uppercase;
  color: var(--color-accent-warm); margin: 0 0 14px;
}
.offre-title {
  font-family: var(--font-display);
  font-weight: var(--font-weight-regular);
  font-size: 1.75rem; line-height: 1.2; margin: 0 0 24px;
}
.offre-lede {
  font-size: var(--font-size-small);
  line-height: 1.6; color: var(--color-text-muted);
  margin: 0 0 22px;
}
.offre-form { display: flex; flex-direction: column; gap: 10px; }
.offre-input {
  width: 100%; box-sizing: border-box;
  padding: 14px 16px;
  border: 1px solid var(--color-border-subtle);
  border-radius: 4px; background: #fff;
  font-family: var(--font-body); font-size: 15px;
  color: var(--color-text-primary); text-align: center;
}
.offre-input:focus { outline: none; border-color: var(--color-accent-warm); }
.offre-submit {
  width: 100%; padding: 15px 18px; cursor: pointer;
  background: var(--color-text-primary); color: var(--color-text-onDark);
  border: 0; border-radius: 4px;
  font-family: var(--font-body); font-size: 14px; letter-spacing: .04em;
  transition: opacity .2s;
}
.offre-submit:hover { opacity: .9; }
.offre-submit[disabled] { opacity: .55; cursor: default; }
.offre-feedback {
  font-size: var(--font-size-small); line-height: 1.5;
  margin: 12px 0 0; min-height: 1em;
}
.offre-feedback[data-state="error"] { color: #a23b2e; }
.offre-feedback[data-state="ok"] { color: var(--color-accent-green); }
.offre-skip {
  display: inline-block; margin: 18px 0 0;
  background: none; border: 0; cursor: pointer;
  font-family: var(--font-body); font-size: var(--font-size-small);
  color: var(--color-text-muted);
  text-decoration: underline; text-underline-offset: 3px;
}
.offre-legal {
  font-size: 11px; line-height: 1.5;
  color: var(--color-text-muted); opacity: .85; margin: 16px 0 0;
}
@media (max-width: 480px) {
  .offre-card { padding: 34px 22px 24px; }
  .offre-title { font-size: 1.5rem; }
}

/* ==========================================================================
   ZOOM PRODUIT — lightbox plein écran (clic sur le visuel principal). Voir app.js
   ========================================================================== */
.zoom-overlay {
  position: fixed; inset: 0; z-index: 100002;
  background: rgba(20, 14, 8, .93);
  display: none;
}
.zoom-overlay[data-open="true"] { display: block; }
.zoom-overlay__scroll {
  width: 100%; height: 100%;
  overflow: auto; -webkit-overflow-scrolling: touch;
  display: flex; align-items: center; justify-content: center;
}
.zoom-overlay__img {
  max-width: 100%; max-height: 100%;
  object-fit: contain; display: block;
  cursor: zoom-in; user-select: none;
}
/* État zoomé : l'image dépasse → on défile/glisse pour inspecter le détail */
.zoom-overlay[data-zoom="true"] .zoom-overlay__scroll { align-items: flex-start; justify-content: flex-start; }
.zoom-overlay[data-zoom="true"] .zoom-overlay__img {
  max-width: none; max-height: none;
  width: auto; height: 175vh;
  cursor: zoom-out;
}
.zoom-overlay__close {
  position: fixed; top: 12px; right: 16px; z-index: 2;
  background: none; border: 0; color: #fff;
  font-size: 30px; line-height: 1; cursor: pointer; opacity: .9;
}
.zoom-overlay__hint {
  position: fixed; left: 0; right: 0; bottom: 16px; z-index: 2;
  text-align: center; color: rgba(255,255,255,.7);
  font-family: var(--font-body); font-size: 12px; letter-spacing: .04em;
  pointer-events: none;
}
.zoom-overlay[data-zoom="true"] .zoom-overlay__hint { display: none; }

/* =========================================================================
   HERO — image dédiée sur MOBILE uniquement (< 600px).
   Le desktop garde son image d'origine (style inline dans index.html).
   ========================================================================= */
@media (max-width: 600px) {
  .section-hero .hero-image {
    background-image: url("assets/standalone/hero-mobile.jpg") !important;
    background-position: center center !important;
  }
}

/* =========================================================================
   COOKIES — sur mobile, boutons empilés pleine largeur.
   (Le bouton « Refuser » débordait du cadre. On GARDE les 3 boutons pour
   rester conforme CNIL : refuser doit être aussi simple qu'accepter.)
   ========================================================================= */
@media (max-width: 600px) {
  .cookie-inner { gap: 1rem; padding: 16px 18px; }
  .cookie-actions { width: 100%; flex-direction: column; gap: 8px; }
  .cookie-actions .cookie-btn { width: 100%; text-align: center; }
}
