/* =========================
   SWEETALERT MODERN THEME
========================= */

.swal-modern-popup {
  width: 32em !important;
  padding: 28px 26px !important;
  border: 1px solid rgba(148, 163, 184, 0.25) !important;
  border-radius: 28px !important;

  background: rgba(255, 255, 255, 0.96) !important;
  box-shadow: 0 28px 70px rgba(15, 23, 42, 0.22) !important;

  -webkit-backdrop-filter: blur(18px) !important;
  backdrop-filter: blur(18px) !important;

  overflow: hidden !important;
  box-sizing: border-box !important;
}


/* =========================
   JUDUL
========================= */

.swal-modern-title {
  margin: 10px 0 8px !important;
  padding: 0 !important;

  color: #0f172a !important;
  font-size: 23px !important;
  font-weight: 800 !important;
  line-height: 1.3 !important;
  letter-spacing: -0.3px !important;
  text-align: center !important;
}


/* =========================
   TEKS
========================= */

.swal-modern-text,
.swal2-html-container.swal-modern-text {
  margin: 0 !important;
  padding: 0 !important;

  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  text-align: center !important;
}


/* =========================
   POSISI IKON
========================= */

.swal-modern-icon,
.swal2-icon.swal-modern-icon {
  margin: 10px auto 12px !important;
  position: relative !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
}


/* =========================
   SUCCESS
========================= */

.swal2-icon.swal2-success {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  margin: 10px auto 12px !important;

  border-color: #14b8a6 !important;
  color: #14b8a6 !important;

  box-sizing: content-box !important;
}

/* Garis centang */
.swal2-icon.swal2-success [class^="swal2-success-line"] {
  background-color: #14b8a6 !important;
}

/* Lingkaran garis luar */
.swal2-icon.swal2-success .swal2-success-ring {
  border-color: rgba(20, 184, 166, 0.28) !important;
}

/*
  Menghilangkan lapisan putih bawaan animasi SweetAlert2
  yang terlihat tidak center ketika popup transparan.
*/
.swal2-icon.swal2-success .swal2-success-fix,
.swal2-icon.swal2-success .swal2-success-circular-line-left,
.swal2-icon.swal2-success .swal2-success-circular-line-right {
  background-color: transparent !important;
}


/* =========================
   WARNING
========================= */

.swal2-icon.swal2-warning {
  margin: 10px auto 12px !important;
  border-color: #f59e0b !important;
  color: #f59e0b !important;
}


/* =========================
   ERROR
========================= */

.swal2-icon.swal2-error {
  margin: 10px auto 12px !important;
  border-color: #ef4444 !important;
  color: #ef4444 !important;
}

.swal2-icon.swal2-error [class^="swal2-x-mark-line"] {
  background-color: #ef4444 !important;
}


/* =========================
   QUESTION
========================= */

.swal2-icon.swal2-question {
  margin: 10px auto 12px !important;
  border-color: #2563eb !important;
  color: #2563eb !important;
}


/* =========================
   INFO
========================= */

.swal2-icon.swal2-info {
  margin: 10px auto 12px !important;
  border-color: #2563eb !important;
  color: #2563eb !important;
}


/* =========================
   AREA TOMBOL
========================= */

.swal2-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-wrap: wrap !important;

  margin: 22px auto 0 !important;
  padding: 0 !important;
}


/* =========================
   SEMUA TOMBOL
========================= */

.swal-modern-confirm,
.swal-modern-cancel,
.swal-modern-danger {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;

  min-height: 42px !important;
  margin: 5px !important;
  padding: 11px 18px !important;

  border: none !important;
  border-radius: 14px !important;
  outline: none !important;

  font-family: inherit !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;

  cursor: pointer !important;
  box-shadow: none !important;

  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    opacity 0.25s ease !important;
}


/* =========================
   TOMBOL CONFIRM
========================= */

