/* ==========================================================================
   RAXINE — Sections dynamiques & animations modernes
   Hero slider, carrousels, blog, countdown, popups, scroll reveal
   ========================================================================== */

/* ==========================================================================
   1. HERO SLIDER (remplace le hero statique)
   ========================================================================== */
.hero-slider {
  position: relative;
  overflow: hidden;
  background: var(--c-brown-deep);
}

.hero-slider .swiper {
  width: 100%;
  height: clamp(520px, 80vh, 780px);
}

.hero-slide {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  overflow: hidden;
}

/* Background image + overlay */
.hero-slide__bg {
  position: absolute;
  inset: 0;
  z-index: 1;
}
.hero-slide__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.1);
  transition: transform 8s ease;
}
.swiper-slide-active .hero-slide__bg img { transform: scale(1); }

.hero-slide__overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(120deg, rgba(42,20,8,.85) 0%, rgba(61,31,8,.5) 50%, rgba(42,20,8,.4) 100%);
}

.hero-slide__pattern {
  position: absolute;
  inset: 0;
  z-index: 3;
  background-image: url("../images/pattern-leaves.svg");
  background-size: 400px;
  opacity: .15;
  pointer-events: none;
}

.hero-slide__content {
  position: relative;
  z-index: 4;
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 clamp(1rem, 4vw, 3rem);
  color: var(--c-cream);
}

.hero-slide__inner { max-width: 640px; }

/* Animations d'entrée (déclenchées au slide-active) */
.hero-slide__eyebrow,
.hero-slide__title,
.hero-slide__lead,
.hero-slide__actions,
.hero-slide__price-tag {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);
}
.swiper-slide-active .hero-slide__eyebrow    { opacity: 1; transform: translateY(0); transition-delay: .2s; }
.swiper-slide-active .hero-slide__title      { opacity: 1; transform: translateY(0); transition-delay: .4s; }
.swiper-slide-active .hero-slide__lead       { opacity: 1; transform: translateY(0); transition-delay: .6s; }
.swiper-slide-active .hero-slide__actions    { opacity: 1; transform: translateY(0); transition-delay: .8s; }
.swiper-slide-active .hero-slide__price-tag  { opacity: 1; transform: translateY(0); transition-delay: 1s; }

.hero-slide__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  background: rgba(232,155,60,.18);
  color: var(--c-orange-light);
  padding: 6px 16px;
  border-radius: var(--r-full);
  font-family: var(--font-body);
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  border: 1px solid rgba(232,155,60,.4);
  margin-bottom: var(--sp-5);
}
.hero-slide__eyebrow .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--c-orange);
  box-shadow: 0 0 0 0 var(--c-orange);
  animation: pulseDot 2s infinite;
}
@keyframes pulseDot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(232,155,60,.6); }
  50%      { box-shadow: 0 0 0 12px rgba(232,155,60,0); }
}

.hero-slide__title {
  font-family: var(--font-display);
  font-size: clamp(2.8rem, 6vw + 1rem, 5.8rem);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--c-cream);
  margin-bottom: var(--sp-5);
}
.hero-slide__title em {
  font-style: italic;
  color: var(--c-orange);
  font-weight: 400;
  display: inline-block;
}

.hero-slide__lead {
  font-size: clamp(1.05rem, 1.2vw + .5rem, 1.25rem);
  color: rgba(250,244,232,.88);
  margin-bottom: var(--sp-6);
  max-width: 56ch;
  line-height: 1.65;
}

.hero-slide__actions {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  align-items: center;
}

.hero-slide__price-tag {
  display: inline-flex;
  align-items: baseline;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
  padding: var(--sp-3) var(--sp-4);
  background: rgba(250,244,232,.08);
  border-left: 3px solid var(--c-orange);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  backdrop-filter: blur(6px);
}
.hero-slide__price-tag small { color: rgba(250,244,232,.7); font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; }
.hero-slide__price-tag .price { font-family: var(--font-display); font-size: 1.8rem; font-weight: 600; color: var(--c-orange); }
.hero-slide__price-tag .old { color: rgba(250,244,232,.5); text-decoration: line-through; font-size: 1rem; }

