/* =========================================================
   IQEC CORE UI
   Unified CSS
   ========================================================= */

:root{
  --iqec-font-family: "Noto Kufi Arabic", sans-serif;

  --iqec-primary: #2563eb;
  --iqec-primary-light: #93c5fd;

  --iqec-success: #16a34a;
  --iqec-success-light: #86efac;

  --iqec-text: #0f172a;
  --iqec-text-soft: #475569;
  --iqec-text-muted: #64748b;

  --iqec-border: #e2e8f0;
  --iqec-border-soft: #e5e7eb;

  --iqec-surface: #ffffff;
  --iqec-surface-soft: #f8fafc;
  --iqec-surface-muted: #f1f5f9;

  --iqec-toast-bg: #111827;
  --iqec-toast-text: #ffffff;
  --iqec-toast-text-soft: #d1d5db;
  --iqec-toast-border: rgba(255,255,255,.08);

  --iqec-shadow-lg: 0 25px 70px rgba(0,0,0,.22);
  --iqec-shadow-toast: 0 18px 46px rgba(0,0,0,.22);
}

/* =========================================================
   Base Scope
   ========================================================= */

.iqec-dm-root,
.iqec-toast-root{
  font-family: var(--iqec-font-family);
  direction: rtl;
}

/* =========================================================
   DAILY MISSIONS MODAL
   ========================================================= */

.iqec-dm-root[hidden]{
  display:none !important;
}

.iqec-dm-root{
  position:fixed;
  inset:0;
  z-index:999997;
}

.iqec-dm-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.48);
  backdrop-filter:blur(3px);
}

.iqec-dm-dialog{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:min(92vw, 560px);
  max-height:min(calc(100vh - 24px), 820px);
  background:var(--iqec-surface);
  border-radius:24px;
  box-shadow:var(--iqec-shadow-lg);
  color:var(--iqec-text);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}

.iqec-dm-x{
  position:absolute;
  top:12px;
  left:12px;
  width:38px;
  height:38px;
  border:0;
  border-radius:999px;
  background:var(--iqec-surface-muted);
  color:var(--iqec-text);
  font-size:22px;
  line-height:1;
  cursor:pointer;
  z-index:4;
}

.iqec-dm-header{
  flex:0 0 auto;
  padding:22px 22px 10px;
  background:var(--iqec-surface);
}

.iqec-dm-badge{
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  border-radius:999px;
  background:#eff6ff;
  color:#1d4ed8;
  font-size:12px;
  font-weight:700;
  margin-bottom:12px;
}

.iqec-dm-title{
  margin:0;
  font-size:28px;
  line-height:1.3;
  font-weight:800;
  padding-left:42px;
}

.iqec-dm-scroll{
  flex:1 1 auto;
  min-height:0;
  overflow:auto;
  padding:0 22px 18px;
  -webkit-overflow-scrolling:touch;
}

.iqec-dm-subtitle{
  margin:0 0 18px;
  font-size:15px;
  line-height:1.8;
  color:var(--iqec-text-soft);
}

.iqec-dm-progress-wrap{
  margin-bottom:16px;
  padding:14px;
  background:var(--iqec-surface-soft);
  border:1px solid var(--iqec-border);
  border-radius:16px;
}

.iqec-dm-progress-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
  font-size:14px;
}

.iqec-dm-progress-bar{
  width:100%;
  height:10px;
  background:var(--iqec-border);
  border-radius:999px;
  overflow:hidden;
}

.iqec-dm-progress-bar span{
  display:block;
  height:100%;
  background:var(--iqec-primary);
  border-radius:999px;
}

.iqec-dm-all-done{
  margin-bottom:14px;
  padding:14px;
  border-radius:16px;
  background:#f0fdf4;
  border:1px solid #bbf7d0;
}

.iqec-dm-all-done-title{
  font-size:16px;
  font-weight:800;
  color:#166534;
  margin-bottom:4px;
}

.iqec-dm-all-done-subtitle{
  font-size:13px;
  line-height:1.8;
  color:#166534;
}

.iqec-dm-list{
  display:grid;
  gap:12px;
}

.iqec-dm-item{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:12px 14px;
  background:var(--iqec-surface-soft);
  border:1px solid var(--iqec-border);
  border-radius:16px;
}

.iqec-dm-item.is-completed{
  background:#f0fdf4;
  border-color:#bbf7d0;
}

.iqec-dm-num{
  width:28px;
  height:28px;
  border-radius:999px;
  background:var(--iqec-primary);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:700;
  flex:0 0 auto;
  margin-top:2px;
}

.iqec-dm-item.is-completed .iqec-dm-num{
  background:var(--iqec-success);
}

.iqec-dm-text{
  flex:1 1 auto;
}

.iqec-dm-item-title{
  font-size:14px;
  font-weight:800;
  margin-bottom:4px;
}

