/* ============================================
   HOME PAGE STYLES
   ============================================ */

/* Smooth scroll behavior */
html {
  scroll-behavior: smooth;
}

/* Hero section gradient animation */
#hero {
  background: linear-gradient(135deg, #15803d 0%, #14532d 100%);
  position: relative;
  overflow: hidden;
}

#hero::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(115deg, transparent 0%, rgba(255, 255, 255, 0.06) 44%, transparent 68%);
  transform: translateX(-34%);
  animation: hero-sheen 16s ease-in-out infinite;
}

@keyframes pulse {

  0%,
  100% {
    opacity: 0.5;
  }

  50% {
    opacity: 1;
  }
}

@keyframes hero-sheen {

  0%,
  100% {
    opacity: 0.25;
    transform: translateX(-28%);
  }

  50% {
    opacity: 0.55;
    transform: translateX(10%);
  }
}

@keyframes hero-float {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-4px);
  }
}

@keyframes hero-phone-float {

  0%,
  100% {
    transform: translateY(0) rotate(-2deg);
  }

  50% {
    transform: translateY(-3px) rotate(-1.5deg);
  }
}

@keyframes hero-pulse-dot {

  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.28);
  }

  50% {
    box-shadow: 0 0 0 4px rgba(34, 197, 94, 0);
  }
}

@keyframes hero-progress {

  0%,
  100% {
    transform: scaleX(0.92);
  }

  50% {
    transform: scaleX(1);
  }
}

.hero-mock-shell {
  animation: hero-float 9s ease-in-out infinite;
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.hero-mock-shell:hover {
  transform: translateY(-3px);
}

.hero-phone {
  animation: hero-phone-float 9s ease-in-out infinite;
}

.hero-floating-card {
  animation: hero-float 10s ease-in-out infinite;
}

.hero-live-dot {
  animation: hero-pulse-dot 2.4s ease-in-out infinite;
}

.hero-progress-bar {
  animation: hero-progress 7s ease-in-out infinite;
  transform-origin: left center;
}

/* CTA Button hover effects */
.cta-button {
  transition: all 0.3s ease;
}

.cta-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 25px rgba(46, 152, 80, 0.3);
}

/* Feature cards hover effect */
#features .bg-white {
  transition: all 0.3s ease;
}

#features .bg-white:hover {
  transform: translateY(-4px);
}

/* Use case selector */
.use-case-tab {
  transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
}

.use-case-tab:hover {
  border-color: #bbf7d0;
  box-shadow: 0 14px 34px rgba(15, 118, 66, 0.08);
  transform: translateY(-1px);
}

.use-case-tab.active {
  background: #dcfce7;
  border-color: #86efac;
  box-shadow: 0 18px 42px rgba(15, 118, 66, 0.14);
}

.use-case-tab.active .use-case-tab-icon {
  background: #ffffff;
  box-shadow: 0 10px 24px rgba(15, 118, 66, 0.16);
}

.use-case-tab.active .use-case-tab-tag {
  background: #ffffff;
  color: #166534;
}

.use-case-preview {
  background: linear-gradient(135deg, #ffffff 0%, #f0fdf4 100%);
}

.use-case-panel {
  animation: use-case-panel-in 0.24s ease;
}

@keyframes use-case-panel-in {
  from {
    opacity: 0;
    transform: translateY(6px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .use-case-panel {
    animation: none;
  }
}

/* Pricing card popular badge */
#pricing .bg-primary {
  position: relative;
  transform: scale(1.05);
}

@media (max-width: 1024px) {
  #pricing .bg-primary {
    transform: scale(1);
  }
}

/* FAQ accordion */
.faq-question svg {
  transition: transform 0.3s ease;
}

.faq-question.active svg {
  transform: rotate(180deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
}

.faq-answer.active {
  max-height: 500px;
}

/* Mobile menu */
#mobileMenu {
  transition: all 0.3s ease;
}

#mobileMenu.active {
  display: block;
}

/* Gradient backgrounds for use cases */
.gradient-blue {
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
}

.gradient-purple {
  background: linear-gradient(135deg, #a855f7 0%, #9333ea 100%);
}

.gradient-green {
  background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
}

/* Loading animation for images */
img {
  transition: opacity 0.3s ease;
}

img[loading="lazy"] {
  opacity: 0;
}

img[loading="lazy"].loaded {
  opacity: 1;
}

/* Smooth transitions for all interactive elements */
a,
button {
  transition: all 0.2s ease;
}

/* Custom scrollbar */
::-webkit-scrollbar {
  width: 10px;
}

::-webkit-scrollbar-track {
  background: #f1f1f1;
}

::-webkit-scrollbar-thumb {
  background: #2e9850;
  border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
  background: #216d39;
}
