/* =============================================================
   WhatsApp Shop – style.css
   RTL-first, no external dependencies.
   ============================================================= */

/* ── Design Tokens (CSS Variables) ─────────────────────────── */
:root {
  /* ── Brand / Primary ── */
  --was-primary: #25d366;
  --was-primary-dark: #1ab857;
  --was-primary-darker: #128c40;
  --was-primary-darkest: #0d7a3e;
  --was-primary-light: #1ebe5d;
  --was-primary-gradient: linear-gradient(135deg, #25d366, #1ab857);
  --was-primary-hover-bg: #c0e8d0;
  --was-primary-selected: #edfff4;
  --was-primary-hover-light: #f8fff8;
  --was-primary-free-bg: #e8f5e9;
  --was-primary-free-text: #2e7d32;

  /* ── Secondary / Accent (proceed / info) ── */
  --was-accent: #4f8ef7;
  --was-accent-dark: #2563eb;
  --was-accent-gradient: linear-gradient(135deg, #4f8ef7, #2563eb);

  /* ── Danger / Sale / Error ── */
  --was-danger: #ff4757;
  --was-danger-light: #ff6b81;
  --was-danger-dark: #e53e3e;
  --was-danger-bg: #ffeeee;
  --was-danger-border: #ffcccc;
  --was-danger-gradient: linear-gradient(135deg, #ff4757, #ff6b81);
  --was-danger-section-bg: #fff5f5;
  --was-danger-section-border: #fecdcd;

  /* ── Warning / Low stock ── */
  --was-warning: #e65100;
  --was-warning-bg: #fff3e0;
  --was-warning-alt: #ffa726;
  --was-warning-alt-dark: #fb8c00;
  --was-warning-border: #ffe082;
  --was-warning-text: #7c5c00;

  /* ── Success / Stock available ── */
  --was-success: #1ab857;
  --was-success-bg: #e8fff2;
  --was-success-border: #b2f0c9;

  /* ── Text ── */
  --was-text-primary: #1a1a1a;
  --was-text-heading: #222;
  --was-text-body: #444;
  --was-text-secondary: #555;
  --was-text-tertiary: #666;
  --was-text-dim: #777;
  --was-text-muted: #888;
  --was-text-soft: #999;
  --was-text-light: #aaa;
  --was-text-lighter: #bbb;
  --was-text-placeholder: #c4c9d4;

  /* ── Borders ── */
  --was-border: #ebebeb;
  --was-border-light: #f0f0f0;
  --was-border-input: #e4e7ec;
  --was-border-hover: #d8f5e5;
  --was-border-subtle: #eee;
  --was-border-cat: #e2e2e8;
  --was-border-section: #f8f8f8;
  --was-border-dashed: #ddd;

  /* ── Backgrounds ── */
  --was-bg: #fff;
  --was-bg-subtle: #f4f4f6;
  --was-bg-muted: #f7f7f7;
  --was-bg-soft: #f5f5f5;
  --was-bg-card: #fff;
  --was-bg-form: #fafbfd;
  --was-bg-form-border: #eaedf2;
  --was-bg-panel: #f9fafb;
  --was-bg-panel-alt: #fafafa;
  --was-bg-footer: #fafbfc;
  --was-bg-overlay: rgba(0, 0, 0, 0.55);
  --was-bg-count: #f0f0f4;
  --was-bg-cat-hover: #e9e9ed;
  --was-bg-qty: #e8e8ec;
  --was-bg-qty-hover: #e0e0e6;

  /* ── Cart Summary ── */
  --was-summary-bg: linear-gradient(135deg, #f0fff8, #e8fff2);
  --was-summary-border: #b2f0c9;
  --was-summary-divider: #c8f0d8;

  /* ── Currency ── */
  --was-currency-color: #696969;

  /* ── Disabled ── */
  --was-disabled-bg: #e0e0e0;
  --was-disabled-text: #aaa;

  /* ── Shadows ── */
  --was-shadow-card: 0 10px 32px rgba(0, 0, 0, 0.12);
  --was-shadow-btn: 0 4px 18px rgba(37, 211, 102, 0.3);
  --was-shadow-focus: 0 0 0 3px rgba(37, 211, 102, 0.1);
  --was-shadow-focus-err: 0 0 0 3px rgba(255, 71, 87, 0.1);

  /* ── Radius ── */
  --was-radius-sm: 8px;
  --was-radius-md: 10px;
  --was-radius-lg: 14px;
  --was-radius-xl: 16px;
  --was-radius-pill: 20px;
}
/* ── Reset & Base ─────────────────────────────────────────── */
.was-products-grid,
.was-cart-page,
.was-cart-icon-link {
  font-family: "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  box-sizing: border-box;
}

.was-products-grid *,
.was-cart-page * {
  box-sizing: border-box;
}

/* ── Category Groups & Filters ────────────────────────────── */
.was-shop-container {
  margin: 20px 0;
}

.was-category-filter {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 12px;
  margin-bottom: 25px;
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE/Edge */
}
.was-category-filter::-webkit-scrollbar {
  display: none; /* Chrome/Safari */
}

.was-cat-btn {
  white-space: nowrap;
  background: var(--was-bg-subtle);
  border: 1px solid var(--was-border-cat);
  border-radius: var(--was-radius-pill);
  padding: 8px 16px;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--was-text-secondary);
  cursor: pointer;
  transition: all 0.2s ease;
}

.was-cat-btn:hover {
  background: var(--was-bg-cat-hover);
  color: var(--was-text-heading);
}

.was-cat-btn.active {
  background: var(--was-primary-dark);
  border-color: var(--was-primary-dark);
  color: #fff;
  box-shadow: 0 4px 10px rgba(26, 184, 87, 0.25);
}

.was-category-section {
  margin-bottom: 40px;
}

.was-section-title {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--was-text-heading);
  margin: 0 0 16px 0;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--was-border-light);
  display: inline-block;
}

/* ── Products Grid ────────────────────────────────────────── */
.was-products-grid {
  display: grid;
  gap: 20px;
  margin: 24px 0;
}

.was-cols-2 {
  grid-template-columns: repeat(2, 1fr);
}
.was-cols-3 {
  grid-template-columns: repeat(3, 1fr);
}
.was-cols-4 {
  grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 768px) {
  .was-cols-2,
  .was-cols-3,
  .was-cols-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .was-products-grid {
    gap: 12px; /* Reduce gap on mobile so 2 cards fit better */
  }
  .was-cols-2,
  .was-cols-3,
  .was-cols-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ── Product Card ───────────────────────────────────── */
.was-product-card {
  position: relative;
  background: var(--was-bg-card);
  border: 1px solid var(--was-border);
  border-radius: 16px;
  overflow: hidden;
  transition:
    box-shadow 0.25s,
    transform 0.25s;
  display: flex;
  flex-direction: column;
}

.was-product-card:hover {
  box-shadow: var(--was-shadow-card);
  transform: translateY(-4px);
}

.was-product-thumb {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--was-bg-muted);
}

.was-product-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.35s;
}

