:root {
  --glass-bg: rgba(255, 255, 255, 0.72);
  --glass-border: rgba(255, 255, 255, 0.6)
}

.btn-grad {
  background: linear-gradient(90deg, var(--b1, #059669), var(--b2, #0ea5e9));
  background-size: 200% 200%;
}

.btn-grad:hover {
  filter: brightness(1.03);
  transform: translateY(-3px)
}

.glass {
  background: var(--glass-bg);
  backdrop-filter: blur(6px);
  border: 1px solid var(--glass-border)
}

.card-hover {
  transition: all .35s cubic-bezier(.2, .9, .3, 1)
}

.card-hover:hover {
  transform: translateY(-8px) scale(1.01);
  box-shadow: 0 20px 50px rgba(2, 6, 23, 0.12)
}

.img-zoom {
  transition: transform .6s ease
}

.img-zoom:hover {
  transform: scale(1.04)
}

.reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: all .7s cubic-bezier(.2, .9, .3, 1)
}

.reveal.revealed {
  opacity: 1;
  transform: translateY(0)
}

.hero-gradient {
  background: linear-gradient(90deg, #059669 0%, #0ea5e9 50%, #06b6d4 100%);
  background-size: 200% 200%
}

.sticky-call {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 60;
  width: 64px;
  height: 64px;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center
}

.pulse-ring {
  animation: pulse-ring 2.6s infinite
}

@keyframes pulse-ring {
  0% {
    box-shadow: 0 0 0 0 rgba(5, 150, 105, 0.18)
  }

  70% {
    box-shadow: 0 0 0 18px rgba(5, 150, 105, 0)
  }

  100% {
    box-shadow: 0 0 0 0 rgba(5, 150, 105, 0)
  }
}