/* ==========================================================================
   B2B Design System - Unified Components
   مكونات موحّدة لجميع صفحات المتجر
   ========================================================================== */

/* ------------------------------------------------------------------
   PAGE LAYOUT
   ------------------------------------------------------------------ */
.b2b-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-5);
  padding-top: var(--sp-3);
  gap: var(--sp-4);
}

.b2b-page-title {
  font-size: var(--fs-lg);
  font-weight: var(--fw-black);
  color: var(--text-primary);
  margin: 0;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.b2b-page-subtitle {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--text-primary);
  margin: 0;
}

.b2b-section {
  margin-bottom: var(--sp-5);
}

.b2b-section-title {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--text-primary);
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--border-light);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.b2b-helper-text {
  font-size: var(--fs-xs);
  color: var(--text-helper);
  line-height: var(--lh-normal);
}

/* ------------------------------------------------------------------
   BUTTONS (D1)
   3 sizes: sm (32px) / md (40px) / lg (48px)
   4 types: primary / secondary / danger / link
   ------------------------------------------------------------------ */
.b2b-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  font-family: inherit;
  font-weight: var(--fw-semibold);
  border: 1.5px solid transparent;
  border-radius: var(--radius);
  cursor: pointer;
  transition: all var(--transition-normal);
  text-decoration: none;
  white-space: nowrap;
  line-height: 1;
}

/* Sizes */
.b2b-btn-sm {
  height: var(--btn-height-sm);
  padding: 0 var(--sp-3);
  font-size: var(--fs-xs);
}

.b2b-btn, .b2b-btn-md {
  height: var(--btn-height-md);
  padding: 0 var(--sp-4);
  font-size: var(--fs-sm);
}

.b2b-btn-lg {
  height: var(--btn-height-lg);
  padding: 0 var(--sp-5);
  font-size: var(--fs-md);
}

/* Full width */
.b2b-btn-block {
  width: 100%;
}

/* Primary */
.b2b-btn-primary {
  background: var(--bs-primary, #3b82f6);
  color: #ffffff;
  border-color: var(--bs-primary, #3b82f6);
}
.b2b-btn-primary:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb, 59, 130, 246), 0.3);
  color: #ffffff;
}
.b2b-btn-primary:active {
  transform: translateY(0);
}

/* Secondary */
.b2b-btn-secondary {
  background: var(--bg-card);
  color: var(--text-secondary);
  border-color: var(--border-color);
}
.b2b-btn-secondary:hover {
  border-color: var(--bs-primary, #3b82f6);
  color: var(--bs-primary, #3b82f6);
  background: var(--bg-hover);
}

/* Danger */
.b2b-btn-danger {
  background: var(--color-danger);
  color: #ffffff;
  border-color: var(--color-danger);
}
.b2b-btn-danger:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
  color: #ffffff;
}

/* Link */
.b2b-btn-link {
  background: transparent;
  color: var(--bs-primary, #3b82f6);
  border-color: transparent;
  padding: 0;
  height: auto;
}
.b2b-btn-link:hover {
  text-decoration: underline;
}

/* Loading State */
.b2b-btn.is-loading {
  pointer-events: none;
  opacity: 0.7;
}
.b2b-btn.is-loading .btn-text { display: none; }
.b2b-btn.is-loading::after {
  content: '';
  width: 16px; height: 16px;
  border: 2px solid transparent;
  border-top-color: currentColor;
  border-radius: 50%;
  animation: b2b-spin 0.6s linear infinite;
}

/* Disabled */
.b2b-btn:disabled, .b2b-btn.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}

@keyframes b2b-spin {
  to { transform: rotate(360deg); }
}

/* ------------------------------------------------------------------
   INPUTS (D2)
   ------------------------------------------------------------------ */
.b2b-label {
  display: block;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--text-secondary);
  margin-bottom: var(--sp-2);
  text-align: right;
}

.b2b-label .required {
  color: var(--color-danger);
  margin-inline-start: 2px;
  font-size: var(--fs-sm);
}

.b2b-input {
  width: 100%;
  height: var(--input-height);
  padding: 0 var(--sp-4);
  font-family: inherit;
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--text-primary);
  background: var(--bg-input);
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius);
  outline: none;
  transition: all var(--transition-normal);
  direction: rtl;
  text-align: right;
}

.b2b-input::placeholder {
  color: var(--text-muted);
  font-weight: var(--fw-regular);
  font-size: var(--fs-sm);
}

