/* =====================================================
   نظام إتقان — نظام التصميم الموحّد (Design System)
   theme.css
   ---------------------------------------------------
   مصدر موحّد للرموز التصميمية (Tokens) والمكوّنات القياسية.
   يُحمَّل بعد styles.css ليكمّله. الأنماط السطرية في الصفحات
   تبقى لها الأسبقية (لا كسر للقائم)، وهذه المكوّنات هي المرجع
   لأي واجهة جديدة وللتوحيد التدريجي.
   ===================================================== */

/* ===== رموز إضافية (Design Tokens) ===== */
:root {
  /* حالات لونية موحّدة */
  --success: #10b981;
  --success-bg: rgba(16, 185, 129, .12);
  --warning: #f59e0b;
  --warning-bg: rgba(245, 158, 11, .14);
  --danger: #ef4444;
  --danger-bg: rgba(239, 68, 68, .12);
  --info: #3b82f6;
  --info-bg: rgba(59, 130, 246, .12);
  --neutral-bg: rgba(255, 255, 255, .06);

  /* سُلّم المسافات */
  --sp-1: .25rem;
  --sp-2: .5rem;
  --sp-3: .75rem;
  --sp-4: 1rem;
  --sp-5: 1.5rem;
  --sp-6: 2rem;

  /* سُلّم الحواف */
  --radius-lg: 16px;
  --radius-md: 12px;
  --radius-pill: 50px;

  /* الظلال */
  --shadow-sm: 0 4px 15px rgba(0, 0, 0, .15);
  --shadow-md: 0 8px 25px rgba(5, 150, 105, .15);

  --surface: var(--bg-card, #111827);
  --surface-2: rgba(255, 255, 255, .03);
}

/* ===== القائمة الجانبية المجمّعة (اقتباس إتحاف) ===== */
.nav-group { margin-bottom: .35rem; }

.nav-group-title {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--text-muted, #6b7280);
  padding: .55rem .8rem .3rem;
  margin-top: .3rem;
  user-select: none;
}
.nav-group-title::before {
  content: "";
  width: 14px;
  height: 1px;
  background: var(--border);
  flex-shrink: 0;
}

/* في الوضع المطوي (الجوال) نُخفي عناوين المجموعات ونُبقي الأيقونات */
@media (max-width: 768px) {
  .nav-group-title { justify-content: center; font-size: 0; padding: .4rem 0; }
  .nav-group-title::before { width: 60%; }
}

/* ===== الأزرار الموحّدة (ds- مساحة أسماء آمنة) ===== */
.ds-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .6rem 1.1rem;
  border-radius: var(--radius-sm, 8px);
  font-family: var(--font-main, 'Tajawal', sans-serif);
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid transparent;
  transition: var(--transition, all .2s ease);
  text-decoration: none;
  white-space: nowrap;
}
.ds-btn:active { transform: translateY(1px); }
.ds-btn-primary { background: var(--gradient-primary); color: #fff; box-shadow: 0 6px 18px rgba(5, 150, 105, .25); }
.ds-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 10px 26px rgba(5, 150, 105, .35); }
.ds-btn-ghost { background: transparent; color: var(--text-primary); border-color: var(--border); }
.ds-btn-ghost:hover { background: var(--bg-card-hover, #1f2937); border-color: var(--primary); }
.ds-btn-danger { background: var(--danger); color: #fff; }
.ds-btn-danger:hover { filter: brightness(1.08); }
.ds-btn-sm { padding: .35rem .7rem; font-size: .8rem; }
.ds-btn-block { width: 100%; }

/* ===== شارات الحالة الموحّدة ===== */
.ds-badge {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .18rem .6rem;
  border-radius: var(--radius-pill);
  font-size: .72rem;
  font-weight: 600;
  line-height: 1.6;
}
.ds-badge-success { background: var(--success-bg); color: var(--success); }
.ds-badge-warning { background: var(--warning-bg); color: var(--warning); }
.ds-badge-danger  { background: var(--danger-bg);  color: var(--danger); }
.ds-badge-info    { background: var(--info-bg);    color: var(--info); }
.ds-badge-neutral { background: var(--neutral-bg); color: var(--text-secondary); }

/* ===== البطاقات ===== */
.ds-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.ds-card-pad { padding: var(--sp-5); }
.ds-card-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--border);
}
.ds-card-hdr h3, .ds-card-hdr h4 { margin: 0; font-size: .98rem; color: var(--primary-light); }

/* ===== بطاقة إحصائية ===== */
.ds-stat {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--sp-5);
  text-align: center;
  transition: var(--transition);
}
.ds-stat:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: rgba(5, 150, 105, .4); }
.ds-stat .num { font-size: 2rem; font-weight: 800; color: var(--primary-light); margin: 0; }
.ds-stat .lbl { color: var(--text-secondary); font-size: .82rem; margin-top: .3rem; }
.ds-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--sp-4); }

