/* =============================================
   SKILLYARDS NEON - ANIMATIONS CSS
============================================= */

/* ---- Keyframe Library ---- */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeDown {
  from { opacity: 0; transform: translateY(-24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes glowPulse {
  0%,100% { opacity: 0.5; transform: scale(1); }
  50%      { opacity: 1; transform: scale(1.15); }
}
@keyframes bounce {
  0%,100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(12px); }
}
@keyframes blink {
  0%,100% { opacity: 1; }
  50%      { opacity: 0.2; }
}
@keyframes rotateSlow {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes particleFloat {
  0%   { transform: translateY(100vh); opacity: 0; }
  5%   { opacity: 1; }
  95%  { opacity: 0.6; }
  100% { transform: translateY(-5vh); opacity: 0; }
}
@keyframes neonFlicker {
  0%,19%,21%,23%,25%,54%,56%,100% { opacity: 1; text-shadow: 0 0 8px #00f5ff, 0 0 20px #00f5ff55; }
  20%,24%,55% { opacity: 0.7; text-shadow: none; }
}
  100% { top: 110%; }
}
@keyframes dataFlow {
  0%   { stroke-dashoffset: 1000; }
  100% { stroke-dashoffset: 0; }
}
@keyframes borderPulse {
  0%,100% { box-shadow: 0 0 8px #00f5ff, 0 0 20px #00f5ff33; }
  50%      { box-shadow: 0 0 15px #00f5ff, 0 0 40px #00f5ff55, 0 0 80px #00f5ff22; }
}
@keyframes glitchShift {
  0%,100% { clip-path: inset(0 0 0 0); transform: translate(0); }
  20%      { clip-path: inset(20% 0 30% 0); transform: translate(-3px); }
  40%      { clip-path: inset(60% 0 10% 0); transform: translate(3px); }
  60%      { clip-path: inset(10% 0 60% 0); transform: translate(-2px); }
  80%      { clip-path: inset(40% 0 20% 0); transform: translate(2px); }
}

/* ---- Animated floating particles ---- */
.hero-particles { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 1; }
.particle {
  position: absolute; border-radius: 50%;
  animation: particleFloat linear infinite;
}
.particle-cyan { background: #00f5ff; box-shadow: 0 0 6px #00f5ff; }
.particle-purple { background: #bf00ff; box-shadow: 0 0 6px #bf00ff; }
.particle-pink { background: #ff0080; box-shadow: 0 0 6px #ff0080; }
.particle-green { background: #00ff88; box-shadow: 0 0 6px #00ff88; }


/* ---- Neon logo flicker on hover ---- */
.site-logo:hover .logo-neon {
  animation: neonFlicker 0.3s ease forwards;
}

/* ---- Hero title gradient animation ---- */
.hero-title .line-2 {
  background-size: 200% auto;
  animation: gradShift 3s linear infinite;
}
@keyframes gradShift {
  0%   { background-position: 0% center; }
  100% { background-position: 200% center; }
}

/* ---- Counselling box border animation ---- */
.counselling-box {
  animation: borderPulse 3s ease-in-out infinite;
}

/* ---- Feature card hover glow line ---- */
.feature-card::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--neon-cyan), transparent);
  opacity: 0; transition: opacity 0.3s;
}
.feature-card:hover::after { opacity: 1; }

/* ---- Section tag animated bar ---- */
.section-tag::after {
  animation: lineGrow 1s ease forwards;
}
@keyframes lineGrow {
  from { width: 0; }
  to { width: 60px; }
}

/* scanning line removed */

/* ---- Batch card glow on hover ---- */
.batch-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--neon-purple), transparent);
  opacity: 0; transition: opacity 0.3s;
}
.batch-card:hover::before { opacity: 1; }

/* ---- Slider dot active pulse ---- */
.slider-dot.active {
  animation: dotPulse 2s ease-in-out infinite;
}
@keyframes dotPulse {
  0%,100% { box-shadow: 0 0 8px #00f5ff; }
  50%      { box-shadow: 0 0 20px #00f5ff, 0 0 40px #00f5ff66; }
}

/* ---- FAQ hover glow ---- */
.faq-question:hover .faq-icon {
  box-shadow: 0 0 12px rgba(0,245,255,0.5);
}

/* ---- Partner logo border glow ---- */
.partner-logo:hover {
  text-shadow: 0 0 8px rgba(0,245,255,0.6);
}

/* ---- Testimonial card purple top glow ---- */
.testimonial-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--neon-purple), transparent);
  opacity: 0; transition: opacity 0.3s;
}
.testimonial-card:hover::before { opacity: 1; }

/* ---- Blog card pink top glow ---- */
.blog-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--neon-pink), transparent);
  opacity: 0; transition: opacity 0.3s;
}
.blog-card:hover::before { opacity: 1; }

/* ---- Job card green top glow ---- */
.job-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--neon-green), transparent);
  opacity: 0; transition: opacity 0.3s;
}
.job-card:hover::before { opacity: 1; }

/* ---- Program card hover scale ---- */
.program-thumb-icon svg {
  transition: transform 0.4s ease, opacity 0.4s;
}
.program-card:hover .program-thumb-icon svg {
  transform: scale(1.2);
  opacity: 1;
}

/* ---- Leader card orbit ring animation ---- */
.leader-avatar-wrap::before {
  content: '';
  position: absolute; inset: -8px;
  border-radius: 50%;
  border: 1px dashed rgba(0,245,255,0.2);
  animation: rotateSlow 8s linear infinite;
}

/* ---- Amenity card yellow shimmer ---- */
.amenity-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--neon-yellow), transparent);
  opacity: 0; transition: opacity 0.3s;
}
.amenity-card:hover::before { opacity: 1; }

/* ---- Scroll reveal ---- */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.7s cubic-bezier(0.4,0,0.2,1), transform 0.7s cubic-bezier(0.4,0,0.2,1); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.1s !important; }
.reveal-delay-2 { transition-delay: 0.2s !important; }
.reveal-delay-3 { transition-delay: 0.3s !important; }
.reveal-delay-4 { transition-delay: 0.4s !important; }

/* ---- Section bg variation ---- */
#about         { background: var(--bg-deep); }
#why-choose    { background: var(--bg-dark); }
#programs      { background: var(--bg-void); }
#testimonials  { background: var(--bg-deep); }
#leadership    { background: var(--bg-dark); }
#newsletter    { background: linear-gradient(135deg, #030018, #001030, #030018); border-top: 1px solid var(--border-cyan); border-bottom: 1px solid var(--border-cyan); }
#counselling   { background: var(--bg-void); }
#faq           { background: var(--bg-deep); }
#batches       { background: var(--bg-dark); }
#blogs         { background: var(--bg-void); }
#opportunities { background: var(--bg-deep); }
#amenities     { background: var(--bg-dark); }
#partners      { background: var(--bg-void); }

/* ---- Smooth scroll offset ---- */
html { scroll-padding-top: 80px; }
