[data-aos][data-aos][data-aos-delay="400"].aos-animate, body[data-aos-delay="400"] [data-aos].aos-animate {
    transition-delay: 0.4s;
}
body {
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safe-area-inset-bottom);
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
}
/* 4. Momentum scrolling en contenedores scroll */
.overflow-x-auto,
.overflow-y-auto,
.scrollbar-hidden {
  -webkit-overflow-scrolling: touch;
}
/* 5. backdrop-filter - prefijo webkit necesario en Safari */
.backdrop-blur-3xl,
.backdrop-blur-sm {
  -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

a,
button,
[role="button"],
.cursor-pointer {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0.05);
}
.dark a,
.dark button,
.dark [role="button"],
.dark .cursor-pointer {
  -webkit-tap-highlight-color: rgba(255, 255, 255, 0.08);
}
/* 10. Prevenir text-size-adjust en landscape */
body {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
@supports (-webkit-touch-callout: none) {
  .gradient-text,
  .gradient-text-light,
  .dark\:gradient-text:is(.dark *) {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
/* 12. Smooth scroll con reducción de movimiento */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .animate-scroll-up,
  .animate-scroll-down {
    animation: none;
  }

  .transition,
  .transition-all,
  .transition-colors,
  .transition-opacity,
  .transition-transform {
    transition-duration: 0.01ms !important;
  }
}
.theme-transition, .theme-transition * {
  -webkit-transition-duration: 1s;
  transition-duration: 1s;
  -webkit-transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  -webkit-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
  transition-timing-function: cubic-bezier(.4, 0, .2, 1);
}
