/* ================================
   SESSE & CO — Premium Layer
   ================================ */

/* ── NO SCROLL PENDANT PRELOADER ── */
body.no-scroll { overflow: hidden; }

/* ── PRELOADER ────────────────── */
#preloader {
  position: fixed;
  inset: 0;
  background: var(--text);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 20px;
  transition: opacity 0.8s ease, visibility 0.8s ease;
}

#preloader.hide {
  opacity: 0;
  visibility: hidden;
}

.pre-monogram {
  display: flex;
  gap: 0;
  margin-bottom: 8px;
}

.pre-letter {
  font-family: 'Cormorant Garamond', serif;
  font-size: 3.5rem;
  font-weight: 600;
  color: var(--white);
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
  letter-spacing: 6px;
}

.pre-letter.visible {
  opacity: 1;
  transform: translateY(0);
}

.pre-line {
  width: 0;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--gold), transparent);
  transition: width 0.6s ease;
}

.pre-line.visible { width: 120px; }

.pre-tagline {
  font-family: 'Jost', sans-serif;
  font-size: 0.65rem;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  opacity: 0;
  transition: opacity 0.5s ease;
}

.pre-tagline.visible { opacity: 1; }

/* ── CURSEUR CUSTOM ──────────────── */
* { cursor: none !important; }

#cursor {
  position: fixed;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(155, 27, 27, 0.6);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9998;
  transform: translate(-50%, -50%);
  transition: width 0.3s ease, height 0.3s ease, border-color 0.3s ease, background 0.3s ease;
}

#cursorDot {
  position: fixed;
  width: 5px;
  height: 5px;
  background: var(--red);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  transition: transform 0.1s ease;
}

#cursor.expand {
  width: 56px;
  height: 56px;
  border-color: var(--gold);
  background: rgba(184, 147, 74, 0.05);
}

#cursor.click {
  width: 28px;
  height: 28px;
}

@media (max-width: 768px) {
  * { cursor: auto !important; }
  #cursor, #cursorDot { display: none; }
}

/* ── HEADER SCROLLED ──────────────── */
.header {
  transition: box-shadow 0.4s ease, background 0.4s ease;
}

.header.scrolled {
  box-shadow: 0 4px 30px rgba(30, 16, 16, 0.12);
  background: rgba(254, 252, 248, 0.98);
}

/* ── SCROLL REVEAL ────────────────── */
.reveal,
.reveal-left,
.reveal-right,
.reveal-up,
.stagger-item {
  opacity: 0;
  transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1),
              transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.reveal        { transform: translateY(40px); }
.reveal-left   { transform: translateX(-50px); }
.reveal-right  { transform: translateX(50px); }
.reveal-up     { transform: translateY(60px); }
.stagger-item  { transform: translateY(30px); }

.reveal.revealed,
.reveal-left.revealed,
.reveal-right.revealed,
.reveal-up.revealed,
.stagger-item.revealed {
  opacity: 1;
  transform: translate(0);
}

/* ── HERO PREMIUM ─────────────────── */
.hero {
  min-height: 100vh;
  padding: 0;
  overflow: hidden;
  position: relative;
}

.hero-content {
  padding: 140px 60px 100px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.hero-image {
  overflow: hidden;
}

.hero-img {
  height: 100vh;
  transform-origin: center;
  transition: transform 0.1s linear;
}

/* MOTS ANIMÉS */
.word {
  display: inline-block;
  overflow: hidden;
}

.anim-word {
  animation: wordReveal 0.9s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes wordReveal {
  from {
    opacity: 0;
    transform: translateY(100%) skewY(5deg);
  }
  to {
    opacity: 1;
    transform: translateY(0) skewY(0deg);
  }
}

/* Ligne décorative hero */
.hero-eyebrow::before,
.hero-eyebrow::after {
  transition: width 1s ease;
}

/* ── PRODUITS PREMIUM ─────────────── */
.product-card {
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1),
              box-shadow 0.4s ease !important;
  transform-style: preserve-3d;
  will-change: transform;
}

.product-image-wrap img {
  transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.product-card:hover .product-image-wrap img {
  transform: scale(1.1) !important;
}

/* Overlay produit au hover */
.product-image-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(30,16,16,0.4) 0%, transparent 60%);
  opacity: 0;
  transition: opacity 0.4s ease;
}

