/* =====================================================
   components.css — مكونات UI
   ===================================================== */

/* ── البطاقات ── */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
  margin-bottom: var(--spacing-lg);
  overflow: hidden;
}
.card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.card-header {
  padding: var(--spacing-md) var(--spacing-lg);
  border-bottom: 1px solid var(--color-border);
  font-weight: 600;
  font-size: var(--font-size-md);
  background: transparent;
}
.card-body { padding: var(--spacing-lg); }
.card-footer {
  padding: var(--spacing-sm) var(--spacing-lg);
  border-top: 1px solid var(--color-border);
  background: var(--color-surface-2);
}

/* بطاقات الإحصاء */
.stat-card {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  transition: all var(--transition-normal);
  position: relative;
  overflow: hidden;
}
.stat-card::before {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 80px; height: 80px;
  border-radius: 0 var(--radius-lg) 0 100%;
  opacity: 0.08;
}
.stat-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.stat-card .stat-icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.stat-card .stat-label {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  font-weight: 500;
}
.stat-card .stat-value {
  font-size: var(--font-size-2xl);
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.1;
}
.stat-card .stat-sub {
  font-size: var(--font-size-xs);
  color: var(--color-text-light);
}

/* بطاقات الأقسام */
.section-card {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: var(--spacing-xl);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border);
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: var(--spacing-sm);
  transition: all var(--transition-normal);
  height: 100%;
}
.section-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.section-card .section-icon {
  width: 64px; height: 64px;
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px;
  margin-bottom: var(--spacing-sm);
}
.section-card h5 { font-weight: 700; font-size: var(--font-size-md); color: var(--color-text); }
.section-card p { font-size: var(--font-size-sm); color: var(--color-text-muted); flex-grow: 1; }

/* ── الأزرار ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 10px 20px;
  border-radius: var(--radius-md);
  font-family: var(--font-family);
  font-size: var(--font-size-sm);
  font-weight: 600;
  border: none; cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
  text-decoration: none;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn-primary {
  background: var(--color-dark);
  color: var(--color-text-white);
  box-shadow: 0 2px 8px rgba(26,26,46,0.3);
}
.btn-primary:hover { background: var(--color-dark-2); color: white; box-shadow: 0 4px 12px rgba(26,26,46,0.4); }

.btn-accent {
  background: var(--color-accent);
  color: var(--color-dark);
  box-shadow: 0 2px 8px var(--color-accent-glow);
}
.btn-accent:hover { background: var(--color-accent-dark); color: var(--color-dark); }

.btn-success  { background: var(--color-success); color: white; }
.btn-success:hover { background: #059669; color: white; }
.btn-danger   { background: var(--color-danger); color: white; }
.btn-danger:hover  { background: #DC2626; color: white; }
.btn-warning  { background: var(--color-warning); color: white; }
.btn-warning:hover { background: #D97706; color: white; }
.btn-info     { background: var(--color-info); color: white; }
.btn-info:hover    { background: #2563EB; color: white; }
.btn-secondary { background: var(--color-surface-2); color: var(--color-text-muted); border: 1px solid var(--color-border); }
.btn-secondary:hover { background: #E5E1D8; color: var(--color-text); }

.btn-outline-primary { background: transparent; color: var(--color-dark); border: 1.5px solid var(--color-dark); }
.btn-outline-primary:hover { background: var(--color-dark); color: white; }
.btn-outline-danger { background: transparent; color: var(--color-danger); border: 1.5px solid var(--color-danger); }
.btn-outline-danger:hover { background: var(--color-danger); color: white; }
.btn-outline-secondary { background: transparent; color: var(--color-text-muted); border: 1.5px solid var(--color-border); }
.btn-outline-secondary:hover { background: var(--color-surface-2); color: var(--color-text); }

.btn-sm { padding: 6px 12px; font-size: var(--font-size-xs); border-radius: var(--radius-sm); }
.btn-lg { padding: 14px 28px; font-size: var(--font-size-md); border-radius: var(--radius-md); }
.btn-xl { padding: 16px 36px; font-size: var(--font-size-lg); border-radius: var(--radius-md); }

.btn:disabled, .btn.disabled {
  opacity: 0.5; cursor: not-allowed; pointer-events: none; transform: none;
}

/* ── الجداول ── */
.modern-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--font-size-sm);
}
.modern-table thead th {
  background: var(--color-dark);
  color: white;
  padding: 12px 16px;
  font-weight: 600;
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border: none;
  white-space: nowrap;
}
.modern-table thead th:first-child { border-radius: 0 var(--radius-sm) 0 0; }
.modern-table thead th:last-child  { border-radius: var(--radius-sm) 0 0 0; }