/* ===== الجداول ===== */
.ds-table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.ds-table thead th {
  text-align: right;
  padding: .7rem .9rem;
  color: var(--text-secondary);
  font-weight: 600;
  border-bottom: 1px solid var(--border);
  background: var(--surface-2);
}
.ds-table tbody td { padding: .7rem .9rem; border-bottom: 1px solid var(--border); }
.ds-table tbody tr:hover { background: var(--surface-2); }
.ds-table tbody tr:last-child td { border-bottom: none; }

/* ===== الحقول ===== */
.ds-field { display: flex; flex-direction: column; gap: .4rem; margin-bottom: var(--sp-4); }
.ds-field label { font-size: .82rem; color: var(--text-secondary); font-weight: 500; }
.ds-field input, .ds-field select, .ds-field textarea {
  padding: .65rem .8rem;
  background: var(--bg-dark, #0a0f1a);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm, 8px);
  color: var(--text-primary);
  font-family: inherit;
  font-size: .9rem;
  transition: var(--transition);
}
.ds-field input:focus, .ds-field select:focus, .ds-field textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(5, 150, 105, .18);
}
.ds-field-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--sp-4); }

/* ===== عنوان الصفحة ===== */
.ds-page-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-4);
  margin-bottom: var(--sp-5);
}
.ds-page-hdr h2 { margin: 0; font-size: 1.5rem; }
.ds-page-hdr .sub { color: var(--text-secondary); font-size: .85rem; margin-top: .2rem; }

/* ===== التبويبات ===== */
.ds-tabs { display: flex; gap: .3rem; border-bottom: 1px solid var(--border); margin-bottom: var(--sp-5); flex-wrap: wrap; }
.ds-tab {
  padding: .6rem 1rem;
  cursor: pointer;
  color: var(--text-secondary);
  font-size: .88rem;
  font-weight: 500;
  border-bottom: 2px solid transparent;
  transition: var(--transition);
}
.ds-tab:hover { color: var(--text-primary); }
.ds-tab.active { color: var(--primary-light); border-bottom-color: var(--primary); }

/* ===== حالة فارغة ===== */
.ds-empty {
  text-align: center;
  padding: var(--sp-6) var(--sp-4);
  color: var(--text-secondary);
}
.ds-empty .icon { font-size: 2.5rem; opacity: .6; margin-bottom: var(--sp-3); }
.ds-empty .title { font-weight: 600; color: var(--text-primary); margin-bottom: .3rem; }
.ds-empty .desc { font-size: .85rem; }