.iqec-dm-item-desc{
  font-size:13px;
  line-height:1.8;
  color:var(--iqec-text-soft);
}

.iqec-dm-item-status{
  margin-top:6px;
  font-size:12px;
  font-weight:700;
}

.iqec-dm-item-status.is-completed{
  color:#15803d;
}

.iqec-dm-item-status.is-pending{
  color:#b45309;
}

.iqec-dm-footer{
  flex:0 0 auto;
  padding:14px 22px 22px;
  background:var(--iqec-surface);
  border-top:1px solid var(--iqec-border-soft);
  box-shadow:0 -10px 24px rgba(15,23,42,.06);
}

.iqec-dm-actions{
  display:grid;
  gap:10px;
}

.iqec-dm-btn{
  appearance:none;
  border:0;
  border-radius:16px;
  padding:14px 16px;
  font-size:14px;
  font-weight:800;
  cursor:pointer;
  transition:transform .18s ease, opacity .18s ease;
  font-family:var(--iqec-font-family);
}

.iqec-dm-btn:hover{
  transform:translateY(-1px);
}

.iqec-dm-btn-primary{
  background:var(--iqec-primary);
  color:#fff;
}

.iqec-dm-btn-secondary{
  background:var(--iqec-border);
  color:var(--iqec-text);
}

.iqec-dm-btn-ghost{
  background:transparent;
  color:var(--iqec-text-muted);
  border:1px solid var(--iqec-border);
}

/* =========================================================
   TOAST SYSTEM
   ========================================================= */

.iqec-toast-root{
  position:fixed;
  left:16px;
  bottom:16px;
  z-index:999998;
  display:flex;
  flex-direction:column;
  gap:10px;
  width:min(92vw, 380px);
  pointer-events:none;
}

.iqec-toast{
  pointer-events:auto;
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px;
  border-radius:18px;
  background:var(--iqec-toast-bg);
  color:var(--iqec-toast-text);
  box-shadow:var(--iqec-shadow-toast);
  border:1px solid var(--iqec-toast-border);
  opacity:0;
  transform:translateY(10px);
  transition:opacity .22s ease, transform .22s ease;
}

.iqec-toast.is-visible{
  opacity:1;
  transform:translateY(0);
}

.iqec-toast__icon{
  width:38px;
  height:38px;
  border-radius:999px;
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.08);
}

.iqec-toast--success .iqec-toast__icon{
  background:rgba(22,163,74,.18);
  color:var(--iqec-success-light);
}

.iqec-toast--complete .iqec-toast__icon{
  background:rgba(37,99,235,.18);
  color:var(--iqec-primary-light);
}

.iqec-toast__content{
  flex:1 1 auto;
  min-width:0;
}

.iqec-toast__title{
  margin:0 0 4px;
  font-size:14px;
  font-weight:800;
  line-height:1.5;
}

.iqec-toast__body{
  margin:0;
  font-size:13px;
  line-height:1.7;
  color:var(--iqec-toast-text-soft);
}

.iqec-toast__close{
  appearance:none;
  border:0;
  background:transparent;
  color:#cbd5e1;
  cursor:pointer;
  padding:2px;
  flex:0 0 auto;
}

.iqec-toast__close svg,
.iqec-toast__icon svg{
  display:block;
}

/* =========================================================
   Mobile
   ========================================================= */

@media (max-width:640px){
  .iqec-dm-dialog{
    top:auto;
    bottom:0;
    left:0;
    right:0;
    transform:none;
    width:100%;
    max-width:none;
    max-height:min(88vh, calc(100vh - 8px));
    border-radius:22px 22px 0 0;
  }

  .iqec-dm-header{
    padding:16px 16px 10px;
  }

  .iqec-dm-title{
    font-size:24px;
    padding-left:40px;
  }

  .iqec-dm-scroll{
    padding:0 16px 14px;
  }

  .iqec-dm-subtitle{
    font-size:14px;
    line-height:1.75;
  }

  .iqec-dm-footer{
    position:sticky;
    bottom:0;
    padding:12px 16px max(16px, env(safe-area-inset-bottom));
    background:rgba(255,255,255,.98);
    backdrop-filter:blur(10px);
  }

  .iqec-dm-actions{
    gap:8px;
  }

  .iqec-dm-btn{
    padding:13px 14px;
    font-size:13px;
    border-radius:14px;
  }

  .iqec-toast-root{
    left:12px;
    right:12px;
    bottom:12px;
    width:auto;
  }
}

.iqec-dm-destination{
  margin-bottom:14px;
  padding:14px;
  border-radius:16px;
  background:#eff6ff;
  border:1px solid #bfdbfe;
}

.iqec-dm-destination-label{
  font-size:12px;
  font-weight:800;
  color:#1d4ed8;
  margin-bottom:4px;
}

.iqec-dm-destination-text{
  font-size:13px;
  line-height:1.8;
  color:#1e3a8a;
}