.img-fluid {
  width: 100vw !important;
  height: auto;
}

input[type="text"].form-control,
input[type="email"].form-control,
input[type="tel"].form-control,
input[type="date"].form-control {
  background-color: #fff !important;
  border: 1px solid #ced4da !important;
  padding: 9px;
  border-radius: 6px;
}
.form-check {
  background-color: #fff !important;
  border: 1px solid #ced4da !important;
  padding: 9px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  position: relative;
}

/* Sembunyikan default radio button */
.form-check-input {
  opacity: 0;
  position: absolute;
}

/* Tambahkan ikon sebelum teks hanya jika radio button dipilih */
.form-check-label::before {
  content: "⬜ ";
  color: red; /* Warna merah */
  font-size: 1.2rem;
}

/* Saat dicentang, ganti ikon ke hijau */
.form-check-input:checked + .form-check-label::before {
  content: "✅ ";
  color: green; /* Warna hijau */
}

/* Warna teks juga berubah saat dipilih */
.form-check-input:checked + .form-check-label {
  font-weight: bold;
  color: #8baa8a;
}
button.disabled {
  background-color: #949494 !important;
}
.sw-btn {
  margin-bottom: 9px;
}
@keyframes pulse-icon {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  50% {
    transform: scale(1.4);
    opacity: 0.7;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.form-control.is-invalid {
  border-color: var(--bs-form-invalid-border-color);
  padding-right: calc(1.5em + 0.75rem);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right calc(0.375em + 0.1875rem) center;
  background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
  animation: pulse-icon 0.8s infinite ease-in-out;
}

.sw-toolbar-elm {
  display: flex;
  justify-content: space-between;
  text-align: center;
  align-items: center;
  flex-wrap: wrap; /* Supaya tidak merusak tampilan di layar kecil */
}

/* Memastikan tombol "Kembali" dan "Lanjut" tidak terlalu lebar */
.sw-btn-prev, .sw-btn-next {
  width: 35%; /* Agar ada jarak kecil di antara keduanya */
}

/* Mengatur bagian Konfirmasi agar tetap dalam dua baris */
.no-flex {
  width: 100%;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Tombol "Kirim" dan "Batal" dalam dua baris */
#btnFinish, #btnCancel {
  width: 100%;
  max-width: 200px; /* Bisa diatur sesuai kebutuhan */
}

.card-hover {
  transition: all 0.3s ease-in-out;
}

/* Saat hover */
.card-hover:hover,
.card-hover.active { /* Tetap aktif setelah diklik */
  transform: scale(1.05);
  box-shadow: 0px 10px 20px rgba(0, 0, 0, 0.3);
  position: relative;
}

/* Saat klik */
.card-hover:active {
  transform: scale(1.08);
  box-shadow: 0px 15px 25px rgba(0, 0, 0, 0.4);
}


.card-backdrop {
  animation: none !important;
  transition: 400ms;
}
.card-backdrop-in {
  background-color: rgba(0,0,0,0.2);
}
.wp-block-image{
  width: 100%;
}
.pvc-stats-icon {
  width: 24px !important;
  display: flex!important
}
.popup-content img{
  width: 100% !important;
  height: auto !important;
}
.wp-block-image img {
  width: 100%!important;  
  height: auto !important;  
  display: block;  
}

.wp-header-img, .wp-block-image,#popup-content img {
  width: 100%;
  height: auto;
  background-image: url('../images/loader.gif'); /* Placeholder loading */
  background-repeat: no-repeat;
  background-size: 50px;
  background-position: center;
  background-size: contain;
  transition: filter 0.5s ease-in-out;
}

.fade {
  opacity: 0;
  transform: translateY(50vh); /* Mulai dari bawah */
  transition: opacity 0.5s ease-in-out, transform 0.5s ease-in-out;
}

.fade.show {
  opacity: 1;
  transform: translateY(0); /* Posisi normal */
}
