Ullubuzzcom New May 2026

/* Grid Pattern */ .grid-pattern { background-image: linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px); background-size: 60px 60px; }

/* Toast */ .toast { position: fixed; bottom: 2rem; right: 2rem; padding: 1rem 1.5rem; border-radius: 1rem; z-index: 9999; transform: translateY(120%); opacity: 0; transition: all 0.5s cubic-bezier(0.17, 0.55, 0.55, 1); } .toast.show { transform: translateY(0); opacity: 1; } ullubuzzcom new

/* Animations */ @keyframes float { 0%, 100% { transform: translateY(0) rotate(0deg); } 25% { transform: translateY(-20px) rotate(2deg); } 50% { transform: translateY(-10px) rotate(0deg); } 75% { transform: translateY(-25px) rotate(-2deg); } } @keyframes morph { 0%, 100% { border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%; } 50% { border-radius: 50% 60% 30% 60% / 30% 60% 70% 40%; } } @keyframes pulse-glow { 0%, 100% { opacity: 0.4; transform: scale(1); } 50% { opacity: 0.8; transform: scale(1.05); } } @keyframes rotate-slow { from { transform: rotate(0deg); } to { transform: rotate(360deg); } } @keyframes rotate-reverse { from { transform: rotate(360deg); } to { transform: rotate(0deg); } } @keyframes fade-up { from { opacity: 0; transform: translateY(60px); } to { opacity: 1; transform: translateY(0); } } @keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } } @keyframes shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } } @keyframes count-pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.1); } } /* Grid Pattern */