
  
  
  .scroll-fade-bounce {
    opacity: 0;
    transform: translateY(50px);
    transition: opacity 0.8s ease-out, transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: opacity, transform;
  }
  
  .scroll-fade-bounce.visible {
    opacity: 1;
    transform: translateY(0);
  }











  /* Smooth Scroll Animation */
@keyframes smooth-scroll {
    0% {
      transform: translateY(10px);
      opacity: 0;
    }
    100% {
      transform: translateY(0);
      opacity: 1;
    }
  }
  
  /* Hero Section Animations */
  @keyframes hero-content-fade {
    0% {
      opacity: 0;
      transform: translateY(50px);
    }
    100% {
      opacity: 1;
      transform: translateY(0);
    }
  }
  
  @keyframes hero-btn-fade {
    0% {
      opacity: 0;
      transform: translateY(30px);
    }
    100% {
      opacity: 1;
      transform: translateY(0);
    }
  }
  
  /* Info Section Animations */
  @keyframes info-section-fade {
    0% {
      opacity: 0;
      transform: translateY(50px);
    }
    100% {
      opacity: 1;
      transform: translateY(0);
    }
  }
  
  @keyframes card-fade {
    0% {
      opacity: 0;
      transform: translateY(100px);
    }
    100% {
      opacity: 1;
      transform: translateY(0);
    }
  }
  
  /* Fade In Animation for Scrolling Elements */
  @keyframes fade-in-scroll {
    0% {
      opacity: 0;
    }
    100% {
      opacity: 1;
    }
  }
  
  /* Apply Animation to Elements */
  .hero .hero-content {
    animation: hero-content-fade 1.5s ease-out forwards;
  }
  
  .hero .btn-primary {
    animation: hero-btn-fade 1.5s ease-out 1s forwards;
  }
  
  .info {
    animation: info-section-fade 1.5s ease-out 0.5s forwards;
  }
  
  .info .card {
    animation: card-fade 1.5s ease-out forwards;
    animation-delay: 0.5s;
  }
  
  [data-scroll-fade] {
    animation: fade-in-scroll 1s ease-out;
    animation-delay: 0.5s;
    animation-fill-mode: both;
  }
  
  [data-scroll-fade].in-view {
    animation-name: fade-in-scroll;
  }
  



  .scroll-fade {
    position: relative;
    opacity: 0;
    transform: translateX(-100%);
    transition: opacity 0.3s ease;
  }
  
  @keyframes bounceInX {
    0% { transform: translateX(-100%); opacity: 0; }
    60% { transform: translateX(20px); opacity: 1; }
    80% { transform: translateX(-10px); }
    100% { transform: translateX(0); }
  }
  
  .scroll-fade.faded-in {
    opacity: 1;
    animation: bounceInX 1s ease-out forwards;
  }
  
  .scroll-fade.faded-out {
    opacity: 0;
    transform: translateX(-50%);
  }
  
  /* Scroll from right */
  .scroll-fade-1 {
    position: relative;
    opacity: 0;
    transform: translateX(100%);
    transition: opacity 0.5s ease;
  }
  
  @keyframes bounceInRightToLeft {
    0% { transform: translateX(100%); opacity: 0; }
    60% { transform: translateX(-20px); opacity: 1; }
    80% { transform: translateX(10px); }
    100% { transform: translateX(0); }
  }
  
  .scroll-fade-1.faded-in {
    opacity: 1;
    animation: bounceInRightToLeft 1s ease-out forwards;
  }
  
  .scroll-fade-1.faded-out {
    opacity: 0;
    transform: translateX(100%);
  }
  
  /* Scroll from top */
  .scroll-fade-y {
    position: relative;
    opacity: 0;
    transform: translateY(-100%);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
  }
  
  @keyframes bounceInY {
    0% { transform: translateY(-100%); opacity: 0; }
    60% { transform: translateY(20px); opacity: 1; }
    80% { transform: translateY(-10px); }
    100% { transform: translateY(0); }
  }
  
  @keyframes fadeOutY {
    0% { opacity: 1; transform: translateY(0); }
    100% { opacity: 0; transform: translateY(100%); }
  }
  
  .scroll-fade-y.faded-in {
    opacity: 1;
    animation: bounceInY 1s ease-out forwards;
  }
  
  .scroll-fade-y.faded-out {
    opacity: 0;
    animation: fadeOutY 0.6s ease-in forwards;

  }


  .scroll-fade-y-01 {
    position: relative;
    opacity: 0;
    transform: translateY(-100%);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
  }
  
  @keyframes bounceInY {
    0% { transform: translateY(-100%); opacity: 0; }
    60% { transform: translateY(20px); opacity: 1; }
    80% { transform: translateY(-10px); }
    100% { transform: translateY(0); }
  }
  
  @keyframes fadeOutY {
    0% { opacity: 1; transform: translateY(0); }
    100% { opacity: 0; transform: translateY(100%); }
  }
  
  .scroll-fade-y-01.faded-in {
    opacity: 1;
    animation: bounceInY 1s ease-out forwards;
  }
  
  .scroll-fade-y-01.faded-out {
    opacity: 0;
    animation: fadeOutY 0.6s ease-in forwards;
  }

  .scroll-fade-y-02 {
    position: relative;
    opacity: 0;
    transform: translateY(100%); /* Start below */
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
  }
  
  @keyframes bounceInY {
    0% { transform: translateY(100%); opacity: 0; }   /* Start from bottom */
    60% { transform: translateY(-20px); opacity: 1; } /* Bounce up */
    80% { transform: translateY(10px); }
    100% { transform: translateY(0); }
  }
  
  @keyframes fadeOutY {
    0% { opacity: 1; transform: translateY(0); }
    100% { opacity: 0; transform: translateY(-100%); } /* Exit to top */
  }
  
  .scroll-fade-y-02.faded-in {
    opacity: 1;
    animation: bounceInY 1s ease-out forwards;
  }
  
  .scroll-fade-y-02.faded-out {
    opacity: 0;
    animation: fadeOutY 0.6s ease-in forwards;
  }
  
  .scroll-fade-y-03 {
    position: relative;
    opacity: 0;
    transform: translateY(100%);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
  }
  
  @keyframes bounceInUp {
    0% {
      opacity: 0;
      transform: translateY(100%);
    }
    60% {
      opacity: 1;
      transform: translateY(-20px); /* Overshoot upward */
    }
    80% {
      transform: translateY(10px);  /* Bounce downward */
    }
    100% {
      transform: translateY(0);     /* Settle in place */
    }
  }
  
  @keyframes fadeOutDown {
    0% {
      opacity: 1;
      transform: translateY(0);
    }
    100% {
      opacity: 0;
      transform: translateY(100%);
    }
  }
  
  .scroll-fade-y-03.faded-in {
    animation: bounceInUp 1s ease-out forwards;
  }
  
  .scroll-fade-y-03.faded-out {
    animation: fadeOutDown 0.6s ease-in forwards;
  }
  
  /* Wave-like fade from bottom */
  .scroll-fade-wave {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
    will-change: opacity, transform;
    pointer-events: none; /* Prevent interaction before visible */
  }
  
  .scroll-fade-wave.visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
  
  /* More consistent and scalable stagger */
  .scroll-fade-wave:nth-child(1)  { transition-delay: 0.1s; }
  .scroll-fade-wave:nth-child(2)  { transition-delay: 0.2s; }
  .scroll-fade-wave:nth-child(3)  { transition-delay: 0.3s; }
  .scroll-fade-wave:nth-child(4)  { transition-delay: 0.4s; }
  .scroll-fade-wave:nth-child(5)  { transition-delay: 0.5s; }
  .scroll-fade-wave:nth-child(6)  { transition-delay: 0.6s; }
  .scroll-fade-wave:nth-child(7)  { transition-delay: 0.7s; }
  .scroll-fade-wave:nth-child(8)  { transition-delay: 0.8s; }
  

  .scroll-fade-01 {
    position: relative;
    opacity: 0;
    transform: translateX(-100%);
    transition: opacity 0.3s ease;
  }
  
  @keyframes bounceInX {
    0% { transform: translateX(-100%); opacity: 0; }
    60% { transform: translateX(20px); opacity: 1; }
    80% { transform: translateX(-10px); }
    100% { transform: translateX(0); }
  }
  
  .scroll-fade-01.faded-in {
    opacity: 1;
    animation: bounceInX 1s ease-out forwards;
  }
  
  .scroll-fade-01.faded-out {
    opacity: 0;
    transform: translateX(-50%);
  }
  


  /* Scroll from right */
  .scroll-fade-right-01 {
    position: relative;
    opacity: 0;
    transform: translateX(100%);
    transition: opacity 0.5s ease;
  }
  
  @keyframes bounceInRightToLeft {
    0% { transform: translateX(100%); opacity: 0; }
    60% { transform: translateX(-20px); opacity: 1; }
    80% { transform: translateX(10px); }
    100% { transform: translateX(0); }
  }
  
  .scroll-fade-right-01.faded-in {
    opacity: 1;
    animation: bounceInRightToLeft 1s ease-out forwards;
  }
  
  .scroll-fade-right-01.faded-out {
    opacity: 0;
    transform: translateX(100%);
  }

  .scroll-fade-right-02 {
    position: relative;
    opacity: 0;
    transform: translateX(100%);
    transition: opacity 0.5s ease;
  }
  
  @keyframes bounceInRightToLeft {
    0% { transform: translateX(100%); opacity: 0; }
    60% { transform: translateX(-20px); opacity: 1; }
    80% { transform: translateX(10px); }
    100% { transform: translateX(0); }
  }
  
  .scroll-fade-right-02.faded-in {
    opacity: 1;
    animation: bounceInRightToLeft 1s ease-out forwards;
  }
  
  .scroll-fade-right-02.faded-out {
    opacity: 0;
    transform: translateX(100%);
  }

  .scroll-fade-right-03 {
    position: relative;
    opacity: 0;
    transform: translateX(100%);
    transition: opacity 0.5s ease;
  }
  
  @keyframes bounceInRightToLeft {
    0% { transform: translateX(100%); opacity: 0; }
    60% { transform: translateX(-20px); opacity: 1; }
    80% { transform: translateX(10px); }
    100% { transform: translateX(0); }
  }
  
  .scroll-fade-right-03.faded-in {
    opacity: 1;
    animation: bounceInRightToLeft 1s ease-out forwards;
  }
  
  .scroll-fade-right-03.faded-out {
    opacity: 0;
    transform: translateX(100%);
  }


  .scroll-fade-right-04 {
    position: relative;
    opacity: 0;
    transform: translateX(100%);
    transition: opacity 0.5s ease;
  }
  
  @keyframes bounceInRightToLeft {
    0% { transform: translateX(100%); opacity: 0; }
    60% { transform: translateX(-20px); opacity: 1; }
    80% { transform: translateX(10px); }
    100% { transform: translateX(0); }
  }
  
  .scroll-fade-right-04.faded-in {
    opacity: 1;
    animation: bounceInRightToLeft 1s ease-out forwards;
  }
  
  .scroll-fade-right-04.faded-out {
    opacity: 0;
    transform: translateX(100%);
  }


  .scroll-fade-right-02-01 {
    position: relative;
    opacity: 0;
    transform: translateX(100%);
    transition: opacity 0.5s ease;
  }
  
  @keyframes bounceInRightToLeft {
    0% { transform: translateX(100%); opacity: 0; }
    60% { transform: translateX(-20px); opacity: 1; }
    80% { transform: translateX(10px); }
    100% { transform: translateX(0); }
  }
  
  .scroll-fade-right-02-01.faded-in {
    opacity: 1;
    animation: bounceInRightToLeft 1s ease-out forwards;
  }
  
  .scroll-fade-right-02-01.faded-out {
    opacity: 0;
    transform: translateX(100%);
  }

  .scroll-fancy {
    opacity: 0;
    transform: translateY(50px);
    will-change: opacity, transform;
  }

  .racing-text {
    opacity: 0;
    transform: translateX(-200px) skewX(20deg) scaleX(1.1);
    will-change: transform, opacity;
    margin: 20px 0;
  }


  .section {
    display: flex;
    height: auto;
  }

  .box-container {
    position: relative;
    top:100px;
    height: auto;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .box {
    position: absolute;
    background: rgba(255, 255, 255, 0.173);
    padding: 2rem;
    border-radius: 12px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    width: 80%;
    text-align: center;
    opacity: 0;
    transform: translateY(100px);
  }


  
  /* Initial style: normal button */
.shield-button {
  transition: all 0.5s ease;
  border-radius: 0.375rem; /* Bootstrap default */
  padding: 10px 20px;
}

/* Transformed shield shape */
.shield-button.shield-shape {
  clip-path: polygon(50% 0%, 100% 25%, 80% 100%, 20% 100%, 0% 25%);
  padding: 15px 25px;
  background-color: #0d6efd; /* Bootstrap primary */
  color: white;
  border: none;
}



.rope-drop-01 {
  animation: ropeFall 1.6s ease-out forwards;
  transform-origin: top center;
  opacity: 1;
}

@keyframes ropeFall {
  0% { transform: translateY(-300px) rotateZ(15deg); opacity: 0; }
  20% { transform: translateY(-180px) rotateZ(-10deg); opacity: 0.4; }
  40% { transform: translateY(-80px) rotateZ(6deg); opacity: 0.7; }
  60% { transform: translateY(20px) rotateZ(-4deg); opacity: 1; }
  80% { transform: translateY(-10px) rotateZ(2deg); }
  100% { transform: translateY(0) rotateZ(0); }
}


/* Delay classes */
.delay-1 { animation-delay: 0.2s; }
.delay-2 { animation-delay: 0.4s; }
.delay-3 { animation-delay: 0.6s; }
.delay-4 { animation-delay: 0.8s; }
.delay-5 { animation-delay: 1s; }
.delay-6 { animation-delay: 1.2s; }



.drop-text {
  opacity: 0;
  transform: translateY(-40px);
  will-change: opacity, transform;
}

