/**
 * Product Grid Styles
 * @package BudgetLappy
 */

.bl-product-grid { display: grid; gap: 1.5rem; }
.bl-grid-4 { grid-template-columns: repeat(4, 1fr); }
.bl-grid-3 { grid-template-columns: repeat(3, 1fr); }

/* Laptop Card */
.bl-laptop-card { background: #fff; border-radius: var(--bl-radius); overflow: hidden; box-shadow: var(--bl-shadow-sm); transition: var(--bl-transition); display: flex; flex-direction: column; border: 1px solid var(--bl-border); }
.bl-laptop-card:hover { transform: translateY(-5px); box-shadow: var(--bl-shadow-lg); border-color: var(--bl-primary); }

.bl-card-link { text-decoration: none; color: inherit; flex: 1; display: flex; flex-direction: column; }
.bl-card-image { position: relative; overflow: hidden; background: var(--bl-bg); border-bottom: 1px solid var(--bl-border); }
.bl-card-image img { width: 100%; aspect-ratio: 4/3; object-fit: contain; transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1); padding: 1rem; }
.bl-laptop-card:hover .bl-card-image img { transform: scale(1.06); }
.bl-card-no-img { width: 100%; aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; background: var(--bl-bg); color: var(--bl-text-secondary); border-bottom: 1px solid var(--bl-border); }

/* Badges */
.bl-badge-condition { position: absolute; top: 10px; left: 10px; padding: 4px 10px; border-radius: 50px; font-size: 0.72rem; font-weight: 600; z-index: 2; }
.bl-condition-excellent { background: #DCFCE7; color: #166534; }
.bl-condition-good { background: #FEF3C7; color: #92400E; }
.bl-condition-fair { background: #FEE2E2; color: #991B1B; }
.bl-badge-discount { position: absolute; top: 10px; right: 10px; background: #FF6B00; color: #fff; padding: 4px 10px; border-radius: 50px; font-size: 0.72rem; font-weight: 700; z-index: 2; }

/* Sold Overlay */
.bl-card-sold { filter: grayscale(40%); opacity: 0.85; }
.bl-card-sold:hover { filter: grayscale(20%); opacity: 0.95; }
.bl-sold-overlay { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; z-index: 3; }
.bl-sold-ribbon { background: #DC2626; color: #fff; padding: 6px 40px; font-weight: 800; font-size: 0.9rem; transform: rotate(-30deg); letter-spacing: 2px; }

/* Card Body */
.bl-card-body { padding: 1.25rem; flex: 1; display: flex; flex-direction: column; }
.bl-card-stock-num { font-size: 0.75rem; color: var(--bl-text-secondary); font-weight: 600; margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.5px; }
.bl-card-title { font-size: 1.05rem; font-weight: 700; line-height: 1.4; margin: 0 0 8px; color: var(--bl-text); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.bl-card-rating { font-size: 0.85rem; margin-bottom: 10px; color: #F59E0B; }
.bl-card-rating span { color: var(--bl-text-secondary); font-size: 0.8rem; margin-left: 4px; }
.bl-card-specs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.bl-spec-pill { background: var(--bl-bg); color: var(--bl-text-secondary); padding: 4px 10px; border-radius: 6px; font-size: 0.75rem; font-weight: 600; border: 1px solid var(--bl-border); }
.bl-card-pricing { display: flex; align-items: baseline; gap: 8px; margin-bottom: 10px; }
.bl-card-price { font-size: 1.3rem; font-weight: 800; color: var(--bl-primary); }
.bl-card-original { font-size: 0.9rem; color: var(--bl-text-secondary); text-decoration: line-through; }
.bl-card-freebies { font-size: 0.75rem; color: var(--bl-text-secondary); line-height: 1.5; padding: 10px 0; border-top: 1px dashed var(--bl-border); margin-top: auto; font-weight: 500; }

/* Card Footer */
.bl-card-footer { display: flex; justify-content: space-between; align-items: center; padding: 0 1.25rem 1.25rem; }
.bl-card-stock-status { font-size: 0.8rem; font-weight: 700; }
.bl-in-stock { color: var(--bl-success); }
.bl-out-stock { color: var(--bl-red); }
.bl-card-verified { text-align: center; font-size: 0.75rem; color: var(--bl-success); font-weight: 600; padding: 8px; background: #ECFDF5; border-radius: 0 0 var(--bl-radius) var(--bl-radius); border-top: 1px solid #D1FAE5; }

/* Related Products */
.bl-related-products { margin: 3rem 0; }

@media (max-width: 1024px) {
  .bl-grid-4 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .bl-grid-4, .bl-grid-3 { grid-template-columns: repeat(2, 1fr); }
  .bl-testimonial-card { min-width: calc(50% - 0.75rem); }
}
@media (max-width: 480px) {
  .bl-grid-4, .bl-grid-3 { grid-template-columns: 1fr; }
  .bl-testimonial-card { min-width: 100%; }
}
