/* Custom Carousel Styles for div#carousel */

#carousel {
  position: relative;
  width: 100%;
  overflow: visible;
}

/* Carousel slides container */
#carousel > div {
  display: none;
  width: 100%;
  animation: fadeIn 0.5s ease-in-out;
}

#carousel > div.active {
  display: flex;
}

#carousel > div[slot="media"] {
  text-align: center;
  padding: 30px 20px;
}

/* Fade in animation */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateX(20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Image styling */
#carousel helix-core-image {
  max-width: 100%;
  height: auto;
  margin: 30px auto 0;
  display: block;
}

/* Header styling */
#carousel h3[slot="header"] {
  color: #1175CB !important;
  font-size: 20px;
  font-family: 'proxima_novabold';
  padding: 30px 0px 0px 0px !important;
  margin-bottom: 0;
}

/* Button styling */
#carousel .btn {
  padding: 12px 35px;
  border-radius: 5px;
  text-decoration: none;
  font-weight: 500;
  font-size: 16px;
  transition: all 0.3s ease;
  margin-top: 20px;
  display: inline-block;
  cursor: pointer;
}

#carousel .btn-secondary {
  background-color: #0073cf;
  color: #fff;
  border: 0;
  border-radius: 32px;
  padding: 12px 40px;
}

#carousel .btn-secondary:hover {
  background-color: #005aa3;
  border-color: #005aa3;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 115, 207, 0.3);
}

/* Navigation arrows - HIDDEN */
.carousel-arrow {
  display: none;
}

/* Number pagination container - positioned below image */
.carousel-pagination {
  display: flex !important;
  justify-content: center;
  align-items: center;
  gap: 0;
  margin: 0;
  padding: 16px 0 0;
  position: relative;
  z-index: 100;
  visibility: visible !important;
}

/* Number pagination buttons */
.carousel-pagination-btn {
  /* width: 15px;
  height: 20px; */
  /* border-radius: 50%; */
  /* background-color: #f5f5f5 !important; */
  /* border: 2px solid #ddd !important; */
  cursor: pointer !important;
  transition: all 0.3s ease;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 16px;
  /* color: #666 !important; */
  /* box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1); */
  position: relative;
  overflow: visible;
  z-index: 10;
  visibility: visible !important;
  opacity: 1 !important;
  padding: 1px 3px;
}

.carousel-pagination-btn::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background-color: rgba(0, 115, 207, 0.1);
  transform: translate(-50%, -50%);
  transition: width 0.3s ease, height 0.3s ease;
}

.carousel-pagination-btn:hover::before {
  width: 100%;
  height: 100%;
}

.carousel-pagination-btn:hover {
  /* border-color: #0073cf; */
  /* color: #0073cf; */
  transform: translateY(-3px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.carousel-pagination-btn.active {
  background-color: #61616f;
  border: 1px solid transparent;
  color: #fff !important;
  /* transform: scale(1.15);
  box-shadow: 0 4px 15px rgba(0, 115, 207, 0.4) !important; */
}
#carousel a.btn.btn-secondary {
  float: none;
  margin: 20px auto 0 auto;
  background: #1175CB;
  border: 0px;
  padding: 12px 40px;
  border-radius: 32px;
}
.carousel-pagination-btn.active::before {
  display: none;
}

/* Number text inside button */
.carousel-pagination-btn span {
  position: relative;
  z-index: 1;
}

/* Responsive design */
@media (max-width: 768px) {
  #carousel h3[slot="header"] {
    font-size: 1.4rem;
  }

  .carousel-pagination-btn {
    width: 42px !important;
    height: 42px !important;
    font-size: 16px !important;
  }

  .carousel-pagination {
    gap: 12px;
  }
}

@media (max-width: 480px) {
  #carousel > div[slot="media"] {
    padding: 20px 10px;
  }

  #carousel h3[slot="header"] {
    font-size: 1.2rem;
  }

  #carousel .btn {
    padding: 10px 25px;
    font-size: 14px;
  }

  .carousel-pagination-btn {
    width: 38px !important;
    height: 38px !important;
    font-size: 14px !important;
  }

  .carousel-pagination {
    gap: 10px;
    padding: 15px 0;
  }
}