/* Pagination */
.hero-slider .swiper-pagination {
  bottom: 2rem !important;
  z-index: 10;
}
.hero-slider .swiper-pagination-bullet {
  width: 36px;
  height: 4px;
  border-radius: 2px;
  background: rgba(250,244,232,.3);
  opacity: 1;
  transition: all .4s ease;
}
.hero-slider .swiper-pagination-bullet-active {
  background: var(--c-orange);
  width: 64px;
}

/* Navigation arrows */
.hero-slider .swiper-button-prev,
.hero-slider .swiper-button-next {
  width: 56px !important;
  height: 56px !important;
  border-radius: 50%;
  background: rgba(250,244,232,.1);
  border: 1px solid rgba(250,244,232,.25);
  backdrop-filter: blur(10px);
  color: var(--c-cream);
  transition: all .3s ease;
}
.hero-slider .swiper-button-prev:hover,
.hero-slider .swiper-button-next:hover {
  background: var(--c-orange);
  border-color: var(--c-orange);
  color: var(--c-brown-deep);
}
.hero-slider .swiper-button-prev::after,
.hero-slider .swiper-button-next::after {
  font-size: 1.2rem !important;
  font-weight: 700;
}
@media (max-width: 768px) {
  .hero-slider .swiper-button-prev,
  .hero-slider .swiper-button-next { display: none !important; }
}

/* Indicateur de progression */
.hero-slider__progress {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 3px;
  background: var(--c-orange);
  width: 0;
  z-index: 10;
  transition: width .1s linear;
}

/* ==========================================================================
   2. CARROUSEL PRODUITS (nouveautés, populaires, tendances)
   ========================================================================== */
.product-carousel {
  position: relative;
  padding: 0;
}

.product-carousel .swiper {
  overflow: visible !important;
  padding: 1rem 0 2rem !important;
}

.product-carousel .swiper-slide {
  height: auto;
  display: flex;
}

.product-carousel .product-card {
  width: 100%;
}

/* Header avec titre + flèches */
.carousel-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
  flex-wrap: wrap;
}
.carousel-header__text { flex: 1; min-width: 250px; }
.carousel-header h2 { margin-bottom: var(--sp-2); }
.carousel-header p { color: var(--c-text-soft); margin: 0; }

.carousel-controls {
  display: flex;
  gap: var(--sp-2);
  align-items: center;
}
.carousel-controls button {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--c-white);
  border: 1.5px solid var(--c-border);
  color: var(--c-brown-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all var(--tr-fast);
  cursor: pointer;
}
.carousel-controls button:hover {
  background: var(--c-orange);
  border-color: var(--c-orange);
  color: var(--c-brown-deep);
  transform: scale(1.05);
}
.carousel-controls button.is-disabled {
  opacity: .4;
  cursor: not-allowed;
}
.carousel-controls .view-all {
  width: auto;
  padding: 0 var(--sp-4);
  border-radius: var(--r-full);
  font-size: .85rem;
  font-weight: 600;
  gap: var(--sp-2);
  text-decoration: none;
}

/* Pagination produits */
.product-carousel .swiper-pagination {
  position: relative !important;
  margin-top: var(--sp-4);
}
.product-carousel .swiper-pagination-bullet {
  background: var(--c-brown);
  opacity: .3;
}
.product-carousel .swiper-pagination-bullet-active {
  background: var(--c-orange);
  opacity: 1;
  width: 24px;
  border-radius: 4px;
}

/* ==========================================================================
   3. PROMO BANNER SLIDER (annonces/marketing)
   ========================================================================== */
.promo-banner {
  background: linear-gradient(135deg, var(--c-orange) 0%, var(--c-orange-dark) 100%);
  color: var(--c-brown-deep);
  overflow: hidden;
  position: relative;
}
.promo-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("../images/pattern-leaves.svg");
  background-size: 200px;
  opacity: .15;
  mix-blend-mode: multiply;
}
.promo-banner .swiper {
  position: relative;
  z-index: 2;
}
.promo-banner__slide {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  font-weight: 600;
  font-size: .95rem;
  text-align: center;
  flex-wrap: wrap;
}
.promo-banner__slide strong { font-weight: 700; }
.promo-banner__slide a {
  text-decoration: underline;
  font-weight: 700;
}