.was-product-card:hover .was-product-thumb img {
  transform: scale(1.07);
}

.was-product-info {
  padding: 14px 16px 18px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.was-product-title {
  margin: 0 0 4px;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--was-text-primary);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* وصف المنتج — خط صغير رمادي */
.was-product-desc {
  margin: 0 0 6px;
  font-size: 0.72rem;
  color: var(--was-text-light);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  line-clamp: 2;
  overflow: hidden;
}

.was-product-sku {
  display: block;
  font-size: 0.72rem;
  color: var(--was-text-light);
  margin-bottom: 8px;
}

.was-product-stock-qty {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--was-success);
  background: var(--was-success-bg);
  padding: 2px 8px;
  border-radius: var(--was-radius-md);
  margin-bottom: 8px;
  align-self: flex-start;
}

/* ── Prices ─────────────────────────────────────────────────────────── */
.was-product-price {
  margin-bottom: 14px;
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}

.was-price,
.was-price-sale {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--was-primary-dark);
}

.was-currency-symbol {
  font-size: 0.7em;
  color: var(--was-currency-color);
  font-weight: 600;
  margin-left: 2px;
}

.was-price-old {
  font-size: 0.82rem;
  color: var(--was-text-lighter);
  text-decoration: line-through;
}

@media (max-width: 480px) {
  .was-product-price {
    flex-direction: column-reverse; /* Reverses order so old price appears top */
    align-items: flex-start; /* flex-start dynamically aligns Right in RTL and Left in LTR */
    align-content: flex-start;
    gap: 0; /* Brings them very close together */
  }
}

/* ── Badges ─────────────────────────────────────────────────────────── */
.was-badge-sale,
.was-badge-out {
  position: absolute;
  top: 10px;
  right: 10px;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  z-index: 1;
}

.was-badge-sale {
  background: var(--was-danger-gradient);
  color: #fff;
}

.was-badge-out {
  background: var(--was-text-muted);
  color: #fff;
}

/* ── Add to Cart Button ─────────────────────────────────────────── */
.was-btn-add-to-cart {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  padding: 11px 0;
  background: var(--was-primary-gradient);
  color: #fff;
  border: none;
  border-radius: var(--was-radius-md);
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  transition:
    opacity 0.15s,
    transform 0.1s;
  letter-spacing: 0.02em;
}

.was-btn-add-to-cart:hover {
  opacity: 0.88;
}