.modern-table tbody tr {
  transition: background var(--transition-fast);
  border-bottom: 1px solid var(--color-border);
}
.modern-table tbody tr.table-secondary {
    background-color: var(--secondary-cream);
    color: var(--dark-navy);
}

.modern-table tbody tr.table-secondary td {
    opacity: 0.8;
}
.modern-table tbody tr:hover { background: var(--color-surface-2); }
.modern-table tbody tr.table-danger { background: var(--color-danger-bg); }
.modern-table tbody tr.table-danger:hover { background: #FEE2E2; }
.modern-table tbody tr.table-warning { background: var(--color-warning-bg); }
.modern-table tbody tr.table-success { background: var(--color-success-bg); }
.modern-table tbody td {
  padding: 12px 16px;
  color: var(--color-text);
  vertical-align: middle;
  border: none;
}
.modern-table tfoot td, .modern-table tfoot th {
  padding: 12px 16px;
  font-weight: 600;
  background: var(--color-surface-2);
  border-top: 2px solid var(--color-border);
}
.table-responsive { overflow-x: auto; border-radius: var(--radius-md); border: 1px solid var(--color-border); }

/* Override Bootstrap table classes */
.table { margin-bottom: 0; }
.table-striped tbody tr:nth-of-type(odd) { background: rgba(0,0,0,0.015); }
.table-striped tbody tr:nth-of-type(odd):hover { background: var(--color-surface-2); }
.table-dark { background: var(--color-dark); }
.table-light { background: var(--color-surface-2); }

/* ── النماذج ── */
.form-label {
  font-weight: 600;
  font-size: var(--font-size-sm);
  color: var(--color-text);
  margin-bottom: 6px;
  display: block;
}
.form-control, .form-select {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-family);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  background: var(--color-surface);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  outline: none;
}
.form-control:focus, .form-select:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px var(--color-accent-glow);
}
.form-control.is-invalid { border-color: var(--color-danger); }
.form-control.is-invalid:focus { box-shadow: 0 0 0 3px rgba(239,68,68,0.2); }
.form-control-lg { padding: 13px 16px; font-size: var(--font-size-base); }

