@keyframes arrowPulse {
  0%   { transform: translateY(0);   opacity: 0.35; }
  50%  { transform: translateY(8px); opacity: 1; }
  100% { transform: translateY(0);   opacity: 0.35; }
}

@keyframes beanFloatY {
  0%   { transform: translateY(0); }
  50%  { transform: translateY(0px); }
  100% { transform: translateY(0); }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .hero__scroll-arrow,
  .bean{
    animation: none !important;
  }
}
.accords-reveal{
  width: 220px;      /* tweak */
  max-width: 100%;
  height: auto;

  opacity: 0;
  transform: translateY(14px) scale(0.98);
  transition:
    opacity 600ms cubic-bezier(.2,.8,.2,1),
    transform 600ms cubic-bezier(.2,.8,.2,1);
  will-change: opacity, transform;
}

.accords-reveal.is-visible{
  opacity: 1;
  transform: translateY(0) scale(1);
}

@media (prefers-reduced-motion: reduce){
  .accords-reveal{
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
  }
}