.was-btn-add-to-cart:active {
  transform: scale(0.96);
}

.was-btn-add-to-cart.was-added {
  background: var(--was-primary-darker);
}

.was-btn-add-to-cart.was-disabled,
.was-btn-add-to-cart:disabled {
  background: var(--was-disabled-bg);
  color: var(--was-disabled-text);
  cursor: not-allowed;
}

/* زر "التقدم لإنهاء الطلب" — أزرق معتدل */
.was-btn-add-to-cart.was-btn-proceed {
  background: var(--was-accent-gradient);
  color: #fff;
  letter-spacing: 0.01em;
}

.was-btn-add-to-cart.was-btn-proceed:hover {
  opacity: 0.9;
}

.was-no-products {
  text-align: center;
  padding: 40px;
  color: var(--was-text-light);
}

/* ── Cart Icon (header badge) ─────────────────────────────────────────── */
.was-cart-icon-link {
  display: inline-flex;
  align-items: center;
  position: relative;
  text-decoration: none;
  font-size: 1.4rem;
}

.was-cart-badge {
  position: absolute;
  top: 0px;
  left: 0px;
  transform: translate(-30%, -30%);
  background: var(--was-danger);
  color: #fff;
  font-size: 0.6rem;
  font-weight: 700;
  min-width: 17px;
  height: 17px;
  line-height: 17px;
  text-align: center;
  border-radius: 9px;
  padding: 0 4px;
  transition: transform 0.2s;
  z-index: 1;
}

.was-badge-hidden {
  transform: translate(-30%, -30%) scale(0);
}

/* ── Cart Page ────────────────────────────────────────────── */
.was-cart-page {
  max-width: 800px;
  margin: 0 auto;
  padding: 24px 16px;
}

.was-cart-title {
  font-size: 1.4rem;
  margin-bottom: 20px;
  color: var(--was-text-primary);
}

/* ── Empty State ──────────────────────────────────────────── */
.was-cart-empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--was-text-muted);
}

.was-empty-icon {
  font-size: 3.5rem;
  margin-bottom: 12px;
}

.was-cart-empty h3 {
  font-size: 1.3rem;
  color: var(--was-text-body);
  margin-bottom: 8px;
}

/* ── Cart Items List (card-based) ──────────────────────────────── */
.was-cart-items-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
}

/* بطاقة كل منتج — سطرين دائماً */
.was-ci {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  background: var(--was-bg);
  border: 1.5px solid var(--was-border-light);
  border-radius: var(--was-radius-lg);
  padding: 13px 16px;
  transition:
    border-color 0.15s,
    box-shadow 0.15s;
}

.was-ci:hover {
  border-color: var(--was-border-hover);
  box-shadow: 0 3px 12px rgba(37, 211, 102, 0.08);
}

/* السطر الأول: الاسم والتنويعات */
.was-ci-info {
  flex: 1;
  min-width: 0;
  width: 100%;
}

.was-ci-name {
  margin: 0 0 2px;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--was-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.was-ci-unit {
  margin: 0;
  font-size: 0.72rem;
  color: var(--was-text-lighter);
}

/* السطر الثاني: الكمية والسعر وزر الحذف */
.was-ci-right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  width: 100%;
  justify-content: space-between;
}

/* السعر الإجمالي */
.was-ci-subtotal {
  font-size: 0.85rem;
  font-weight: 800;
  color: var(--was-primary-dark);
  white-space: nowrap;
  min-width: 70px;
  text-align: center;
}

/* Qty stepper — ضغوط جداً */
.was-qty-wrap {
  display: inline-flex !important;
  align-items: center !important;
  background: var(--was-bg-subtle) !important;
  border-radius: 7px !important;
  overflow: hidden !important;
  border: 1.5px solid var(--was-bg-qty) !important;
  flex-shrink: 0 !important;
  width: auto !important;
}

.was-qty-btn {
  width: 30px !important;
  height: 30px !important;
  min-width: 0 !important;
  max-width: 30px !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  cursor: pointer;
  font-size: 0.95rem !important;
  font-weight: 700;
  color: var(--was-text-tertiary) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition:
    background 0.12s,
    color 0.12s;
  line-height: 1;
  flex-shrink: 0 !important;
}

.was-qty-btn:hover {
  background: var(--was-bg-qty-hover) !important;
  color: var(--was-text-primary) !important;
}

.was-qty-input {
  width: 40px !important;
  max-width: 40px !important;
  min-width: 0 !important;
  box-sizing: content-box !important;
  text-align: center !important;
  border: none !important;
  background: transparent !important;
  font-size: 0.82rem !important;
  font-weight: 700 !important;
  color: var(--was-text-primary) !important;
  padding: 0 !important;
  margin: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  display: block !important;
  flex-shrink: 0 !important;
}