.input-group {
  display: flex;
  align-items: stretch;
}
.input-group .form-control { border-radius: var(--radius-sm) 0 0 var(--radius-sm); flex: 1; }
.input-group .btn { border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }
.input-group-text {
  padding: 10px 14px;
  background: var(--color-surface-2);
  border: 1.5px solid var(--color-border);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

.form-check-input {
  width: 18px; height: 18px;
  border: 2px solid var(--color-border);
  border-radius: 4px;
  cursor: pointer;
  accent-color: var(--color-dark);
}

/* ── التنبيهات ── */
.alert {
  padding: var(--spacing-md) var(--spacing-lg);
  border-radius: var(--radius-md);
  border: none;
  font-size: var(--font-size-sm);
  font-weight: 500;
  margin-bottom: var(--spacing-md);
  display: flex; align-items: flex-start; gap: 10px;
}
.alert::before { font-family: 'Font Awesome 6 Free'; font-weight: 900; margin-top: 2px; flex-shrink: 0; }
.alert-success  { background: var(--color-success-bg); color: #065F46; }
.alert-success::before  { content: '\f058'; color: var(--color-success); }
.alert-danger   { background: var(--color-danger-bg);  color: #991B1B; }
.alert-danger::before   { content: '\f057'; color: var(--color-danger); }
.alert-warning  { background: var(--color-warning-bg); color: #92400E; }
.alert-warning::before  { content: '\f071'; color: var(--color-warning); }
.alert-info     { background: var(--color-info-bg);    color: #1E40AF; }
.alert-info::before     { content: '\f05a'; color: var(--color-info); }

/* ── الشارات ── */
.badge {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  font-size: var(--font-size-xs);
  font-weight: 700;
}
.bg-success { background: var(--color-success-bg) !important; color: var(--color-success) !important; }
.bg-danger  { background: var(--color-danger-bg)  !important; color: var(--color-danger)  !important; }
.bg-warning { background: var(--color-warning-bg) !important; color: var(--color-warning) !important; }
.bg-info    { background: var(--color-info-bg)    !important; color: var(--color-info)    !important; }
.bg-dark    { background: var(--color-dark)        !important; color: white                !important; }
.bg-light   { background: var(--color-surface-2)  !important; color: var(--color-text)   !important; }

/* عنوان الصفحة */
.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-xl);
}
.page-header h1, .page-header h2 {
  font-size: var(--font-size-xl);
  font-weight: 700;
  color: var(--color-text);
  display: flex; align-items: center; gap: 10px;
  margin: 0;
}
.page-header h1 i, .page-header h2 i { color: var(--color-accent-dark); }

/* فلاتر Pill */
.filter-pills {
  display: flex;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
  align-items: center;
}
.filter-pill {
  padding: 8px 18px;
  border-radius: var(--radius-pill);
  font-size: var(--font-size-sm);
  font-weight: 600;
  cursor: pointer;
  border: 1.5px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
  transition: all var(--transition-fast);
}
.filter-pill:hover { border-color: var(--color-accent); color: var(--color-accent-dark); }
.filter-pill.active { background: var(--color-dark); color: white; border-color: var(--color-dark); }

/* قائمة نتائج البحث */
.list-group { border-radius: var(--radius-md); overflow: hidden; }
.list-group-item {
  padding: 12px 16px;
  border: none;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text);
  font-size: var(--font-size-sm);
  transition: background var(--transition-fast);
}
.list-group-item:hover, .list-group-item.active-highlight {
  background: var(--color-accent-light);
  cursor: pointer;
}
.list-group-item:last-child { border-bottom: none; }

/* modal */
.modal {
  display: none;
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(4px);
  z-index: 2000;
  padding: 1rem;
}
.modal.show { display: flex; align-items: center; justify-content: center; }

.modal-dialog {
  width: 100%;
  max-width: 600px;
  margin: auto;
  pointer-events: none;
}
.modal-content {
  background: var(--color-surface);
  border: none;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  pointer-events: auto;
  display: flex; flex-direction: column;
  max-height: 90vh;
}
.modal-header {
  border-bottom: 1px solid var(--color-border);
  padding: var(--spacing-lg);
  display: flex; align-items: center; justify-content: space-between;
}
.modal-body { padding: var(--spacing-lg); overflow-y: auto; }
.modal-footer {
  border-top: 1px solid var(--color-border);
  padding: var(--spacing-md) var(--spacing-lg);
  display: flex; gap: var(--spacing-sm);
}

/* Dropdown */
.dropdown-menu {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-lg) !important;
  padding: 6px !important;
  background: var(--color-surface) !important;
}
.dropdown-item {
  border-radius: var(--radius-xs);
  padding: 8px 14px !important;
  font-size: var(--font-size-sm) !important;
  color: var(--color-text) !important;
  transition: background var(--transition-fast);
}
.dropdown-item:hover { background: var(--color-surface-2) !important; color: var(--color-text) !important; }