/* ==========================================================================
   4. COLLECTIONS HIGHLIGHTS (carrousel "univers")
   ========================================================================== */
.collections-slider .swiper-slide {
  height: auto;
}

.collection-card {
  position: relative;
  aspect-ratio: 3/4;
  border-radius: var(--r-xl);
  overflow: hidden;
  display: block;
  background: var(--c-brown);
  transition: transform var(--tr-base);
}
.collection-card:hover { transform: translateY(-8px); }
.collection-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .7s cubic-bezier(.2,.7,.2,1);
}
.collection-card:hover img { transform: scale(1.08); }

.collection-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(42,20,8,.95) 0%, rgba(42,20,8,.3) 60%, transparent 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--sp-6);
  color: var(--c-cream);
}
.collection-card__overlay .count {
  display: inline-block;
  background: rgba(232,155,60,.2);
  color: var(--c-orange-light);
  padding: 4px 12px;
  border-radius: var(--r-full);
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: var(--sp-3);
  align-self: flex-start;
}
.collection-card__overlay h3 {
  color: var(--c-cream);
  font-size: 1.8rem;
  margin-bottom: var(--sp-2);
}
.collection-card__overlay p {
  color: rgba(250,244,232,.85);
  font-size: .95rem;
  margin-bottom: var(--sp-4);
}
.collection-card__overlay .arrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-weight: 600;
  color: var(--c-orange);
  transition: gap var(--tr-fast);
}
.collection-card:hover .arrow { gap: var(--sp-3); }

/* ==========================================================================
   5. COUNTDOWN OFFRE FLASH
   ========================================================================== */
.flash-deal {
  background: linear-gradient(135deg, var(--c-brown-deep) 0%, var(--c-brown) 100%);
  color: var(--c-cream);
  border-radius: var(--r-xl);
  padding: clamp(2rem, 4vw, 3.5rem);
  position: relative;
  overflow: hidden;
}
.flash-deal::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("../images/pattern-leaves.svg");
  background-size: 300px;
  opacity: .1;
}
.flash-deal__inner {
  position: relative;
  z-index: 2;
  display: grid;
  gap: var(--sp-6);
  align-items: center;
}
@media (min-width: 768px) {
  .flash-deal__inner { grid-template-columns: 1.3fr 1fr; }
}

.flash-deal__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  background: var(--c-orange);
  color: var(--c-brown-deep);
  padding: 6px 16px;
  border-radius: var(--r-full);
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: var(--sp-4);
}
.flash-deal__badge .lightning {
  animation: lightning 1.5s infinite;
}
@keyframes lightning {
  0%, 100% { opacity: 1; }
  50% { opacity: .5; transform: rotate(-5deg); }
}

.flash-deal h2 {
  color: var(--c-cream);
  font-size: clamp(2rem, 3vw, 2.8rem);
  margin-bottom: var(--sp-3);
}
.flash-deal p { color: rgba(250,244,232,.85); margin-bottom: var(--sp-5); }

.countdown {
  display: flex;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
  flex-wrap: wrap;
}
.countdown__unit {
  background: rgba(250,244,232,.12);
  border: 1px solid rgba(232,155,60,.3);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4);
  text-align: center;
  min-width: 72px;
  backdrop-filter: blur(8px);
}
.countdown__value {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 600;
  color: var(--c-orange);
  line-height: 1;
  display: block;
  font-variant-numeric: tabular-nums;
}
.countdown__label {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: rgba(250,244,232,.7);
  margin-top: 4px;
}

.flash-deal__product {
  background: rgba(250,244,232,.06);
  border: 1px solid rgba(232,155,60,.25);
  border-radius: var(--r-lg);
  overflow: hidden;
  backdrop-filter: blur(8px);
}
.flash-deal__product-img {
  aspect-ratio: 4/3;
  overflow: hidden;
}
.flash-deal__product-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.flash-deal__product-info {
  padding: var(--sp-4);
}
.flash-deal__product-info h4 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  color: var(--c-cream);
  margin-bottom: var(--sp-2);
}
.flash-deal__product-info .prices {
  display: flex;
  align-items: baseline;
  gap: var(--sp-2);
}
.flash-deal__product-info .now {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 600;
  color: var(--c-orange);
}
.flash-deal__product-info .was {
  color: rgba(250,244,232,.5);
  text-decoration: line-through;
}
.flash-deal__product-info .discount {
  background: var(--c-error);
  color: white;
  padding: 2px 8px;
  border-radius: var(--r-sm);
  font-size: .75rem;
  font-weight: 700;
}