/* Remove button */
.was-btn-remove {
  width: 20px !important;
  height: 20px !important;
  min-width: 0 !important;
  max-width: 20px !important;
  padding: 0 !important;
  margin: 0 !important;
  box-sizing: content-box !important;
  background: var(--was-danger-bg) !important;
  border: 1.5px solid var(--was-danger-border) !important;
  cursor: pointer;
  color: var(--was-danger-dark) !important;
  font-size: 0.7rem !important;
  font-weight: 700;
  line-height: 1;
  border-radius: 5px !important;
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    background 0.15s,
    color 0.15s,
    border-color 0.15s;
  flex-shrink: 0;
}

.was-btn-remove:hover {
  background: var(--was-danger-dark);
  border-color: var(--was-danger-dark);
  color: #fff;
}

/* ── Cart Summary Bar ───────────────────────────────────────────── */
.was-cart-summary {
  background: var(--was-summary-bg);
  border: 1.5px solid var(--was-summary-border);
  border-radius: var(--was-radius-lg);
  padding: 14px 18px;
  margin-bottom: 12px;
}

.was-cart-summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.92rem;
  color: var(--was-text-body);
  padding: 4px 0;
}

.was-cart-summary-row + .was-cart-summary-row {
  border-top: 1px dashed var(--was-summary-divider);
  margin-top: 8px;
  padding-top: 10px;
}

.was-cart-summary-row strong {
  font-size: 1.05rem;
  color: var(--was-primary-dark);
  font-weight: 800;
}

.was-cart-total-final {
  color: var(--was-primary-darkest);
}

/* ── Price Mismatch ───────────────────────────────────────────── */
.was-price-mismatch {
  background: var(--was-warning-bg);
  border: 1px solid var(--was-warning-border);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 0.82rem;
  color: var(--was-warning-text);
  margin-top: 8px;
}

/* ── Clear Cart ─────────────────────────────────────────────────── */
.was-btn-clear {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: 1.5px solid var(--was-border-subtle);
  color: var(--was-text-lighter);
  padding: 7px 14px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 0.8rem;
  margin-bottom: 20px;
  transition:
    border-color 0.15s,
    color 0.15s;
}

.was-btn-clear:hover {
  border-color: var(--was-danger);
  color: var(--was-danger);
}

/* ── Customer Form (modal) ────────────────────────────────── */
.was-customer-form {
  background: var(--was-bg-form);
  border: 1.5px solid var(--was-bg-form-border);
  border-radius: 16px;
  padding: 20px 20px 12px;
  margin-bottom: 16px;
}

.was-customer-form h3 {
  margin: 0 0 16px;
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--was-text-heading);
  display: flex;
  align-items: center;
  gap: 7px;
}

.was-form-group {
  margin-bottom: 14px;
  position: relative;
}

.was-form-group label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--was-text-secondary);
  margin-bottom: 7px;
  letter-spacing: 0.02em;
}

.was-field-icon {
  width: 14px;
  height: 14px;
  color: var(--was-primary);
  flex-shrink: 0;
}

.was-required {
  color: var(--was-danger);
  font-size: 0.85em;
}

.was-optional {
  color: var(--was-text-lighter);
  font-weight: 400;
  font-size: 0.85em;
}

.was-form-group input,
.was-form-group textarea {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--was-border-input);
  border-radius: var(--was-radius-md);
  font-size: 0.92rem;
  color: var(--was-text-primary);
  transition:
    border-color 0.15s,
    box-shadow 0.15s;
  background: var(--was-bg);
  outline: none;
  font-family: inherit;
}

.was-form-group input::placeholder,
.was-form-group textarea::placeholder {
  color: var(--was-text-placeholder);
}

.was-form-group input:focus,
.was-form-group textarea:focus {
  border-color: var(--was-primary);
  box-shadow: var(--was-shadow-focus);
}

.was-form-group textarea {
  resize: none;
}

/* Inline validation */
.was-form-group input.was-input-error {
  border-color: var(--was-danger);
  box-shadow: var(--was-shadow-focus-err);
}

.was-field-error {
  display: block;
  font-size: 0.75rem;
  color: var(--was-danger);
  margin-top: 5px;
  font-weight: 700;
}

/* ── Order Button ─────────────────────────────────────────────────────── */
.was-order-actions {
  padding-bottom: 6px;
}

.was-btn-order {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  background: var(--was-primary-gradient);
  color: #fff;
  border: none;
  border-radius: var(--was-radius-lg);
  padding: 16px 24px;
  font-size: 1.05rem;
  font-weight: 800;
  cursor: pointer;
  transition:
    opacity 0.15s,
    transform 0.1s;
  box-shadow: var(--was-shadow-btn);
  letter-spacing: 0.01em;
}