.swal-modern-confirm {
  color: #ffffff !important;

  background:
    linear-gradient(
      135deg,
      #2563eb 0%,
      #14b8a6 100%
    ) !important;

  box-shadow:
    0 12px 26px rgba(37, 99, 235, 0.24) !important;
}


/* =========================
   TOMBOL DELETE / DANGER
========================= */

.swal-modern-danger {
  color: #ffffff !important;

  background:
    linear-gradient(
      135deg,
      #ef4444 0%,
      #e11d48 100%
    ) !important;

  box-shadow:
    0 12px 26px rgba(239, 68, 68, 0.24) !important;
}


/* =========================
   TOMBOL CANCEL
========================= */

.swal-modern-cancel {
  color: #475569 !important;
  background: #f1f5f9 !important;

  box-shadow:
    0 8px 18px rgba(15, 23, 42, 0.08) !important;
}


/* =========================
   HOVER TOMBOL
========================= */

.swal-modern-confirm:hover,
.swal-modern-danger:hover,
.swal-modern-cancel:hover {
  transform: translateY(-2px) !important;
}

.swal-modern-confirm:hover {
  box-shadow:
    0 16px 30px rgba(37, 99, 235, 0.3) !important;
}

.swal-modern-danger:hover {
  box-shadow:
    0 16px 30px rgba(239, 68, 68, 0.3) !important;
}

.swal-modern-cancel:hover {
  background: #e2e8f0 !important;

  box-shadow:
    0 12px 22px rgba(15, 23, 42, 0.12) !important;
}


/* =========================
   ACTIVE TOMBOL
========================= */

.swal-modern-confirm:active,
.swal-modern-danger:active,
.swal-modern-cancel:active {
  transform: translateY(0) scale(0.98) !important;
}


/* =========================
   FOCUS TOMBOL
========================= */

.swal-modern-confirm:focus,
.swal-modern-danger:focus,
.swal-modern-cancel:focus {
  outline: none !important;

  box-shadow:
    0 0 0 4px rgba(20, 184, 166, 0.14) !important;
}


/* =========================
   DESKRIPSI CUSTOM
========================= */

.swal-desc {
  max-width: 340px;
  margin: 0 auto 12px !important;
  padding: 0 !important;

  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  text-align: center !important;
}


/* =========================
   LOADING
========================= */

.swal2-loader {
  border-color:
    #14b8a6
    transparent
    #14b8a6
    transparent !important;
}


/* =========================
   BACKDROP
========================= */

.swal2-container.swal2-backdrop-show,
.swal2-container.swal2-noanimation {
  background: rgba(15, 23, 42, 0.42) !important;

  -webkit-backdrop-filter: blur(4px) !important;
  backdrop-filter: blur(4px) !important;
}


/* =========================
   PROGRESS BAR / TIMER
========================= */

.swal2-timer-progress-bar {
  background:
    linear-gradient(
      90deg,
      #2563eb,
      #14b8a6
    ) !important;
}


/* =========================
   CLOSE BUTTON
========================= */

.swal2-close {
  color: #94a3b8 !important;
  transition: 0.2s ease !important;
}

.swal2-close:hover {
  color: #0f172a !important;
  transform: scale(1.08) !important;
}


/* =========================
   RESPONSIVE MOBILE
========================= */

@media (max-width: 576px) {
  .swal-modern-popup {
    width: calc(100% - 28px) !important;
    padding: 24px 18px !important;
    border-radius: 22px !important;
  }

  .swal-modern-title {
    margin-top: 8px !important;
    font-size: 20px !important;
  }

  .swal-modern-text,
  .swal2-html-container.swal-modern-text,
  .swal-desc {
    font-size: 13px !important;
  }

  .swal2-actions {
    width: 100% !important;
    margin-top: 18px !important;
    padding: 0 4px !important;
  }

  .swal-modern-confirm,
  .swal-modern-cancel,
  .swal-modern-danger {
    width: 100% !important;
    min-height: 40px !important;
    margin: 5px 0 !important;
    font-size: 13px !important;
  }
}