/* ===== منصة العربة — مكونات الواجهة (متجاوب) ===== */

.page-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--spacing-md);
}
@media (max-width: 576px) {
  .page-wrap { padding: 0 var(--spacing-sm); }
}

.page-title {
  font-weight: 700;
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-md);
  font-size: 1.5rem;
  line-height: 1.3;
}
@media (max-width: 576px) {
  .page-title { font-size: 1.25rem; }
}

.card-ui {
  background: var(--color-bg-panel);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--spacing-lg);
}
@media (max-width: 576px) {
  .card-ui { padding: var(--spacing-md); border-radius: var(--radius-md); }
}

.input-ui {
  width: 100%;
  min-height: 44px;
  padding: 0.6rem 0.85rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-input);
  background: var(--color-bg-panel);
  color: var(--color-text-primary);
  font-size: 1rem;
  transition: border var(--transition-fast);
}
.input-ui:focus {
  outline: none;
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px var(--color-brand-focus);
}
@media (max-width: 576px) {
  .input-ui { min-height: 48px; }
}

.btn-ui {
  min-height: 44px;
  padding: 0.6rem 1rem;
  border-radius: var(--radius-sm);
  border: none;
  cursor: pointer;
  font-weight: 500;
  font-size: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  transition: var(--transition-fast);
}
.btn-primary-ui {
  background: var(--color-brand);
  color: #fff;
}
.btn-primary-ui:hover {
  background: var(--color-brand-hover);
  color: #fff;
}

.table-ui { width: 100%; border-collapse: collapse; }
.table-ui th {
  background: var(--color-bg-subtle);
  color: var(--color-text-secondary);
  padding: 0.75rem 1rem;
  text-align: right;
  font-weight: 600;
  font-size: 0.875rem;
}
.table-ui td { padding: 0.75rem 1rem; border-bottom: 1px solid var(--color-border); }
@media (max-width: 768px) {
  .table-ui th, .table-ui td { padding: 0.6rem 0.5rem; font-size: 0.875rem; }
}

.card-ui .table-responsive {
  border-radius: var(--radius-md);
  overflow: hidden;
}
.table .badge { font-weight: 600; }

/* أزرار Bootstrap موحدة مع الثيم */
.btn-primary {
  background: var(--color-brand);
  border-color: var(--color-brand);
  color: #fff;
  font-weight: 500;
  padding: 0.5rem 1rem;
  border-radius: var(--radius-sm);
  min-height: 44px;
}
.btn-primary:hover {
  background: var(--color-brand-hover);
  border-color: var(--color-brand-hover);
  color: #fff;
}
.btn-success { background: var(--color-success); border-color: var(--color-success); }
.btn-success:hover { background: #0d9668; border-color: #0d9668; color: #fff; }
.btn-danger { background: var(--color-danger); border-color: var(--color-danger); }
.btn-danger:hover { background: #dc2626; border-color: #dc2626; color: #fff; }
.btn-warning { background: var(--color-warning); border-color: var(--color-warning); color: #000; }
.btn-info { background: var(--color-info); border-color: var(--color-info); color: #fff; }
.btn-outline-primary { color: var(--color-brand); border-color: var(--color-brand); }
.btn-outline-primary:hover { background: var(--color-brand); border-color: var(--color-brand); color: #fff; }
.btn-outline-secondary { border-radius: var(--radius-sm); }
.btn-outline-danger:hover { color: #fff; }

.btn-sm { min-height: 38px; padding: 0.35rem 0.75rem; }
@media (max-width: 576px) {
  .btn { min-height: 44px; }
  .btn-sm { min-height: 40px; }
}

.alert-success { background: var(--color-success-bg); border-color: var(--color-success); color: var(--color-text-dark); }
.alert-danger { background: var(--color-danger-bg); border-color: var(--color-danger); color: var(--color-text-dark); }
.alert-warning { background: var(--color-warning-bg); border-color: var(--color-warning); color: var(--color-text-dark); }
.alert-info { background: var(--color-info-bg); border-color: var(--color-info); color: var(--color-text-dark); }