.was-btn-order:hover {
  opacity: 0.9;
}
.was-btn-order:active {
  transform: scale(0.98);
}
.was-btn-order:disabled {
  background: var(--was-disabled-bg);
  color: var(--was-disabled-text);
  cursor: not-allowed;
  box-shadow: none;
}

.was-wa-icon {
  font-size: 1.2rem;
}

.was-order-note {
  font-size: 0.8rem;
  color: var(--was-text-light);
  margin-top: 10px;
}

/* ── Primary Button ───────────────────────────────────────── */
.was-btn-primary {
  display: inline-block;
  background: var(--was-primary);
  color: #fff;
  text-decoration: none;
  padding: 12px 28px;
  border-radius: 10px;
  font-weight: 600;
  margin-top: 16px;
  transition: background 0.15s;
}

.was-btn-primary:hover {
  background: var(--was-primary-light);
}

/* ── Loading Overlay ───────────────────────────────── */
.was-loading-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.85);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  z-index: 999999;
  direction: ltr; /* ← يمنع RTL من قلب الـ flex */
  text-align: center; /* ← يضمن توسيط النص */
}

.was-loading-card {
  display: contents; /* ← يجعل الكارد شفافة تماماً — السبينر والنص يتمركزان بالـ flex الخارجي */
}

.was-loading-text {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--was-text-secondary);
}

.was-spinner {
  width: 44px;
  height: 44px;
  border: 4px solid var(--was-disabled-bg);
  border-top-color: var(--was-primary);
  border-radius: 50%;
  animation: was-spin 0.7s linear infinite;
  margin-bottom: 14px;
}

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

.was-currency {
  margin-right: 4px;
}

/* ── Cart Modal ───────────────────────────────────────────── */

/* Overlay – same as variation popup */
.was-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  animation: was-fadeIn 0.2s ease;
}

/* صندوق المودال – same design as varpop */
.was-modal-box {
  background: var(--was-bg);
  border-radius: 20px;
  width: 100%;
  max-width: 520px;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
  animation: was-slideUp 0.25s ease;
  overflow: hidden;
}

/* ── Modal Header ─────────────────────────────────────────────────────────── */
.was-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  border-bottom: 1px solid var(--was-border-light);
  flex-shrink: 0;
  background: var(--was-bg);
  border-radius: 20px 20px 0 0;
}

.was-modal-header-left {
  display: flex;
  align-items: center;
  gap: 10px;
}

.was-modal-title {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--was-text-primary);
}

.was-modal-count {
  background: var(--was-bg-count);
  color: var(--was-text-tertiary);
  font-size: 0.72rem;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 20px;
  letter-spacing: 0.02em;
}

/* Close button */
.was-modal-close {
  width: 28px;
  height: 28px;
  border: none !important;
  background: transparent !important;
  cursor: pointer;
  color: var(--was-text-light);
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.15s;
  flex-shrink: 0;
  padding: 0 !important;
}

.was-modal-close:hover {
  color: var(--was-danger);
  background: transparent !important;
}

/* جسم المودال قابل للسكرول */
.was-modal-body {
  overflow-y: auto;
  padding: 18px 20px;
  flex: 1;
  background: var(--was-bg-form);
}

/* إخفاء سكرول الصفحة عند فتح المودال */
body.was-modal-open {
  overflow: hidden;
}

/* أيقونة السلة في المنيو */
.was-menu-cart-item > a.was-cart-icon-link {
  display: inline-flex;
  align-items: center;
  position: relative;
  text-decoration: none;
  font-size: 1.3rem;
  padding: 4px 6px;
}

.was-cart-badge-inline {
  position: absolute;
  top: 28px;
  left: 4px;
  background: var(--was-danger);
  color: #fff;
  font-size: 0.6rem;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  line-height: 16px;
  text-align: center;
  border-radius: 8px;
  padding: 0 3px;
  transition: transform 0.2s;
}

/* Responsive المودال — bottom-sheet on mobile (same as varpop) */
@media (max-width: 500px) {
  .was-modal-overlay {
    align-items: flex-end;
    padding: 0;
  }

  .was-modal-box {
    max-height: 90vh;
    border-radius: 16px 16px 0 0;
  }

  .was-modal-header {
    padding: 16px 16px 12px;
    border-radius: 16px 16px 0 0;
  }

  .was-modal-body {
    padding: 14px 14px;
  }
}

/* ── Thank-You Screen ─────────────────────────────────────── */
.was-thankyou {
  text-align: center;
  padding: 10px 0 20px;
}

.was-ty-icon {
  font-size: 3.8rem;
  margin-bottom: 14px;
  animation: wasBounce 0.5s ease;
}

