@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-100px)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes glowPulse{0%,to{box-shadow:0 0 20px #8b5cf64d}50%{box-shadow:0 0 40px #8b5cf699}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes typewriter{0%{width:0}to{width:100%}}@keyframes blinkCursor{0%,to{border-color:#0000}50%{border-color:#8b5cf6}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes rotateIn{0%{opacity:0;transform:rotate(-360deg)scale(0)}to{opacity:1;transform:rotate(0)scale(1)}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.animate-float{animation:4s ease-in-out infinite float}.animate-slide-in-left{animation:.6s ease-out slideInFromLeft}.animate-slide-in-right{animation:.6s ease-out slideInFromRight}.animate-glow-pulse{animation:2s ease-in-out infinite glowPulse}.animate-scale-in{animation:.5s ease-out scaleIn}.animate-bounce-in{animation:.8s cubic-bezier(.68,-.55,.265,1.55) bounceIn}.animate-rotate-in{animation:.6s ease-out rotateIn}.animate-shimmer{background:linear-gradient(90deg,#fff0 0%,#fff6 20%,#fffc 60%,#fff0) 0 0/200%;animation:2s linear infinite shimmer}.animate-gradient{background-size:400% 400%;animation:3s infinite gradientShift}.timeline-card:hover{transition:all .3s cubic-bezier(.4,0,.2,1);transform:translateY(-8px)scale(1.02)}.timeline-card:hover .tech-icon{animation:.6s infinite bounce}.timeline-card:hover .commit-hash{animation:1s linear infinite shimmer}.glass-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff40;border:1px solid #ffffff2e}.neon-glow{filter:drop-shadow(0 0 10px #8b5cf680)}.neon-glow:hover{filter:drop-shadow(0 0 20px #8b5cf6cc);transition:filter .3s}.bg-element{opacity:.1;border-radius:50%;animation:6s ease-in-out infinite float;position:absolute}.bg-element:first-child{animation-duration:8s;animation-delay:0s}.bg-element:nth-child(2){animation-duration:10s;animation-delay:2s}.bg-element:nth-child(3){animation-duration:12s;animation-delay:4s}.timeline-line{background:linear-gradient(#8b5cf6,#06b6d4,#10b981) 0 0/100% 200%;animation:4s infinite gradientShift}.timeline-item:first-child{animation-delay:.1s}.timeline-item:nth-child(2){animation-delay:.2s}.timeline-item:nth-child(3){animation-delay:.3s}.timeline-item:nth-child(4){animation-delay:.4s}.timeline-item:nth-child(5){animation-delay:.5s}.timeline-item:nth-child(6){animation-delay:.6s}.timeline-item:nth-child(7){animation-delay:.7s}.timeline-item:nth-child(8){animation-delay:.8s}.timeline-item:nth-child(9){animation-delay:.9s}@media (max-width:768px){.timeline-card{transform:none!important}.timeline-card:hover{transform:translateY(-4px)!important}}@media (prefers-color-scheme:dark){.glass-card{background:#11182740;border:1px solid #ffffff1a}}
