/* ============================================================
   Mocktailspirit — Effets visuels modernes (2026)
   Chargé après styles.css dans base.twig.
   Tous les effets respectent prefers-reduced-motion.
   ============================================================ */

/* ====== 1. SMOOTH SCROLL + sélection custom ====== */
html { scroll-behavior: smooth; }
::selection {
  background: var(--color-primary, #D67A3C);
  color: #fff;
}
::-moz-selection {
  background: var(--color-primary, #D67A3C);
  color: #fff;
}

/* ====== 2. HEADER glassmorphism au scroll ====== */
.topbar {
  transition: background .35s ease, backdrop-filter .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.topbar.is-scrolled {
  background: rgba(254, 250, 240, 0.78);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  box-shadow: 0 6px 30px rgba(30, 51, 41, 0.08);
  border-bottom: 1px solid rgba(30, 51, 41, 0.06);
}

/* ====== 3. SCROLL REVEAL (data-reveal) ====== */
[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity .8s cubic-bezier(.2, .9, .3, 1),
    transform .8s cubic-bezier(.2, .9, .3, 1);
  will-change: transform, opacity;
}
[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}
[data-reveal-delay="1"].is-visible { transition-delay: .08s; }
[data-reveal-delay="2"].is-visible { transition-delay: .16s; }
[data-reveal-delay="3"].is-visible { transition-delay: .24s; }
[data-reveal-delay="4"].is-visible { transition-delay: .32s; }
[data-reveal-delay="5"].is-visible { transition-delay: .40s; }

/* ====== 4. CTA bouton magnétique / gradient animé ====== */
.btn-primary,
.header-cta,
.cookie-btn-accept {
  position: relative;
  overflow: hidden;
  transition: transform .25s cubic-bezier(.2,.9,.3,1.4), box-shadow .25s, color .25s;
  z-index: 1;
}
.btn-primary::before,
.header-cta::before,
.cookie-btn-accept::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, var(--color-primary, #D67A3C) 0%, #E89860 50%, var(--color-primary, #D67A3C) 100%);
  background-size: 200% 100%;
  animation: shimmerBtn 3s ease-in-out infinite;
  z-index: -1;
  opacity: 0;
  transition: opacity .3s;
}
.btn-primary:hover::before,
.header-cta:hover::before,
.cookie-btn-accept:hover::before {
  opacity: 1;
}
.btn-primary:hover,
.header-cta:hover,
.cookie-btn-accept:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 16px 36px rgba(214, 122, 60, 0.36);
}
.btn-primary:active,
.header-cta:active {
  transform: translateY(0) scale(.98);
}
@keyframes shimmerBtn {
  0%, 100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}

/* ====== 5. CARTES — hover lift universal ====== */
.product-card,
.recipe-card,
.brand-tile,
.guide-card,
.archive-card {
  transition:
    transform .4s cubic-bezier(.2,.9,.3,1.2),
    box-shadow .4s ease,
    border-color .3s;
  will-change: transform;
}
.product-card:hover,
.recipe-card:hover,
.brand-tile:hover,
.guide-card:hover,
.archive-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 24px 60px rgba(30, 51, 41, 0.16);
}

/* ====== 6. LINKS — underline qui glisse ====== */
.foot a:not(.related-card):not(.cookie-btn),
.breadcrumb a {
  position: relative;
  text-decoration: none;
  background-image: linear-gradient(currentColor, currentColor);
  background-size: 0% 1.5px;
  background-position: 0 100%;
  background-repeat: no-repeat;
  transition: background-size .4s cubic-bezier(.2,.9,.3,1);
}
.foot a:not(.related-card):not(.cookie-btn):hover,
.breadcrumb a:hover {
  background-size: 100% 1.5px;
}

/* ====== 7. IMAGES — zoom doux au hover sur conteneurs hover-image ====== */
.hover-zoom {
  overflow: hidden;
  display: block;
}
.hover-zoom img {
  transition: transform .8s cubic-bezier(.2,.9,.3,1);
  will-change: transform;
}
.hover-zoom:hover img {
  transform: scale(1.06);
}

/* ====== 8. HERO — léger float du visuel ====== */
.hero-visual {
  animation: floatHero 7s ease-in-out infinite;
}
@keyframes floatHero {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-12px); }
}

/* ====== 9. EYEBROW — pulse dot ====== */
.eyebrow .dot,
.hero-eyebrow .dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--color-primary, #D67A3C);
  margin-right: 8px;
  animation: dotPulse 2.5s ease-in-out infinite;
  vertical-align: middle;
}
@keyframes dotPulse {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(214, 122, 60, 0.55);
  }
  50% {
    transform: scale(1.15);
    box-shadow: 0 0 0 8px rgba(214, 122, 60, 0);
  }
}