/* ===== شريحة معلومات (chip) ===== */
.ds-chip {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .25rem .7rem;
  background: var(--neutral-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  font-size: .78rem;
  color: var(--text-secondary);
}

/* ===== أدوات مساعدة ===== */
.ds-stack { display: flex; flex-direction: column; gap: var(--sp-4); }
.ds-row { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.ds-spacer { flex: 1; }
.ds-muted { color: var(--text-muted); }
.ds-text-secondary { color: var(--text-secondary); }

/* =====================================================
   نظام الثيمات: فاتح (افتراضي) × داكن — هوية مدموجة إتقان × إتحاف
   ---------------------------------------------------
   :root = الوضع الفاتح (عاجي/زيتي إتحاف + زمردي إتقان) وهو الافتراضي.
   [data-theme="dark"] = الوضع الداكن المرتقى.
   كل القيم تُعيد تعريف الرموز الأساسية فتنتشر تلقائياً على كل
   مكوّنات اللوحات (التي تستعمل var()) دون تعديل صفحات. theme.css
   يأتي بعد styles.css فيسود. التبديل عبر data-theme على <html>.
   ===================================================== */

/* ===== الوضع الفاتح (الافتراضي) ===== */
:root {
  color-scheme: light;

  /* الأساسي: زمردي إتقان (بدرجة مقروءة على الفاتح) */
  --primary: #0e9e6e;
  --primary-dark: #0a7d56;
  --primary-light: #0c8f63;        /* يُستخدم كلون نص → غامق كفاية على الأبيض */
  --secondary: #0d9488;            /* تيل إتحاف */
  /* الذهبي = زيتي إتحاف (خاكي) للتمييز */
  --accent: #9a8444;
  --gold: #9a8444;

  /* سطوح فاتحة دافئة (عاجية) */
  --bg-dark: #f5f6f2;              /* خلفية الصفحة */
  --bg-card: #ffffff;             /* البطاقات */
  --bg-card-hover: #f1f3ee;

  --text-primary: #1f2a37;
  --text-secondary: #5b6573;
  --text-muted: #9aa3ad;

  --border: rgba(20, 30, 45, .10);
  --shadow: 0 12px 30px -10px rgba(20, 30, 45, .14);
  --shadow-md: 0 8px 22px rgba(14, 158, 110, .14);

  /* تراكبات داخلية (تتبدّل مع الثيم) */
  --inset: rgba(20, 30, 45, .045);
  --inset-soft: rgba(20, 30, 45, .025);
  --inset-strong: rgba(20, 30, 45, .08);

  /* تدرّجات الهوية المدموجة */
  --gradient-primary: linear-gradient(135deg, #0e9e6e 0%, #0d9488 100%);
  --gradient-gold: linear-gradient(135deg, #8f7a3e 0%, #b29a55 50%, #8f7a3e 100%);
  --gradient-bg: linear-gradient(180deg, #f6f7f3 0%, #eef1ea 55%, #f6f7f3 100%);

  --surface: #ffffff;
  --surface-2: rgba(20, 30, 45, .03);
  --neutral-bg: rgba(20, 30, 45, .05);

  /* القائمة الجانبية */
  --side-bg: linear-gradient(180deg, #ffffff 0%, #fbfbf7 100%);
  --side-border: rgba(20, 30, 45, .08);

  /* حالة القائمة النشطة بأسلوب إتحاف (كريمي زيتي) */
  --nav-active-bg: linear-gradient(90deg, rgba(154, 132, 68, .16), rgba(154, 132, 68, .03));
  --nav-active-fg: #6e5d2c;
  --nav-active-bar: var(--gold);
  --nav-hover-bg: rgba(14, 158, 110, .08);
}

/* ===== الوضع الداكن ===== */
[data-theme="dark"] {
  color-scheme: dark;

  --primary: #0ea371;
  --primary-dark: #0b7d57;
  --primary-light: #34d399;
  --secondary: #0d9488;
  --accent: #f0b429;
  --gold: #e3b341;

  --bg-dark: #0a0f17;
  --bg-card: #131b27;
  --bg-card-hover: #1b2535;

  --text-primary: #f9fafb;
  --text-secondary: #9ca3af;
  --text-muted: #6b7280;

  --border: rgba(255, 255, 255, .08);
  --shadow: 0 20px 45px -12px rgba(0, 0, 0, .55);
  --shadow-md: 0 10px 28px rgba(14, 163, 113, .18);

  --inset: rgba(255, 255, 255, .05);
  --inset-soft: rgba(255, 255, 255, .03);
  --inset-strong: rgba(255, 255, 255, .10);

  --gradient-primary: linear-gradient(135deg, #0ea371 0%, #0d9488 100%);
  --gradient-gold: linear-gradient(135deg, #e3b341 0%, #f7d774 50%, #e3b341 100%);
  --gradient-bg: linear-gradient(180deg, #0a0f17 0%, #0f1622 55%, #0a0f17 100%);

  --surface: #131b27;
  --surface-2: rgba(255, 255, 255, .035);
  --neutral-bg: rgba(255, 255, 255, .06);

  --side-bg: linear-gradient(180deg, rgba(13, 21, 33, .98) 0%, rgba(10, 15, 23, .98) 100%);
  --side-border: rgba(255, 255, 255, .08);

  --nav-active-bg: linear-gradient(90deg, rgba(14, 163, 113, .20), rgba(14, 163, 113, .04));
  --nav-active-fg: var(--primary-light);
  --nav-active-bar: var(--primary);
  --nav-hover-bg: rgba(14, 163, 113, .10);
}

/* تنعيم انتقال تبديل الثيم */
body, .side, .main, .card, .st-card, .st, .ds-card, .mi {
  transition: background-color .25s ease, color .25s ease, border-color .25s ease;
}

/* القائمة الجانبية تتبع الثيم (تتجاوز القيم الداكنة المثبّتة في الصفحات) */
.dash .side {
  background: var(--side-bg) !important;
  border-left: 1px solid var(--side-border);
  backdrop-filter: blur(12px);
}
.dash .side-hdr h3 {
  background: var(--gradient-gold);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 800;
}
.dash .side nav .mi { border-radius: 10px; transition: background .2s ease, color .2s ease, box-shadow .2s ease; }
.dash .side nav .mi:hover { background: var(--nav-hover-bg); color: var(--primary); }
.dash .side nav .mi.active {
  background: var(--nav-active-bg);
  color: var(--nav-active-fg);
  font-weight: 600;
  box-shadow: inset -3px 0 0 0 var(--nav-active-bar);
}

/* --- بطاقات الإحصاء: لمسة علوية ملوّنة --- */
.main .st-card { position: relative; overflow: hidden; }
.main .st-card::before {
  content: "";
  position: absolute;
  top: 0; right: 0; left: 0;
  height: 3px;
  background: var(--gradient-primary);
  opacity: .9;
}
.main .st-card:hover { box-shadow: var(--shadow-md); border-color: rgba(14, 158, 110, .35); }

/* --- ترويسات البطاقات: شريط رفيع يمين العنوان --- */
.main .card-hdr h3, .main .card-hdr h4 { position: relative; padding-right: .7rem; }
.main .card-hdr h3::before, .main .card-hdr h4::before {
  content: "";
  position: absolute;
  right: 0; top: 50%;
  transform: translateY(-50%);
  width: 3px; height: 1em;
  border-radius: 2px;
  background: var(--gradient-primary);
}

/* خيارات القوائم المنسدلة حسب الثيم (تتجاوز القاعدة العامة في styles.css) */
:root select, :root input, :root textarea { color-scheme: light; }
[data-theme="dark"] select, [data-theme="dark"] input, [data-theme="dark"] textarea { color-scheme: dark; }
:root select option { background-color: #ffffff !important; color: #1f2a37 !important; }
[data-theme="dark"] select option { background-color: #1f2937 !important; color: #ffffff !important; }

/* زر مبدّل الثيم */
.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  cursor: pointer;
  background: var(--inset);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  border-radius: 8px;
  padding: .5rem .7rem;
  font-family: inherit;
  font-size: .85rem;
  transition: var(--transition);
}
.theme-toggle:hover { color: var(--primary); border-color: var(--primary); }
/* داخل القائمة الجانبية: يظهر كعنصر قائمة نظيف */
.side .theme-toggle { background: transparent; border: none; padding: .7rem .8rem; width: 100%; }
.side .theme-toggle:hover { background: var(--nav-hover-bg); }

/* مربّع نص المصحف (Amiri) يتبع الثيم — صفحة QCF .qcf-page تبقى ورقية دائماً */
.main .quran-box { background: var(--surface-2); color: var(--text-primary); }

/* مكوّنات النظام الموحّد تتبع نفس الترقية تلقائياً عبر var() */