/* ==========================================================================
   6. BLOG / ARTICLES & ACTUALITÉS
   ========================================================================== */
.blog-grid {
  display: grid;
  gap: var(--sp-5);
  grid-template-columns: 1fr;
}
@media (min-width: 768px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .blog-grid { grid-template-columns: repeat(3, 1fr); } }

/* Article hero (premier article featured) */
.blog-featured {
  display: grid;
  gap: var(--sp-6);
  margin-bottom: var(--sp-7);
}
@media (min-width: 880px) { .blog-featured { grid-template-columns: 1.2fr 1fr; align-items: center; } }

.blog-featured__visual {
  aspect-ratio: 4/3;
  border-radius: var(--r-xl);
  overflow: hidden;
  position: relative;
}
.blog-featured__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .8s cubic-bezier(.2,.7,.2,1);
}
.blog-featured:hover .blog-featured__visual img { transform: scale(1.05); }
.blog-featured__visual .badge {
  position: absolute;
  top: var(--sp-4);
  left: var(--sp-4);
  background: var(--c-orange);
  color: var(--c-brown-deep);
  padding: 6px 14px;
  border-radius: var(--r-full);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.blog-featured__content .meta {
  display: flex;
  gap: var(--sp-3);
  align-items: center;
  font-size: .85rem;
  color: var(--c-text-soft);
  margin-bottom: var(--sp-3);
}
.blog-featured__content .meta .dot { color: var(--c-orange); }
.blog-featured__content h2 {
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  margin-bottom: var(--sp-4);
  line-height: 1.2;
}
.blog-featured__content h2 a { color: inherit; transition: color var(--tr-fast); }
.blog-featured__content h2 a:hover { color: var(--c-orange-dark); }
.blog-featured__content p {
  font-size: 1.05rem;
  color: var(--c-text-soft);
  margin-bottom: var(--sp-5);
  line-height: 1.7;
}

.blog-card {
  display: flex;
  flex-direction: column;
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: all var(--tr-base);
  height: 100%;
}
.blog-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--sh-md);
  border-color: var(--c-orange-light);
}
.blog-card__visual {
  aspect-ratio: 16/10;
  overflow: hidden;
  position: relative;
}
.blog-card__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .7s cubic-bezier(.2,.7,.2,1);
}
.blog-card:hover .blog-card__visual img { transform: scale(1.07); }
.blog-card__cat {
  position: absolute;
  top: var(--sp-3);
  left: var(--sp-3);
  background: rgba(42,20,8,.85);
  color: var(--c-orange-light);
  padding: 4px 12px;
  border-radius: var(--r-full);
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  backdrop-filter: blur(8px);
}
.blog-card__body {
  padding: var(--sp-5);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.blog-card__meta {
  display: flex;
  gap: var(--sp-2);
  align-items: center;
  font-size: .8rem;
  color: var(--c-text-soft);
}
.blog-card__meta .dot::before { content: "•"; color: var(--c-orange); margin: 0 6px; }
.blog-card__title {
  font-family: var(--font-display);
  font-size: 1.35rem;
  line-height: 1.25;
  color: var(--c-brown-deep);
  margin: 0;
}
.blog-card__title a { color: inherit; transition: color var(--tr-fast); }
.blog-card__title a:hover { color: var(--c-orange-dark); }
.blog-card__excerpt {
  color: var(--c-text-soft);
  font-size: .95rem;
  line-height: 1.65;
  margin: 0;
}
.blog-card__more {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  color: var(--c-orange-dark);
  font-weight: 600;
  font-size: .9rem;
  transition: gap var(--tr-fast);
}
.blog-card__more:hover { gap: var(--sp-3); color: var(--c-orange-dark); }

/* ==========================================================================
   7. INSTAGRAM / SOCIAL FEED
   ========================================================================== */
.insta-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-2);
}
@media (min-width: 640px) { .insta-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 960px) { .insta-grid { grid-template-columns: repeat(6, 1fr); } }
.insta-item {
  aspect-ratio: 1;
  overflow: hidden;
  position: relative;
  border-radius: var(--r-md);
}
.insta-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}
.insta-item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(107,52,16,.6);
  opacity: 0;
  transition: opacity var(--tr-fast);
}
.insta-item:hover img { transform: scale(1.1); }
.insta-item:hover::after { opacity: 1; }
.insta-item .ic {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  opacity: 0;
  transition: opacity var(--tr-fast);
  z-index: 2;
}
.insta-item:hover .ic { opacity: 1; }