.b2b-input:focus {
  border-color: var(--border-focus);
  background: var(--bg-card);
  box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb, 59, 130, 246), 0.1);
}

.b2b-input:disabled, .b2b-input[readonly] {
  background: var(--bg-page);
  color: var(--text-muted);
  cursor: not-allowed;
  opacity: 0.7;
}

.b2b-input.is-invalid {
  border-color: var(--color-danger);
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.08);
}

.b2b-input.is-valid {
  border-color: var(--color-success);
}

/* Textarea */
textarea.b2b-input {
  height: auto;
  min-height: 80px;
  padding: var(--sp-3) var(--sp-4);
  resize: vertical;
}

/* Select */
select.b2b-input {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: left var(--sp-3) center;
  padding-left: var(--sp-6);
}

/* Input with icon */
.b2b-input-group {
  position: relative;
}

.b2b-input-group .b2b-input {
  padding-right: 40px;
}

.b2b-input-icon {
  position: absolute;
  right: var(--sp-3);
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  font-size: var(--fs-md);
  pointer-events: none;
  z-index: 2;
  transition: color var(--transition-fast);
}

.b2b-input:focus ~ .b2b-input-icon,
.b2b-input-group:focus-within .b2b-input-icon {
  color: var(--border-focus);
}

/* Error message under input */
.b2b-field-error {
  font-size: var(--fs-xs);
  color: var(--color-danger);
  margin-top: var(--sp-1);
  display: flex;
  align-items: center;
  gap: var(--sp-1);
}

/* Form Group */
.b2b-form-group {
  margin-bottom: var(--sp-4);
}

/* ------------------------------------------------------------------
   CHECKBOX / RADIO / SWITCH (D3)
   ------------------------------------------------------------------ */
.b2b-checkbox-wrapper {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  cursor: pointer;
}

.b2b-checkbox-wrapper input[type="checkbox"],
.b2b-checkbox-wrapper input[type="radio"] {
  width: 18px;
  height: 18px;
  accent-color: var(--bs-primary, #3b82f6);
  cursor: pointer;
  flex-shrink: 0;
}

.b2b-checkbox-wrapper label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--text-secondary);
  cursor: pointer;
}

/* ------------------------------------------------------------------
   CARDS
   ------------------------------------------------------------------ */
.b2b-card {
  background: var(--bg-card);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm);
}

.b2b-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--border-light);
}

.b2b-card-title {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--text-primary);
  margin: 0;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

/* ------------------------------------------------------------------
   BADGES
   ------------------------------------------------------------------ */
.b2b-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--radius);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  white-space: nowrap;
}

.b2b-badge-success { background: var(--color-success-bg); color: var(--color-success); }
.b2b-badge-danger  { background: var(--color-danger-bg);  color: var(--color-danger); }
.b2b-badge-warning { background: var(--color-warning-bg); color: var(--color-warning); }
.b2b-badge-info    { background: var(--color-info-bg);    color: var(--color-info); }
.b2b-badge-neutral { background: var(--bg-page);          color: var(--text-secondary); }

/* ------------------------------------------------------------------
   ALERTS
   ------------------------------------------------------------------ */
.b2b-alert {
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
  text-align: right;
}