@keyframes wasBounce {
  0% {
    transform: scale(0);
    opacity: 0;
  }
  70% {
    transform: scale(1.15);
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.was-ty-title {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--was-text-primary);
  margin: 0 0 8px;
}

.was-ty-subtitle {
  font-size: 0.92rem;
  color: var(--was-text-dim);
  margin-bottom: 28px;
}

.was-ty-section {
  background: var(--was-bg-panel);
  border: 1px solid var(--was-border-subtle);
  border-radius: 14px;
  padding: 18px 20px;
  margin-bottom: 16px;
  text-align: right;
}

.was-ty-section-title {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--was-text-secondary);
  margin: 0 0 14px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.was-ty-items {
  border-bottom: 1px solid var(--was-border-subtle);
  margin-bottom: 14px;
  padding-bottom: 12px;
}

.was-ty-item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 8px 0;
  border-bottom: 1px dashed var(--was-border-light);
  gap: 10px;
}

.was-ty-item:last-child {
  border-bottom: none;
}

.was-ty-item-info {
  flex: 1;
  min-width: 0;
}

.was-ty-item-name {
  font-size: 0.9rem;
  color: var(--was-text-heading);
  font-weight: 600;
  display: block;
}

.was-ty-item-detail {
  font-size: 0.78rem;
  color: var(--was-text-muted);
  margin-top: 2px;
  padding-inline-start: 6px;
}

.was-ty-item-meta {
  font-size: 0.82rem;
  color: var(--was-text-muted);
  white-space: nowrap;
  flex-shrink: 0;
  padding-top: 2px;
}

.was-ty-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.95rem;
  color: var(--was-text-body);
}

.was-ty-total strong {
  color: var(--was-primary-dark);
  font-size: 1.1rem;
}

.was-ty-customer {
  background: var(--was-bg-panel);
  border: 1px solid var(--was-border-subtle);
  border-radius: 14px;
  padding: 16px 20px;
  margin-bottom: 24px;
  text-align: right;
}

.was-ty-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 7px 0;
  border-bottom: 1px dashed var(--was-border-light);
  font-size: 0.9rem;
}

.was-ty-row:last-child {
  border-bottom: none;
}

.was-ty-row span {
  color: var(--was-text-muted);
}
.was-ty-row strong {
  color: var(--was-text-heading);
}

.was-ty-close-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 40px;
  background: var(--was-primary-gradient);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition:
    opacity 0.15s,
    transform 0.1s;
  margin-top: 4px;
}

.was-ty-close-btn:hover {
  opacity: 0.88;
}
.was-ty-close-btn:active {
  transform: scale(0.97);
}

/* ═══════════════════════════════════════════════════════════════════
   Low Stock Badge
   ═══════════════════════════════════════════════════════════════════ */
.was-badge-low-stock {
  position: absolute;
  top: 10px;
  right: 10px;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  z-index: 1;
  background: linear-gradient(
    135deg,
    var(--was-warning-alt),
    var(--was-warning-alt-dark)
  );
  color: #fff;
}

/* ═══════════════════════════════════════════════════════════════════
   Cart Item Metadata (variation / option labels)
   ═══════════════════════════════════════════════════════════════════ */
.was-ci-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin: 3px 0;
}

.was-ci-meta-line {
  font-size: 0.72rem;
  color: var(--was-text-muted);
  line-height: 1.3;
}

.was-ci-sku {
  font-size: 0.65rem;
  color: var(--was-text-light);
  margin-inline-start: 4px;
}

/* ═══════════════════════════════════════════════════════════════════
   Variation / Option Selection Popup
   ═══════════════════════════════════════════════════════════════════ */
body.was-varpop-open {
  overflow: hidden;
}

.was-varpop-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 999998;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  animation: was-fadeIn 0.2s ease;
}

@keyframes was-fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.was-varpop-modal {
  background: var(--was-bg);
  border-radius: 20px;
  max-width: 520px;
  width: 100%;
  max-height: 85vh;
  overflow-y: auto;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
  position: relative;
  animation: was-slideUp 0.25s ease;
}

@keyframes was-slideUp {
  from {
    transform: translateY(24px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

/* ── Popup close — uses .was-modal-close from cart (no separate class needed) ── */

/* ── Header — matches cart modal header ── */
.was-varpop-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  border-bottom: 1px solid var(--was-border-light);
  flex-shrink: 0;
  background: var(--was-bg);
  border-radius: 20px 20px 0 0;
}

.was-varpop-name {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--was-text-primary);
  line-height: 1.3;
}

/* ── Sections ── */
.was-varpop-section {
  padding: 16px 20px;
  border-bottom: 1px solid var(--was-border-section);
}

.was-varpop-section.was-varpop-error {
  background: var(--was-danger-section-bg);
  border-color: var(--was-danger-section-border);
}

.was-varpop-label {
  display: block;
  margin-bottom: 10px;
  font-weight: 700;
  font-size: 0.85rem;
  color: var(--was-text-body);
}

.was-req {
  color: var(--was-danger-dark);
}

.was-optional {
  color: var(--was-text-lighter);
  font-weight: 400;
  font-size: 0.75em;
}

/* ── Variation items ── */
.was-varpop-var-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.was-varpop-var-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: 2px solid var(--was-border-subtle);
  border-radius: 10px;
  cursor: pointer;
  transition:
    border-color 0.15s,
    background 0.15s;
}

