html {
  scroll-behavior: smooth;
  background-image: radial-gradient(#14532d 1px, transparent 1px);
  background-size: 30px 30px;
  background-attachment: fixed;
  background-position: 0 0;
  background-repeat: repeat;
  animation: moveDots 60s linear infinite;
  z-index: -1;
}

/* Dot movement animation (infinite background shifting) */
@keyframes moveDots {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -50px -50px;
  }
}

/* Dot Pattern Section Background */
.bg-dot-pattern {
  background-color: #ffffff; /* hijau tua */
  background-image: radial-gradient(#1a663b 1px, transparent 1px);
  background-size: 20px 20px;
  animation: moveDots 20s linear infinite;
  position: relative;
  z-index: 0;
}

@keyframes moveDots {
  0% { background-position: 0 0; }
  100% { background-position: 20px 20px; }
}

/* Gunakan nama animasi yang berbeda untuk garis */
@keyframes waveScroll {
  0% { background-position: 0 0; }
  100% { background-position: 40px 40px; }
}

.bg-wavy-lines {
  background-color: #0f3f31;
  background-image: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.05) 1px,
    transparent 1px
  );
  background-size: 40px 40px;
  animation: waveScroll 20s linear infinite;
  background-repeat: repeat;
  background-attachment: scroll;
}

/* Hero Section Floating Title */
@keyframes float {
  0%   { transform: translateY(0); }
  50%  { transform: translateY(-8px); }
  100% { transform: translateY(0); }
}
.animate-float {
  animation: float 4s ease-in-out infinite;
}

/* Fade In Animations */
@keyframes fadeInUp {
  0% { opacity: 0; transform: translateY(30px); }
  100% { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInDown {
  0% { opacity: 0; transform: translateY(-30px); }
  100% { opacity: 1; transform: translateY(0); }
}
.animate-fade-in-up {
  animation: fadeInUp 0.8s ease forwards;
}
.animate-fade-in-down {
  animation: fadeInDown 0.8s ease forwards;
}
.delay-100 { animation-delay: 0.1s; }
.delay-200 { animation-delay: 0.2s; }
.delay-300 { animation-delay: 0.3s; }

/* Button Shimmer */
.btn-shimmer {
  position: relative;
  overflow: hidden;
}
.btn-shimmer::before {
  content: '';
  position: absolute;
  top: 0;
  left: -75%;
  width: 50%;
  height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,0.3), transparent);
  animation: shimmer 2s infinite;
}
@keyframes shimmer {
  0% { left: -75%; }
  100% { left: 125%; }
}

/* Brand Scroll (for footer logo carousel) */
@keyframes brand-scroll {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-50%);
  }
}

.animate-brand-scroll {
  width: 200%;
  animation: brand-scroll 30s linear infinite;
}

/* Hover Tilt Effect (SVG or cards) */
.hover-tilt:hover {
  transform: rotate(2deg) scale(1.05);
  transition: transform 0.3s ease;
}

/* Floating Dots & Title */
@keyframes float {
  0%   { transform: translateY(0); }
  50%  { transform: translateY(-8px); }
  100% { transform: translateY(0); }
}
.animate-float {
  animation: float 4s ease-in-out infinite;
}

/* Fade In Effects */
@keyframes fadeInUp {
  0% { opacity: 0; transform: translateY(30px); }
  100% { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInDown {
  0% { opacity: 0; transform: translateY(-30px); }
  100% { opacity: 1; transform: translateY(0); }
}
.animate-fade-in-up {
  animation: fadeInUp 0.8s ease forwards;
}
.animate-fade-in-down {
  animation: fadeInDown 0.8s ease forwards;
}
.delay-100 { animation-delay: 0.1s; }
.delay-200 { animation-delay: 0.2s; }
.delay-300 { animation-delay: 0.3s; }

/* Button shimmer */
.btn-shimmer {
  position: relative;
  overflow: hidden;
}
.btn-shimmer::before {
  content: '';
  position: absolute;
  top: 0;
  left: -75%;
  width: 50%;
  height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,0.3), transparent);
  animation: shimmer 2s infinite;
}
@keyframes shimmer {
  0% { left: -75%; }
  100% { left: 125%; }
}

@keyframes pulseSlow {
  0%, 100% { opacity: 0.2; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(1.1); }
}

.animate-pulse-slow {
  animation: pulseSlow 6s ease-in-out infinite;
}

.btn-hero-glow {
  box-shadow: 0 0 0 rgba(34, 197, 94, 0.5);
  transition: box-shadow 0.4s ease, transform 0.3s ease;
  position: relative;
}

.btn-hero-glow:hover {
  box-shadow: 0 0 15px rgba(34, 197, 94, 0.6), 0 0 30px rgba(34, 197, 94, 0.4);
  transform: scale(1.05);
}

.btn-hero-glow span:last-child {
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,0.4), transparent);
  opacity: 0.4;
  transform: translateX(-100%);
  transition: transform 0.7s ease-in-out;
}

.btn-hero-glow:hover span:last-child {
  transform: translateX(100%);
}

.card-hover-glow {
  position: relative;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.card-hover-glow:hover {
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 15px 30px rgba(34, 197, 94, 0.2);
  border-color: #22c55e;
}

/* Optional inner shine sweep effect */
.card-hover-glow::before {
  content: '';
  position: absolute;
  top: 0;
  left: -75%;
  width: 50%;
  height: 100%;
  background: linear-gradient(
    120deg,
    transparent,
    rgba(255, 255, 255, 0.1),
    transparent
  );
  transform: skewX(-20deg);
  transition: none;
}

.card-hover-glow:hover::before {
  animation: shine-sweep 1s ease forwards;
}

@keyframes shine-sweep {
  from {
    left: -75%;
  }
  to {
    left: 125%;
  }
}

.footer-contact li p {
  transition: color 0.3s ease;
}
.footer-contact li p:hover {
  color: #ffffff;
}

@keyframes marquee {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-50%);
  }
}

.animate-marquee {
  animation: marquee 60s linear infinite;
}

.animate-marquee:hover {
  animation-play-state: paused;
}

.bg-line-pattern {
  background-image: repeating-linear-gradient(
    0deg,
    #f3f4f6,
    #f3f4f6 1px,
    transparent 1px,
    transparent 24px
  );
}

.nav-link {
  position: relative;
  display: inline-block;
  padding-bottom: 2px;
  color: #374151; /* Tailwind text-gray-700 */
  transition: color 0.3s ease;
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  width: 0%;
  background-color: #22c55e; /* Tailwind green-500 */
  transition: width 0.3s ease;
}

.nav-link:hover::after {
  width: 100%;
}

.nav-link:hover {
  color: #22c55e; /* Hover color */
}

@keyframes scrollVertical {
  0% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(-50%);
  }
}

.animate-scroll-vertical {
  animation: scrollVertical 20s linear infinite;
}
