/* static/css/notify.css */
/* =========================================================
   NOTIFY UI — Modern Academic
   - Toast + modal styles untuk notify.js
   - 100% pakai tokens dari theme.css
   ========================================================= */

/* ===== Toast Host ===== */
#toastHost[data-toast-host]{
  position: fixed;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  z-index: var(--z-toast);

  display: flex;
  flex-direction: column;
  gap: 10px;

  max-width: min(520px, calc(100vw - 28px));
  pointer-events: none;

  /* optional: bikin toast card rata tengah */
  align-items: center;
  direction: ltr;
  text-align: left;
}

/* ===== Toast Card ===== */
.notifyToast{
  pointer-events: auto;
  display: grid;
  grid-template-columns: 10px 1fr auto;
  gap: 10px;
  align-items: start;

  padding: 10px 12px;
  border-radius: var(--r-md);
  background: var(--notify-card);
  border: 1px solid var(--notify-border);
  box-shadow: var(--notify-shadow-sm);
  transform: translateY(-6px);
  opacity: 0;
  transition: transform var(--dur-1) var(--ease), opacity var(--dur-1) var(--ease);
  direction: ltr;
  text-align: left;
  width: fit-content;
  max-width: min(420px, calc(100vw - 28px));
  min-width: 240px;    
}

.notifyToast.show{
  transform: translateY(0);
  opacity: 1;
}

.notifyToast .bar{
  width: 10px;
  border-radius: 999px;
  height: 100%;
  background: var(--info);
}

.notifyToast .txt{
  font-size: 13px;
  line-height: 1.35;
  color: var(--notify-text);
  direction: ltr;
  text-align: left;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.notifyToast .btnX{
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  padding: 0 4px;
  opacity: .55;
  color: var(--notify-muted)
}
.notifyToast .btnX:hover{ opacity: .9; }

/* semantic bars */
.notifyToast.info .bar{ background: var(--info); }
.notifyToast.success .bar{ background: var(--success); }
.notifyToast.warning .bar{ background: var(--warning); }
.notifyToast.error .bar{ background: var(--danger); }

/* ===== Modal Host ===== */
#modalHost[data-modal-host]{
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: none;
  isolation: isolate;
}
#modalHost[data-modal-host].show{
  display: grid;
  place-items: center;
}

.notifyBackdrop{
  position: absolute;
  inset: 0;
  background: var(--notify-backdrop);
  backdrop-filter: blur(2px);
}

/* ===== Modal Panel ===== */
.notifyModal{
  position: relative;
  width: min(520px, calc(100vw - 28px));
  border-radius: var(--r-lg);
  background: var(--notify-card);
  box-shadow: var(--notify-shadow-md);
  border: 1px solid var(--notify-border);
  overflow: hidden;
  direction: ltr;
}

.notifyHead{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--notify-border);
  background: var(--notify-card-2);
}

.notifyTitle{
  font-weight: 750;
  font-size: 14px;
  color: var(--notify-text);
  display: flex;
  align-items: center;
  gap: 10px;
}

.notifyBody{
  padding: 14px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--notify-text);
  direction: ltr;
  text-align: left;
}

/* Isi teks mengikuti arah halaman: style ini akan dipakai kalau nanti diputuskan alert pakai bahasa arab*/
/*
html[dir="rtl"] .notifyBody{
  direction: rtl;
  text-align: right;
}

html[dir="ltr"] .notifyBody{
  direction: ltr;
  text-align: left;
}
  */


.notifyFoot{
  display: flex;
  justify-content: center !important;
  align-items: center;
  text-align: center;
  gap: 14px;
  padding: 12px 14px;
  border: 1px solid var(--notify-border);
  background: var(--notify-card-2);
}

.notifyFoot [data-act="ok"]{
  order: 1;
}

.notifyFoot [data-act="cancel"]{
  order: 2;
}


/* ===== Buttons ===== */
.notifyBtn{
  background: #fff;
  border-radius: var(--r-sm);
  padding: 8px 12px;
  cursor: pointer;
  font-size: 13px;
  border: 1px solid var(--notify-border-2);
  color: var(--notify-text);
  transition: transform var(--dur-1) var(--ease), filter var(--dur-1) var(--ease);
}
.notifyBtn:hover{ filter: brightness(.98); }
.notifyBtn:active{ transform: translateY(1px); }

.notifyBtn.primary{
  border-color: transparent;
  background: var(--accent);
  color: #fff;
}

.notifyHead .notifyBtn[data-act="x"]{
  margin-left: auto;
}

/* ===== Badge (subtle) ===== */
.notifyBadge{
  display: inline-block;
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid var(--border);
  color: var(--muted);
  background: rgba(15, 23, 42, .04);
}

.notifyBadge.info{ background: var(--info-bg); color: var(--info); border-color: rgba(37,99,235,.25); }
.notifyBadge.success{ background: var(--success-bg); color: var(--success); border-color: rgba(5,150,105,.25); }
.notifyBadge.warning{ background: var(--warning-bg); color: var(--warning); border-color: rgba(217,119,6,.25); }
.notifyBadge.error{ background: var(--danger-bg); color: var(--danger); border-color: rgba(220,38,38,.25); }
