/* ==========================================================================
   ABMKeys Widget — Product Grid CSS
   ========================================================================== */

/* Grid layout */
.abm-prod-grid {
  display: grid !important;
  gap: 18px !important;
}
.abm-prod-grid.cols-2 { grid-template-columns: repeat(2, 1fr) !important; }
.abm-prod-grid.cols-3 { grid-template-columns: repeat(3, 1fr) !important; }
.abm-prod-grid.cols-4 { grid-template-columns: repeat(4, 1fr) !important; }

/* Card base */
.abm-p-card {
  background: var(--abm-white) !important;
  border: 1px solid var(--abm-border) !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  transition: all 0.22s !important;
  box-shadow: var(--abm-shadow-sm) !important;
  display: flex !important;
  flex-direction: column !important;
}
.abm-p-card:hover {
  box-shadow: var(--abm-shadow-lg) !important;
  transform: translateY(-3px) !important;
  border-color: transparent !important;
}

/* Image area with color backgrounds */
.abm-p-img {
  height: 140px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px !important;
  position: relative;
  overflow: hidden;
}
.abm-p-img img,
.abm-p-img .abm-p-thumb {
  max-height: 100% !important;
  width: auto !important;
  max-width: 100% !important;
  object-fit: contain !important;
}

/* Color classes */
.abm-p-img.c-blue   { background: linear-gradient(135deg, #EFF6FF, #DBEAFE) !important; }
.abm-p-img.c-red    { background: linear-gradient(135deg, #FFF1F2, #FECDD3) !important; }
.abm-p-img.c-sky    { background: linear-gradient(135deg, #F0F9FF, #BAE6FD) !important; }
.abm-p-img.c-green  { background: linear-gradient(135deg, #F0FDF4, #BBF7D0) !important; }
.abm-p-img.c-amber  { background: linear-gradient(135deg, #FFFBEB, #FDE68A) !important; }
.abm-p-img.c-purple { background: linear-gradient(135deg, #F5F3FF, #DDD6FE) !important; }

/* Sale badge */
.abm-p-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  background: #FEE2E2 !important;
  color: #DC2626 !important;
  font-family: 'DM Mono', monospace !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  border-radius: 5px !important;
  padding: 3px 8px !important;
  line-height: 1.4 !important;
  z-index: 2;
}

/* Card body */
.abm-p-body {
  padding: 14px 18px 18px !important;
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
}

/* Brand / category label */
.abm-p-brand {
  font-family: 'DM Mono', monospace !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  color: var(--abm-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  margin-bottom: 4px !important;
}

/* Product name */
.abm-p-name {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--abm-ink) !important;
  line-height: 1.35 !important;
  margin-bottom: 0 !important;
}
.abm-p-name a {
  color: inherit !important;
  text-decoration: none !important;
}
.abm-p-name a:hover {
  color: var(--abm-blue) !important;
}

/* Price + button footer */
.abm-p-foot {
  margin-top: auto !important;
  padding-top: 12px !important;
  border-top: 1px solid var(--abm-border);
}
.abm-p-price {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #1B4FD8 !important;
  letter-spacing: -0.3px !important;
  margin-bottom: 10px !important;
}
.abm-p-price bdi,
.abm-p-price .woocommerce-Price-amount {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: -0.3px !important;
}
.abm-p-price .woocommerce-Price-currencySymbol {
  font-family: 'gulf-currencies', 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: -0.3px !important;
}
.abm-p-price del {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  color: #94A3B8 !important;
  margin-left: 6px !important;
}

/* Add to cart button */
.abm-p-add {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  background: var(--abm-blue) !important;
  color: white !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 8px 16px !important;
  transition: background 0.15s !important;
  display: block !important;
  width: 100% !important;
  text-align: center !important;
  text-decoration: none !important;
  cursor: pointer !important;
}
.abm-p-add:hover {
  background: var(--abm-blue-dark) !important;
  color: white !important;
}

/* Responsive */
@media (max-width: 768px) {
  .abm-prod-grid.cols-4,
  .abm-prod-grid.cols-3 {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 480px) {
  .abm-prod-grid.cols-4,
  .abm-prod-grid.cols-3,
  .abm-prod-grid.cols-2 {
    grid-template-columns: 1fr !important;
  }
}