.product-card:hover .product-image-wrap::after { opacity: 1; }

/* ── CATÉGORIES PREMIUM ───────────── */
.category-card img {
  transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.category-card:hover img {
  transform: scale(1.08) !important;
}

/* ── HERO BADGE ANIMÉ ─────────────── */
.hero-badge {
  animation: badgeFloat 3s ease-in-out infinite;
}

@keyframes badgeFloat {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-8px); }
}

/* ── TRUST BAR ICÔNES ─────────────── */
.trust-icon {
  transition: transform 0.3s ease;
}

.trust-item:hover .trust-icon {
  transform: scale(1.15) rotate(-5deg);
}

/* ── BANDEAU TICKER ───────────────── */
.announcement-bar {
  background: linear-gradient(90deg, #7A1515, var(--red), #7A1515);
}

/* ── BOUTONS PREMIUM ──────────────── */
.btn-primary {
  position: relative;
  overflow: hidden;
}

.btn-primary::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
  transition: left 0.5s ease;
}

.btn-primary:hover::before { left: 100%; }

/* ── SECTION ABOUT ────────────────── */
.about-img-frame img {
  transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.about-img-frame:hover img {
  transform: scale(1.03);
}

/* ── PROMO BANNER ─────────────────── */
.promo-banner {
  background: linear-gradient(135deg, #7A1515 0%, var(--red) 50%, #7A1515 100%);
  background-size: 200% 200%;
  animation: gradientShift 6s ease infinite;
}

@keyframes gradientShift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* ── SCROLL INDICATOR HERO ────────── */
.scroll-indicator {
  position: absolute;
  bottom: 36px;
  left: 60px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: var(--text-light);
  font-size: 0.65rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  font-family: 'Jost', sans-serif;
  animation: fadeInUp 1s ease 2s both;
}

.scroll-line {
  width: 1px;
  height: 50px;
  background: linear-gradient(to bottom, var(--gold), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}

@keyframes scrollPulse {
  0%, 100% { transform: scaleY(1); opacity: 1; }
  50%       { transform: scaleY(0.6); opacity: 0.5; }
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── WHATSAPP PULSE ───────────────── */
.whatsapp-float::before {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: rgba(37, 211, 102, 0.3);
  animation: waPulse 2s ease-in-out infinite;
}

.whatsapp-float { position: fixed; }

@keyframes waPulse {
  0%, 100% { transform: scale(1); opacity: 0.7; }
  50%       { transform: scale(1.3); opacity: 0; }
}

/* ── STAT NUMBERS ─────────────────── */
.stat-number {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem;
  font-weight: 700;
  color: var(--red);
  display: block;
}

/* ── FOOTER REVEAL ────────────────── */
.footer {
  position: relative;
  overflow: hidden;
}

.footer::before {
  content: 'S & C';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: 'Cormorant Garamond', serif;
  font-size: 20vw;
  font-weight: 700;
  color: rgba(255,255,255,0.02);
  white-space: nowrap;
  pointer-events: none;
  user-select: none;
}

/* ── PRODUCT BADGE SHIMMER ────────── */
.product-badge {
  position: relative;
  overflow: hidden;
}

.product-badge::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  animation: badgeShimmer 3s ease infinite;
}

@keyframes badgeShimmer {
  0%   { left: -100%; }
  40%, 100% { left: 160%; }
}

/* ── SECTION HEADER LIGNE DORÉE ───── */
.section-header::after {
  content: '';
  display: block;
  width: 40px;
  height: 1px;
  background: var(--gold);
  margin: 16px auto 0;
}

/* ── LOGO HOVER ───────────────────── */
.logo a:hover .logo-monogram {
  color: var(--gold);
  transition: color 0.3s ease;
}

@media (max-width: 768px) {
  .hero-content { padding: 100px 24px 60px; }
  .scroll-indicator { display: none; }
}