/* ==========================================================================
   8. POPUP NEWSLETTER (modale marketing)
   ========================================================================== */
.popup-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(42,20,8,.7);
  backdrop-filter: blur(6px);
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
  transition: all .4s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-4);
}
.popup-backdrop.is-open {
  opacity: 1;
  visibility: visible;
}

.popup {
  background: var(--c-cream);
  border-radius: var(--r-xl);
  max-width: 540px;
  width: 100%;
  overflow: hidden;
  position: relative;
  transform: scale(.9) translateY(20px);
  transition: transform .5s cubic-bezier(.2,.9,.3,1.2);
  box-shadow: 0 30px 80px rgba(0,0,0,.4);
}
.popup-backdrop.is-open .popup { transform: scale(1) translateY(0); }

.popup__close {
  position: absolute;
  top: var(--sp-3);
  right: var(--sp-3);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,.9);
  color: var(--c-brown-deep);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: all var(--tr-fast);
}
.popup__close:hover {
  background: var(--c-orange);
  transform: rotate(90deg);
}

.popup__visual {
  background: linear-gradient(135deg, var(--c-brown) 0%, var(--c-brown-dark) 100%);
  padding: var(--sp-7) var(--sp-5);
  text-align: center;
  color: var(--c-cream);
  position: relative;
  overflow: hidden;
}
.popup__visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("../images/pattern-leaves.svg");
  background-size: 200px;
  opacity: .2;
}
.popup__visual-content { position: relative; z-index: 2; }
.popup__discount {
  font-family: var(--font-display);
  font-size: clamp(3.5rem, 8vw, 5rem);
  font-weight: 700;
  line-height: 1;
  color: var(--c-orange);
  margin-bottom: var(--sp-2);
}
.popup__discount-label {
  font-size: .85rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--c-orange-light);
  font-weight: 600;
}

.popup__body {
  padding: var(--sp-6) var(--sp-5);
  text-align: center;
}
.popup__body h2 {
  font-size: 1.6rem;
  margin-bottom: var(--sp-3);
  color: var(--c-brown-deep);
}
.popup__body p {
  color: var(--c-text-soft);
  margin-bottom: var(--sp-5);
  font-size: .95rem;
}
.popup__form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.popup__form input {
  padding: .9em 1.2em;
  border: 1.5px solid var(--c-border);
  border-radius: var(--r-full);
  font-family: inherit;
  font-size: .95rem;
  text-align: center;
}
.popup__form input:focus {
  outline: none;
  border-color: var(--c-orange);
  box-shadow: 0 0 0 3px rgba(232,155,60,.18);
}
.popup__nope {
  background: none;
  border: none;
  color: var(--c-text-soft);
  font-size: .85rem;
  margin-top: var(--sp-4);
  cursor: pointer;
  text-decoration: underline;
}
.popup__nope:hover { color: var(--c-brown-deep); }

/* ==========================================================================
   9. SCROLL REVEAL ANIMATIONS
   ========================================================================== */
[data-reveal] {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);
}
[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}
[data-reveal="fade"] { transform: none; }
[data-reveal="left"] { transform: translateX(-40px); }
[data-reveal="left"].is-visible { transform: translateX(0); }
[data-reveal="right"] { transform: translateX(40px); }
[data-reveal="right"].is-visible { transform: translateX(0); }
[data-reveal="scale"] { transform: scale(.95); }
[data-reveal="scale"].is-visible { transform: scale(1); }

