/* ============================================================
   SweetAlert2 — Soft Pastel Blue Theme
   Font: DM Sans (body) + Instrument Serif (title accent)
   Mood: airy, gentle, clean — seperti kertas aquarelle
   ============================================================ */

/* ── Light Mode ─────────────────────────────────────────── */
:root,
[data-theme="light"] {
    --sw-bg: #f7f9ff;
    --sw-bg2: #eef2fc;
    --sw-surface: #ffffff;
    --sw-border: #d6e2f8;
    --sw-border-soft: #e8eefb;
    --sw-shadow:
        0 4px 24px rgba(96, 130, 220, 0.1), 0 1px 4px rgba(96, 130, 220, 0.06);
    --sw-shadow-btn: 0 2px 10px rgba(72, 114, 232, 0.28);

    --sw-title: #1c2b5e;
    --sw-text: #6272a0;
    --sw-caption: #9aaace;

    --sw-blue: #4872e8;
    --sw-blue-light: #dce8ff;
    --sw-blue-hover: #3460d6;
    --sw-blue-rgb: 72, 114, 232;

    --sw-success: #2ca87f;
    --sw-success-bg: #e8f8f2;
    --sw-danger: #e05c75;
    --sw-danger-bg: #fde8ed;
    --sw-warning: #d4882a;
    --sw-warning-bg: #fdf3e3;
    --sw-info: #4872e8;
    --sw-info-bg: #dce8ff;

    --sw-overlay: rgba(100, 125, 195, 0.18);
    --sw-radius: 18px;
    --sw-radius-btn: 10px;
    --sw-ease: cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* ── Dark Mode ──────────────────────────────────────────── */
[data-theme="dark"] {
    --sw-bg: #111827;
    --sw-bg2: #1a2337;
    --sw-surface: #16203a;
    --sw-border: #243050;
    --sw-border-soft: #1e2b45;
    --sw-shadow: 0 8px 48px rgba(0, 0, 0, 0.55), 0 2px 8px rgba(0, 0, 0, 0.35);
    --sw-shadow-btn: 0 2px 12px rgba(72, 114, 232, 0.35);

    --sw-title: #d8e4ff;
    --sw-text: #7d93c0;
    --sw-caption: #4d6090;

    --sw-blue: #6b96f5;
    --sw-blue-light: rgba(107, 150, 245, 0.12);
    --sw-blue-hover: #85aaff;
    --sw-blue-rgb: 107, 150, 245;

    --sw-success: #4ec9a0;
    --sw-success-bg: rgba(78, 201, 160, 0.1);
    --sw-danger: #f4788e;
    --sw-danger-bg: rgba(244, 120, 142, 0.1);
    --sw-warning: #f0ab4e;
    --sw-warning-bg: rgba(240, 171, 78, 0.1);
    --sw-info: #6b96f5;
    --sw-info-bg: rgba(107, 150, 245, 0.12);

    --sw-overlay: rgba(5, 10, 25, 0.65);
    --sw-radius: 18px;
    --sw-radius-btn: 10px;
}

/* ============================================================
   POPUP
   ============================================================ */
.swal2-popup {
    background: var(--sw-surface) !important;
    border: 1px solid var(--sw-border) !important;
    border-radius: var(--sw-radius) !important;
    box-shadow: var(--sw-shadow) !important;
    font-family: "DM Sans", sans-serif !important;
    padding: 32px 28px 26px !important;
    position: relative;
    overflow: hidden;
    max-width: 390px !important;
}

/* Soft watercolor wash top-left */
.swal2-popup::before {
    content: "";
    position: absolute;
    top: -40px;
    left: -40px;
    width: 160px;
    height: 160px;
    background: radial-gradient(
        circle,
        rgba(var(--sw-blue-rgb), 0.08) 0%,
        transparent 70%
    );
    pointer-events: none;
    border-radius: 50%;
}

/* Bottom-right soft blob */
.swal2-popup::after {
    content: "";
    position: absolute;
    bottom: -30px;
    right: -30px;
    width: 120px;
    height: 120px;
    background: radial-gradient(
        circle,
        rgba(var(--sw-blue-rgb), 0.05) 0%,
        transparent 70%
    );
    pointer-events: none;
    border-radius: 50%;
}

/* ============================================================
   TITLE
   ============================================================ */
.swal2-title {
    font-family: "DM Sans", sans-serif !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    color: var(--sw-title) !important;
    letter-spacing: -0.025em !important;
    line-height: 1.3 !important;
    margin-top: 10px !important;
    margin-bottom: 0 !important;
}

/* ============================================================
   HTML CONTENT
   ============================================================ */
.swal2-html-container {
    font-family: "DM Sans", sans-serif !important;
    font-size: 13.5px !important;
    color: var(--sw-text) !important;
    line-height: 1.65 !important;
    margin-top: 8px !important;
    font-weight: 400 !important;
}

/* ============================================================
   ACTIONS
   ============================================================ */
.swal2-actions {
    margin-top: 22px !important;
    gap: 8px !important;
    justify-content: flex-end !important;
}

/* ============================================================
   CONFIRM BUTTON
   ============================================================ */
.swal2-confirm {
    background: var(--sw-blue) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: var(--sw-radius-btn) !important;
    padding: 9px 22px !important;
    font-family: "DM Sans", sans-serif !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
    letter-spacing: 0.01em !important;
    box-shadow: var(--sw-shadow-btn) !important;
    transition:
        background 0.2s var(--sw-ease),
        box-shadow 0.2s var(--sw-ease),
        transform 0.15s var(--sw-ease) !important;
}

.swal2-confirm:hover {
    background: var(--sw-blue-hover) !important;
    box-shadow: 0 4px 18px rgba(var(--sw-blue-rgb), 0.4) !important;
    transform: translateY(-1px) !important;
}

.swal2-confirm:active {
    transform: translateY(0) scale(0.97) !important;
    box-shadow: 0 1px 6px rgba(var(--sw-blue-rgb), 0.25) !important;
}

/* ============================================================
   CANCEL BUTTON
   ============================================================ */
.swal2-cancel {
    background: transparent !important;
    color: var(--sw-caption) !important;
    border: 1px solid var(--sw-border) !important;
    border-radius: var(--sw-radius-btn) !important;
    padding: 9px 18px !important;
    font-family: "DM Sans", sans-serif !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    transition:
        background 0.18s,
        border-color 0.18s,
        color 0.18s,
        transform 0.15s !important;
}

.swal2-cancel:hover {
    background: var(--sw-bg2) !important;
    border-color: var(--sw-blue) !important;
    color: var(--sw-blue) !important;
    transform: translateY(-1px) !important;
}

.swal2-cancel:active {
    transform: scale(0.97) !important;
}

/* ============================================================
   DENY BUTTON
   ============================================================ */
.swal2-deny {
    background: var(--sw-danger-bg) !important;
    color: var(--sw-danger) !important;
    border: 1px solid transparent !important;
    border-radius: var(--sw-radius-btn) !important;
    padding: 9px 18px !important;
    font-family: "DM Sans", sans-serif !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
    box-shadow: none !important;
    transition:
        filter 0.18s,
        transform 0.15s !important;
}

.swal2-deny:hover {
    filter: brightness(0.94) !important;
    transform: translateY(-1px) !important;
}

/* ============================================================
   ICONS — base
   Penting: JANGAN override width/height — akan merusak posisi
   internal checkmark & X karena SweetAlert2 memakai em units.
   Gunakan transform: scale() agar semua proporsi tetap benar.
   ============================================================ */
.swal2-icon {
    transform: scale(0.82) !important;
    transform-origin: center center !important;
    margin: -6px auto 0 !important;
    border-width: 2px !important;
    border-style: solid !important;
}

/* ── SUCCESS ──────────────────────────────────────────────
   Struktur SweetAlert2 v11:
   .swal2-success
     .swal2-success-circular-line-left   (pseudo clip kiri)
     .swal2-success-circular-line-right  (pseudo clip kanan)
     .swal2-success-ring                 (lingkaran luar animasi)
     .swal2-success-fix                  (fix artifact)
     .swal2-success-line-tip             (batang pendek ceklis)
     .swal2-success-line-long            (batang panjang ceklis)
   ──────────────────────────────────────────────────────── */
.swal2-icon.swal2-success {
    border-color: var(--sw-success) !important;
    background-color: var(--sw-success-bg) !important;
}

/* Dua batang ceklis (tip + long) */
.swal2-icon.swal2-success .swal2-success-line-tip,
.swal2-icon.swal2-success .swal2-success-line-long {
    background-color: var(--sw-success) !important;
}

/* Ring animasi luar */
.swal2-icon.swal2-success .swal2-success-ring {
    border-color: rgba(44, 168, 127, 0.28) !important;
}

/* Clip area kiri & kanan — harus match background POPUP (bukan success-bg)
   supaya animasi rotate tidak "bocor" keluar lingkaran                      */
.swal2-icon.swal2-success .swal2-success-circular-line-left,
.swal2-icon.swal2-success .swal2-success-circular-line-right,
.swal2-icon.swal2-success .swal2-success-fix {
    background-color: var(--sw-surface) !important;
}

/* ── ERROR ────────────────────────────────────────────────
   Struktur SweetAlert2 v11:
   .swal2-error
     .swal2-x-mark
       .swal2-x-mark-line-left   (batang silang /)
       .swal2-x-mark-line-right  (batang silang \)
   ──────────────────────────────────────────────────────── */
.swal2-icon.swal2-error {
    border-color: var(--sw-danger) !important;
    background-color: var(--sw-danger-bg) !important;
}

/* Kedua batang silang */
.swal2-icon.swal2-error .swal2-x-mark-line-left,
.swal2-icon.swal2-error .swal2-x-mark-line-right {
    background-color: var(--sw-danger) !important;
}

/* ── WARNING ──────────────────────────────────────────────
   Warning memakai teks "!" via :before content
   ──────────────────────────────────────────────────────── */
.swal2-icon.swal2-warning {
    border-color: var(--sw-warning) !important;
    background-color: var(--sw-warning-bg) !important;
    color: var(--sw-warning) !important;
    /* Paksa warna teks "!" */
    font-color: var(--sw-warning) !important;
}

/* Karakter "!" di dalam icon warning */
.swal2-icon.swal2-warning.swal2-icon-show::before,
.swal2-icon.swal2-warning::before {
    color: var(--sw-warning) !important;
}

/* ── INFO ─────────────────────────────────────────────── */
.swal2-icon.swal2-info {
    border-color: var(--sw-info) !important;
    background-color: var(--sw-info-bg) !important;
    color: var(--sw-info) !important;
}

/* ── QUESTION ─────────────────────────────────────────── */
.swal2-icon.swal2-question {
    border-color: var(--sw-blue) !important;
    background-color: var(--sw-blue-light) !important;
    color: var(--sw-blue) !important;
}

/* ============================================================
   BACKDROP
   ============================================================ */
.swal2-backdrop-show {
    background: var(--sw-overlay) !important;
    backdrop-filter: blur(4px) saturate(1.2) !important;
    -webkit-backdrop-filter: blur(4px) saturate(1.2) !important;
}

/* ============================================================
   FOCUS RING
   ============================================================ */
.swal2-styled:focus {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(var(--sw-blue-rgb), 0.2) !important;
}

/* ============================================================
   INPUT / TEXTAREA / SELECT
   ============================================================ */
.swal2-input,
.swal2-textarea,
.swal2-select,
.swal2-file {
    background: var(--sw-bg) !important;
    border: 1px solid var(--sw-border) !important;
    border-radius: 10px !important;
    color: var(--sw-title) !important;
    font-family: "DM Sans", sans-serif !important;
    font-size: 13.5px !important;
    padding: 10px 14px !important;
    box-shadow: none !important;
    transition:
        border-color 0.18s,
        box-shadow 0.18s !important;
}

.swal2-input:focus,
.swal2-textarea:focus,
.swal2-select:focus {
    border-color: var(--sw-blue) !important;
    box-shadow: 0 0 0 3px rgba(var(--sw-blue-rgb), 0.15) !important;
    outline: none !important;
}

.swal2-input::placeholder,
.swal2-textarea::placeholder {
    color: var(--sw-caption) !important;
}

/* ============================================================
   VALIDATION MESSAGE
   ============================================================ */
.swal2-validation-message {
    background: var(--sw-danger-bg) !important;
    color: var(--sw-danger) !important;
    border-radius: 8px !important;
    font-size: 12.5px !important;
    font-family: "DM Sans", sans-serif !important;
    font-weight: 500 !important;
    border: none !important;
    margin-top: 6px !important;
}

.swal2-validation-message::before {
    background: var(--sw-danger) !important;
}

/* ============================================================
   CLOSE BUTTON
   ============================================================ */
.swal2-close {
    color: var(--sw-caption) !important;
    font-size: 20px !important;
    border-radius: 8px !important;
    width: 32px !important;
    height: 32px !important;
    transition:
        background 0.15s,
        color 0.15s !important;
    top: 14px !important;
    right: 14px !important;
}

.swal2-close:hover {
    background: var(--sw-bg2) !important;
    color: var(--sw-title) !important;
}

/* ============================================================
   TIMER PROGRESS BAR
   ============================================================ */
.swal2-timer-progress-bar {
    background: var(--sw-blue) !important;
    opacity: 0.35;
    border-radius: 99px;
    height: 3px !important;
}

/* ============================================================
   LOADER SPINNER
   ============================================================ */
.swal2-loader {
    border-color: var(--sw-blue) transparent var(--sw-blue) transparent !important;
}

/* ============================================================
   PROGRESS STEPS
   ============================================================ */
.swal2-progress-steps .swal2-progress-step {
    background: var(--sw-blue) !important;
    color: #fff !important;
    font-family: "DM Sans", sans-serif !important;
    font-size: 11px !important;
}

.swal2-progress-steps .swal2-progress-step-line {
    background: var(--sw-border) !important;
}

/* ============================================================
   ANIMATIONS — lembut, seperti mengambang
   ============================================================ */
.swal2-show {
    animation: sw-float-in 0.3s cubic-bezier(0.22, 1, 0.36, 1) both !important;
}

.swal2-hide {
    animation: sw-float-out 0.2s ease-in both !important;
}

@keyframes sw-float-in {
    from {
        opacity: 0;
        transform: scale(0.94) translateY(12px);
        filter: blur(2px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
        filter: blur(0);
    }
}

@keyframes sw-float-out {
    from {
        opacity: 1;
        transform: scale(1) translateY(0);
        filter: blur(0);
    }
    to {
        opacity: 0;
        transform: scale(0.97) translateY(6px);
        filter: blur(1px);
    }
}

/* Icon bounce masuk */
.swal2-icon.swal2-animate-success-icon,
.swal2-icon.swal2-animate-error-icon,
.swal2-icon.swal2-animate-warning-icon,
.swal2-icon.swal2-animate-info-icon {
    animation: sw-icon-pop 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) both !important;
    animation-delay: 0.12s !important;
}

@keyframes sw-icon-pop {
    from {
        opacity: 0;
        transform: scale(0.5);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}
