/* Smart Recommendations — Frontend */
.sr-section { margin: 40px 0; }
.sr-title { font-size: 1.4rem; font-weight: 600; color: #1a1a2e; margin-bottom: 20px; padding-bottom: 10px; border-bottom: 2px solid #e0003c; display: inline-block; }
.sr-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 16px; }
.sr-card { border: 1px solid #eee; border-radius: 10px; overflow: hidden; background: #fff; transition: box-shadow 0.2s, transform 0.2s; display: flex; flex-direction: column; }
.sr-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.1); transform: translateY(-2px); }
.sr-img-wrap { position: relative; display: block; aspect-ratio: 1; overflow: hidden; background: #f9f9f9; }
.sr-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.sr-card:hover .sr-img-wrap img { transform: scale(1.04); }
.sr-badge { position: absolute; top: 8px; left: 8px; background: #e0003c; color: #fff; font-size: 11px; font-weight: 700; padding: 2px 7px; border-radius: 4px; z-index: 2; }
.sr-info { padding: 10px 12px 12px; display: flex; flex-direction: column; gap: 5px; flex: 1; }
.sr-name { font-size: 13px; font-weight: 500; color: #1a1a2e; text-decoration: none; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.sr-name:hover { color: #e0003c; }
.sr-price { font-size: 13px; }
.sr-price .woocommerce-Price-amount { color: #e0003c; font-weight: 600; }
.sr-price del { color: #aaa; font-size: 11px; }
.sr-stock { font-size: 11px; font-weight: 500; }
.sr-stock.in  { color: #00a651; }
.sr-stock.out { color: #e0003c; }
.sr-btn { margin-top: auto; display: block; text-align: center; background: #e0003c; color: #fff; border-radius: 6px; padding: 7px 10px; font-size: 12px; font-weight: 600; text-decoration: none; transition: background 0.2s; }
.sr-btn:hover { background: #b8002f; color: #fff; }
@media (max-width: 600px) { .sr-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; } }

/* ── Responsive ── */
@media (max-width: 767px) {
    .sr-hide-mobile { display: none !important; }
    .sr-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .sr-title { font-size: 1.1rem; }
    .sr-info { padding: 8px; gap: 4px; }
    .sr-name { font-size: 12px; }
    .sr-price { font-size: 12px; }
    .sr-btn { font-size: 11px; padding: 6px 8px; }
    .sr-badge { font-size: 10px; padding: 2px 5px; }
    .sr-stock { font-size: 10px; }
}
@media (min-width: 768px) and (max-width: 1024px) {
    .sr-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .sr-name { font-size: 13px; }
}