.was-varpop-var-item:hover {
  border-color: var(--was-primary-hover-bg);
  background: var(--was-primary-hover-light);
}

.was-varpop-var-item.was-varpop-selected {
  border-color: var(--was-primary);
  background: var(--was-primary-selected);
}

.was-varpop-var-item.was-varpop-soldout {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Inline variation thumbnail */
.was-varpop-var-thumb {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--was-bg-muted);
}

.was-varpop-var-label {
  flex: 1;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--was-text-body);
}

.was-varpop-sku {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 500;
  color: var(--was-text-light);
  margin-inline-start: 6px;
}

.was-varpop-var-price {
  font-size: 0.85rem;
  color: var(--was-primary-dark);
  white-space: nowrap;
}

.was-varpop-var-price del {
  color: var(--was-text-lighter);
  font-weight: 400;
  margin-right: 4px;
}

.was-varpop-stock-badge {
  font-size: 0.65rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 10px;
  white-space: nowrap;
}

.was-varpop-stock-badge.low {
  background: var(--was-warning-bg);
  color: var(--was-warning);
}

.was-varpop-stock-badge.sold {
  background: var(--was-bg-soft);
  color: var(--was-text-soft);
}

.was-varpop-stock-badge.available {
  background: var(--was-success-bg);
  color: var(--was-success);
  margin-inline-start: 6px;
  border: 1px solid var(--was-primary);
}

/* ── Option choices ── */
.was-varpop-opt-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.was-varpop-choice {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--was-bg-panel-alt);
  border: 1px solid var(--was-border-subtle);
  border-radius: 8px;
  cursor: pointer;
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--was-text-body);
  transition:
    border-color 0.15s,
    background 0.15s;
}

.was-varpop-choice:hover {
  background: var(--was-bg-soft);
  border-color: var(--was-border-dashed);
}

.was-varpop-choice input {
  width: auto !important;
  margin: 0 !important;
}

.was-varpop-mod {
  color: var(--was-primary-dark);
  font-weight: 600;
  font-size: 0.82rem;
  margin-inline-start: auto;
}

.was-varpop-free {
  background: var(--was-primary-free-bg);
  color: var(--was-primary-free-text);
  font-size: 0.72rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 10px;
}

/* ── Footer ── */
.was-varpop-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 20px;
  border-top: 1px solid var(--was-border-light);
  background: var(--was-bg-footer);
  border-radius: 0 0 20px 20px;
}

.was-varpop-total {
  font-size: 0.92rem;
  color: var(--was-text-secondary);
}

.was-varpop-total strong {
  font-size: 1.05rem;
  color: var(--was-primary-dark);
}

.was-varpop-add-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  background: var(--was-primary-gradient);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  transition:
    opacity 0.15s,
    transform 0.1s;
  box-shadow: 0 3px 12px rgba(37, 211, 102, 0.25);
}

.was-varpop-add-btn:hover {
  opacity: 0.9;
}

.was-varpop-add-btn:active {
  transform: scale(0.97);
}

