/* Custom animations */ @keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } } /* Apply animation to card elements */ #ip-address, #location, #country, #isp, #timezone, #security { animation: fadeIn 0.5s ease-out forwards; } .delay-100 { animation-delay: 0.1s; } .delay-200 { animation-delay: 0.2s; } .delay-300 { animation-delay: 0.3s; } .delay-400 { animation-delay: 0.4s; } .delay-500 { animation-delay: 0.5s; } /* Custom scrollbar */ ::-webkit-scrollbar { width: 8px; height: 8px; } ::-webkit-scrollbar-track { background: #f1f1f1; } ::-webkit-scrollbar-thumb { background: #888; border-radius: 4px; } ::-webkit-scrollbar-thumb:hover { background: #555; } .dark ::-webkit-scrollbar-track { background: #2d3748; } .dark ::-webkit-scrollbar-thumb { background: #4a5568; } .dark ::-webkit-scrollbar-thumb:hover { background: #718096; } /* Smooth transitions for dark mode */ html { scroll-behavior: smooth; transition: background-color 0.3s ease; } body { transition: background-color 0.3s ease, color 0.3s ease; }