[data-reveal-delay="1"] { transition-delay: .1s; }
[data-reveal-delay="2"] { transition-delay: .2s; }
[data-reveal-delay="3"] { transition-delay: .3s; }
[data-reveal-delay="4"] { transition-delay: .4s; }
[data-reveal-delay="5"] { transition-delay: .5s; }

/* Parallax léger */
[data-parallax] { will-change: transform; transition: transform .1s linear; }

/* ==========================================================================
   10. PAGE TRANSITIONS (fade entre pages)
   ========================================================================== */
.page-transition {
  position: fixed;
  inset: 0;
  background: var(--c-brown-deep);
  z-index: 9999;
  transform: translateY(100%);
  transition: transform .6s cubic-bezier(.7,0,.3,1);
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-transition.is-active {
  transform: translateY(0);
}
.page-transition__logo {
  width: 200px;
  opacity: 0;
  transition: opacity .3s ease .2s;
}
.page-transition.is-active .page-transition__logo { opacity: 1; }

/* Fade-in initial du body */
body { animation: bodyFadeIn .6s ease; }
@keyframes bodyFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ==========================================================================
   11. EFFETS HOVER PRODUITS AMÉLIORÉS
   ========================================================================== */
.product-card .product-media { position: relative; }

.product-card .product-quick-actions {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--sp-3);
  display: flex;
  gap: var(--sp-2);
  justify-content: center;
  transform: translateY(100%);
  transition: transform .35s cubic-bezier(.2,.7,.2,1);
  background: linear-gradient(to top, rgba(42,20,8,.9), transparent);
}
.product-card:hover .product-quick-actions {
  transform: translateY(0);
}
.product-card .product-quick-actions button {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--c-cream);
  color: var(--c-brown-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all var(--tr-fast);
}
.product-card .product-quick-actions button:hover {
  background: var(--c-orange);
  transform: scale(1.1);
}

/* Ombre dorée au hover */
.product-card { transition: all .35s cubic-bezier(.2,.7,.2,1); }
.product-card:hover {
  box-shadow: 0 16px 40px rgba(232,155,60,.18), 0 4px 12px rgba(61,31,8,.08);
}

/* ==========================================================================
   12. BACK-TO-TOP BOUTON
   ========================================================================== */
.back-to-top {
  position: fixed;
  bottom: 100px;
  right: 24px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--c-brown-deep);
  color: var(--c-orange);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--sh-md);
  z-index: 90;
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
  transition: all .3s ease;
}
.back-to-top.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.back-to-top:hover {
  background: var(--c-orange);
  color: var(--c-brown-deep);
  transform: translateY(-4px);
}

/* ==========================================================================
   13. RESPONSIVE FINE-TUNING
   ========================================================================== */
@media (max-width: 640px) {
  .hero-slide__title { font-size: clamp(2.2rem, 8vw, 3rem); }
  .hero-slide__lead { font-size: 1rem; }
  .countdown__unit { padding: var(--sp-2) var(--sp-3); min-width: 60px; }
  .countdown__value { font-size: 1.6rem; }
  .flash-deal { padding: var(--sp-5) var(--sp-4); }
  .carousel-controls .view-all { display: none; }
}

/* ==========================================================================
   14. CHARGEMENT / SKELETON
   ========================================================================== */
.skeleton {
  background: linear-gradient(90deg, var(--c-cream-2) 0%, var(--c-border) 50%, var(--c-cream-2) 100%);
  background-size: 200% 100%;
  animation: skeletonShimmer 1.5s infinite;
  border-radius: var(--r-md);
}
@keyframes skeletonShimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ==========================================================================
   15. REDUCED MOTION (accessibilité)
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
  .swiper-slide-active .hero-slide__eyebrow,
  .swiper-slide-active .hero-slide__title,
  .swiper-slide-active .hero-slide__lead,
  .swiper-slide-active .hero-slide__actions,
  .swiper-slide-active .hero-slide__price-tag,
  [data-reveal] {
    transition-duration: .01ms !important;
    transition-delay: 0 !important;
    transform: none !important;
    opacity: 1 !important;
  }
  .pulseDot, .lightning { animation: none !important; }
}