/* ── Responsive ── */
@media (max-width: 500px) {
  .was-varpop-modal {
    border-radius: 16px 16px 0 0;
    max-height: 90vh;
  }

  .was-varpop-overlay {
    align-items: flex-end;
    padding: 0;
  }

  .was-varpop-header {
    padding: 16px 16px 12px;
  }

  .was-varpop-thumb {
    width: 60px;
    height: 60px;
  }

  .was-varpop-section {
    padding: 12px 16px;
  }

  .was-varpop-footer {
    flex-direction: column;
    padding: 14px 16px;
  }

  .was-varpop-add-btn {
    width: 100%;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   Fulfillment Mode Tabs
   ═══════════════════════════════════════════════════════════════════ */
.was-fulfillment-tabs {
  display: flex;
  gap: 6px;
  margin-bottom: 16px;
  padding: 4px;
  background: var(--was-bg-subtle);
  border-radius: var(--was-radius-md);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none; /* Firefox */
}

.was-fulfillment-tabs::-webkit-scrollbar {
  display: none; /* Chrome/Safari */
}

.was-fulfillment-tab {
  flex: 1 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 14px;
  background: transparent;
  border: none;
  border-radius: var(--was-radius-sm);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--was-text-muted);
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.was-fulfillment-tab:hover {
  color: var(--was-text-body);
  background: var(--was-bg);
}

.was-fulfillment-tab.active {
  background: var(--was-bg);
  color: var(--was-primary-dark);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
}

.was-tab-icon {
  font-size: 1.05em;
}

@media (max-width: 480px) {
  .was-fulfillment-tab {
    padding: 8px 10px;
    font-size: 0.75rem;
    gap: 4px;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   Product Detail Popup (Quick View)
   ═══════════════════════════════════════════════════════════════════ */

/* Make product card image and title clickable */
.was-product-thumb,
.was-product-title {
  cursor: pointer;
}

/* Product Detail modal — no header, image starts from top */
.was-pdp-modal {
  position: relative;
  padding-top: 0;
}

/* Floating close button over the image */
.was-pdp-close-btn {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 10;
  width: 32px;
  height: 32px;
  border: none !important;
  background: rgba(255, 255, 255, 0.75) !important;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border-radius: 50%;
  cursor: pointer;
  color: #333;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    background 0.15s,
    color 0.15s;
  padding: 0 !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}

.was-pdp-close-btn:hover {
  background: rgba(255, 255, 255, 0.95) !important;
  color: var(--was-danger);
}

/* RTL support for close button */
[dir="rtl"] .was-pdp-close-btn {
  right: auto;
  left: 12px;
}

/* Product image inside popup */
.was-pdp-image {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--was-bg-muted);
  border-radius: 0;
}

.was-pdp-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Product info section */
.was-pdp-info {
  padding: 18px 22px 8px;
}

.was-pdp-name {
  margin: 0 0 6px;
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--was-text-primary);
  line-height: 1.35;
}

.was-pdp-price-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}

.was-pdp-price {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--was-primary-dark);
}

.was-pdp-price-old {
  font-size: 0.9rem;
  color: var(--was-text-lighter);
  text-decoration: line-through;
}

.was-pdp-badge {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  letter-spacing: 0.02em;
}

.was-pdp-badge-sale {
  background: var(--was-danger-gradient);
  color: #fff;
}

.was-pdp-badge-out {
  background: var(--was-text-muted);
  color: #fff;
}

.was-pdp-badge-low {
  background: linear-gradient(
    135deg,
    var(--was-warning-alt),
    var(--was-warning-alt-dark)
  );
  color: #fff;
}

/* SKU & Stock row */
.was-pdp-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.was-pdp-sku {
  font-size: 0.72rem;
  color: var(--was-text-light);
}

.was-pdp-stock {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--was-success);
  background: var(--was-success-bg);
  padding: 2px 8px;
  border-radius: var(--was-radius-md);
}

/* Description */
.was-pdp-desc-section {
  padding: 14px 22px 6px;
}

.was-pdp-desc-label {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--was-text-secondary);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Wrapper: controls max-height + holds the fade overlay */
.was-pdp-desc-wrap {
  position: relative;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.was-pdp-desc-wrap.was-pdp-desc-collapsed {
  max-height: 4.2em; /* ~3 lines (line-height 1.4 × 3) */
}

/* The description text */
.was-pdp-desc {
  font-size: 0.85rem;
  color: var(--was-text-dim);
  line-height: 1.65;
  margin: 0;
}

/* Gradient fade overlay — visible only when collapsed */
.was-pdp-desc-fade {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2.2em;
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.85) 60%,
    rgba(255, 255, 255, 1) 100%
  );
  pointer-events: none;
  opacity: 1;
  transition: opacity 0.25s ease;
}

.was-pdp-desc-wrap:not(.was-pdp-desc-collapsed) .was-pdp-desc-fade {
  opacity: 0;
}

/* When expanded — no height limit */
.was-pdp-desc-wrap:not(.was-pdp-desc-collapsed) {
  max-height: 600px; /* large enough for any description */
}

/* Show More / Show Less button */
.was-pdp-desc-toggle {
  display: block;
  background: none !important;
  border: none !important;
  color: var(--was-primary) !important;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  padding: 4px 0 !important;
  margin-top: 4px;
  transition: color 0.15s;
  text-align: start;
}

.was-pdp-desc-toggle:hover {
  color: var(--was-primary-dark);
  text-decoration: underline;
}

/* Separator line between sections */
.was-pdp-divider {
  border: none;
  border-top: 1px solid var(--was-border-light);
  margin: 0;
}

/* Responsive */
@media (max-width: 500px) {
  .was-pdp-info {
    padding: 14px 16px 6px;
  }

  .was-pdp-desc-section {
    padding: 12px 16px 6px;
  }

  .was-pdp-name {
    font-size: 1.05rem;
  }
}