/* ====== 10. SECTION HEAD — display titles avec underline animé ====== */
.display-md::after,
.display-lg::after {
  content: '';
  display: block;
  width: 60px;
  height: 3px;
  margin-top: 14px;
  background: linear-gradient(90deg, var(--color-primary, #D67A3C) 0%, transparent 100%);
  border-radius: 2px;
  transform-origin: left;
  animation: titleUnderline 1.5s cubic-bezier(.2,.9,.3,1) .2s both;
}
@keyframes titleUnderline {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

/* ====== 11. NEWSLETTER / FORMS — input focus glow ====== */
input[type="email"]:focus,
input[type="text"]:focus,
textarea:focus {
  outline: none;
  box-shadow: 0 0 0 4px rgba(214, 122, 60, 0.15), 0 0 0 1px var(--color-primary, #D67A3C);
  transition: box-shadow .25s;
}

/* ====== 12. BADGES / pills — entrée ressort ====== */
.badge,
.related-product-rating,
.score-global {
  animation: badgePop .5s cubic-bezier(.2,.9,.3,1.6);
}
@keyframes badgePop {
  0%   { transform: scale(.6); opacity: 0; }
  60%  { transform: scale(1.08); opacity: 1; }
  100% { transform: scale(1); }
}

/* ====== 13. STATS HERO — count-up shine ====== */
.stat .v {
  background: linear-gradient(135deg, var(--color-ink, #1E3329) 0%, var(--color-primary, #D67A3C) 100%);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

/* ====== 14. BREADCRUMB — séparateur élégant ====== */
.breadcrumb .sep {
  color: var(--color-ink-muted, #9098B8);
  opacity: 0.5;
  margin: 0 8px;
}

/* ====== 15. SCROLL-TO-TOP button ====== */
.scroll-top {
  position: fixed;
  right: 24px;
  bottom: 24px;
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--color-ink, #1E3329);
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  box-shadow: 0 8px 24px rgba(30, 51, 41, 0.28);
  opacity: 0;
  pointer-events: none;
  transform: translateY(20px);
  transition: opacity .3s, transform .3s, background .25s;
  z-index: 90;
}
.scroll-top.visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.scroll-top:hover {
  background: var(--color-primary, #D67A3C);
  transform: translateY(-4px) scale(1.05);
}

/* ====== 16. NOISE / TEXTURE subtile sur hero ====== */
.archive-hero,
.hero {
  position: relative;
}
.archive-hero::after,
.hero::after {
  content: '';
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' /%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
  opacity: 0.04;
  pointer-events: none;
  mix-blend-mode: multiply;
}

/* ====== 17. ARTICLE BODY — first paragraph drop cap ====== */
.article-body > p:first-of-type::first-letter {
  font-family: 'DM Serif Display', serif;
  font-size: 4.2rem;
  font-weight: 400;
  float: left;
  line-height: 0.9;
  margin: 8px 12px 0 0;
  color: var(--color-primary, #D67A3C);
}

/* ====== 18. ARTICLE BODY — links underline élégant ====== */
.article-body a {
  color: var(--color-primary, #D67A3C);
  background-image: linear-gradient(to right, var(--color-primary, #D67A3C), var(--color-primary, #D67A3C));
  background-position: 0 100%;
  background-size: 100% 1.5px;
  background-repeat: no-repeat;
  text-decoration: none;
  transition: background-size .25s, color .2s;
}
.article-body a:hover {
  color: var(--color-ink, #1E3329);
  background-size: 0% 1.5px;
}

/* ====== 19. LOADING shimmer pour cards en chargement ====== */
@keyframes shimmerSkeleton {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
.skeleton {
  background: linear-gradient(90deg,
    rgba(30,51,41,0.06) 25%,
    rgba(30,51,41,0.12) 50%,
    rgba(30,51,41,0.06) 75%
  );
  background-size: 200% 100%;
  animation: shimmerSkeleton 1.4s ease-in-out infinite;
  border-radius: 8px;
}

/* ====== 20. PRIX produit — number ticker effect ====== */
.related-product-price,
.product-card .price {
  display: inline-block;
  transition: transform .25s cubic-bezier(.2,.9,.3,1.5), color .25s;
}
.related-product-card:hover .related-product-price,
.product-card:hover .price {
  transform: scale(1.08);
  color: var(--color-primary, #D67A3C);
}

/* ============================================================
   RESPECT prefers-reduced-motion (accessibilité)
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  [data-reveal] {
    opacity: 1 !important;
    transform: none !important;
  }
}