.b2b-alert-success { background: var(--color-success-bg); color: #065f46; border: 1px solid #bbf7d0; }
.b2b-alert-danger  { background: var(--color-danger-bg);  color: #991b1b; border: 1px solid #fecaca; }
.b2b-alert-warning { background: var(--color-warning-bg); color: #92400e; border: 1px solid #fde68a; }
.b2b-alert-info    { background: var(--color-info-bg);    color: #1e40af; border: 1px solid #bfdbfe; }

/* ------------------------------------------------------------------
   EMPTY STATE
   ------------------------------------------------------------------ */
.b2b-empty-state {
  text-align: center;
  padding: var(--sp-6) var(--sp-4);
}

.b2b-empty-state-icon {
  font-size: 56px;
  color: var(--border-color);
  margin-bottom: var(--sp-4);
}

.b2b-empty-state-title {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--text-primary);
  margin-bottom: var(--sp-2);
}

.b2b-empty-state-desc {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  margin-bottom: var(--sp-5);
}

/* ------------------------------------------------------------------
   BACK BUTTON
   ------------------------------------------------------------------ */
.b2b-back-btn {
  width: var(--btn-height-md);
  height: var(--btn-height-md);
  border-radius: 50%;
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-primary);
  text-decoration: none;
  transition: all var(--transition-normal);
  box-shadow: var(--shadow-xs);
  flex-shrink: 0;
}

.b2b-back-btn:hover {
  background: var(--bg-hover);
  color: var(--bs-primary, #3b82f6);
  transform: scale(1.05);
}

[dir="rtl"] .b2b-back-btn i {
  transform: rotate(180deg);
}

/* ------------------------------------------------------------------
   TOAST (Unified)
   ------------------------------------------------------------------ */
.b2b-toast-container {
  position: fixed;
  top: var(--sp-5);
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.b2b-toast {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: var(--sp-3) var(--sp-5);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  min-width: 300px;
  box-shadow: var(--shadow-lg);
  direction: rtl;
  animation: b2b-toastIn 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.b2b-toast.removing {
  animation: b2b-toastOut 0.3s ease forwards;
}

@keyframes b2b-toastIn {
  from { opacity: 0; transform: translateY(-16px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes b2b-toastOut {
  to { opacity: 0; transform: translateY(-16px) scale(0.96); }
}

.b2b-toast-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-sm);
  flex-shrink: 0;
}

.b2b-toast-icon.success { background: var(--color-success-bg); color: var(--color-success); }
.b2b-toast-icon.error   { background: var(--color-danger-bg);  color: var(--color-danger); }
.b2b-toast-icon.warning { background: var(--color-warning-bg); color: var(--color-warning); }

.b2b-toast-text {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--text-primary);
}

/* ------------------------------------------------------------------
   MODAL (Custom)
   ------------------------------------------------------------------ */
.b2b-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.3);
  backdrop-filter: blur(4px);
  z-index: 1055;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  padding: var(--sp-4);
}

.b2b-modal-overlay.show {
  opacity: 1;
  pointer-events: auto;
}

.b2b-modal {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  padding: var(--sp-6);
  width: 100%;
  max-width: var(--modal-md);
  transform: scale(0.95) translateY(16px);
  transition: transform var(--transition-slow);
  box-shadow: var(--shadow-xl);
  max-height: 85vh;
  overflow-y: auto;
}

.b2b-modal-sm { max-width: var(--modal-sm); }
.b2b-modal-lg { max-width: var(--modal-lg); }

.b2b-modal-overlay.show .b2b-modal {
  transform: scale(1) translateY(0);
}

.b2b-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--border-light);
}

.b2b-modal-title {
  font-size: var(--fs-lg);
  font-weight: var(--fw-black);
  color: var(--text-primary);
  margin: 0;
}

.b2b-modal-close {
  width: 32px;
  height: 32px;
  border-radius: var(--radius);
  border: 1px solid var(--border-color);
  background: var(--bg-page);
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  font-size: var(--fs-sm);
}

.b2b-modal-close:hover {
  background: var(--color-danger-bg);
  border-color: var(--color-danger);
  color: var(--color-danger);
}

.b2b-modal-body {
  color: var(--text-secondary);
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
}

/* Modal scrollbar */
.b2b-modal::-webkit-scrollbar { width: 4px; }
.b2b-modal::-webkit-scrollbar-track { background: transparent; }
.b2b-modal::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 4px; }

/* ------------------------------------------------------------------
   CONTACT CARD (Auth pages)
   ------------------------------------------------------------------ */
.b2b-contact-card {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3);
  background: var(--bg-input);
  border-radius: var(--radius);
  border: 1px solid var(--border-light);
  transition: all var(--transition-normal);
  text-decoration: none;
  cursor: pointer;
}

.b2b-contact-card:hover {
  border-color: var(--bs-primary, #3b82f6);
  background: var(--bg-card);
}

.b2b-contact-card-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-md);
  flex-shrink: 0;
}

.b2b-contact-card-label {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  margin-bottom: 2px;
}

.b2b-contact-card-value {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--text-primary);
}

/* ------------------------------------------------------------------
   RESPONSIVE UTILITIES
   ------------------------------------------------------------------ */
@media (max-width: 576px) {
  :root {
    --sp-5: 16px;
    --sp-6: 24px;
  }

  .b2b-card {
    padding: var(--sp-4);
    border-radius: var(--radius);
  }

  .b2b-page-title {
    font-size: 18px;
  }

  .b2b-modal {
    padding: var(--sp-4);
    border-radius: var(--radius-lg);
  }
}
