:root {
  --vibrant-red: #d60000;
  --pastel-red: #ffdbdb;
  --charcoal: #111;
  --light-bg: #f8f9fa;
}

body {
  font-family: "Poppins", Arial, sans-serif;
  margin: 0;
  padding: 0;
}

.navbar {
  transition: all 0.3s ease;
}

.bg-light-red {
  background-color: var(--pastel-red, #ff4d4d1a);
}

.text-danger {
  color: var(--vibrant-red) !important;
}

.btn-danger {
  background-color: var(--vibrant-red);
  border: none;
}
.btn-danger:hover {
  background-color: #b50000;
}

#hero {
  height: 100vh;
  background: url('assets/background.jpg') center/cover no-repeat fixed;
  position: relative;
}
#hero .overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55);
}
#hero .content {
  position: relative;
  z-index: 1;
}

#preloader {
  position: fixed;
  inset: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  z-index: 2000;
}
#preloader img.spin {
  animation: spin 2s linear infinite;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.service-box, .province-block, .step {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  padding: 16px;
}

.fade-in {
  opacity: 0;
  animation: fadeIn 1s forwards;
}
.fade-in-delay {
  opacity: 0;
  animation: fadeIn 1.5s forwards;
}
@keyframes fadeIn {
  from {
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#backTop {
  position: fixed;
  bottom: 25px;
  right: 25px;
  display: none;
  z-index: 999;
}

.whatsapp-float {
  position: fixed;
  bottom: 25px;
  left: 25px;
  background: #25d366;
  color: #fff;
  padding: 12px 14px;
  border-radius: 50%;
  font-size: 22px;
  z-index: 998;
}

/* Favicon pulsing animation */
@keyframes pulse {
  0% {
    filter: drop-shadow(0 0 0 var(--vibrant-red));
  }
  50% {
    filter: drop-shadow(0 0 6px var(--vibrant-red));
  }
  100% {
    filter: drop-shadow(0 0 0 var(--vibrant-red));
  }
}
link[rel="icon"] {
  animation: pulse 4s infinite;
}