/* Minimal custom polish on top of Tailwind utilities. */

:root {
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

/* Premium reveal animation (IntersectionObserver toggles .is-visible). */
.reveal {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out);
  will-change: opacity, transform;
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Subtle glass effect helper (used on a few cards). */
.glass {
  background: rgba(255, 255, 255, 0.65);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(226, 232, 240, 0.7);
}

/* Smooth focus for all browsers. */
:focus-visible {
  outline: none;
}

/* Home hero dashboard callouts: calm motion + refined depth. */
.hero-callout {
  transform: translate3d(0, 0, 0);
  will-change: transform;
}

@keyframes heroFloat {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(0, -4px, 0);
  }
}

@media (prefers-reduced-motion: no-preference) {
  .hero-float {
    animation: heroFloat 7.5s ease-in-out infinite;
  }
  .hero-float-slow {
    animation: heroFloat 10s ease-in-out infinite reverse;
  }
}

/* WhatsApp widget micro-interactions */
[data-wa-widget] {
  transition: transform 380ms ease-in, opacity 380ms ease-in;
  transform: translate3d(0, 0, 0);
  will-change: transform, opacity;
}

[data-wa-widget].wa-dismissed {
  transform: translate3d(0, 120px, 0) scale(0.96);
  opacity: 0;
  pointer-events: none;
}

[data-wa-widget-toggle] [data-wa-icon] {
  transition: transform 260ms var(--ease-out), opacity 220ms var(--ease-out);
  transform-origin: center;
}

[data-wa-widget-toggle] {
  touch-action: none;
  -webkit-user-select: none;
  user-select: none;
  cursor: grab;
  will-change: transform;
}

[data-wa-widget-toggle].is-dragging {
  cursor: grabbing;
}

@media (min-width: 768px) {
  /* Desktop-only dismiss control: appears when hovering the widget area. */
  [data-wa-widget]:hover [data-wa-widget-dismiss],
  [data-wa-widget]:focus-within [data-wa-widget-dismiss] {
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  .reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  .hero-float,
  .hero-float-slow {
    animation: none !important;
  }
  [data-wa-widget],
  [data-wa-widget-toggle] [data-wa-icon],
  [data-wa-widget-dismiss] {
    transition: none !important;
  }
}

