.ml-filter-bar {
    background: #FAF9F6;
    padding: 20px 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-radius: 8px;
}
.ml-filter-count { font-size: 14px; color: #666; }
.ml-filter-count strong { color: #1a1a1a; font-weight: bold; }
.ml-sort-select { padding: 8px; border: 1px solid #E0E0E0; border-radius: 8px; font-size: 13px; background: #fff; }

.ml-product-grid { display: grid; gap: 24px; }
.ml-cols-4 { grid-template-columns: repeat(4, 1fr); }
.ml-cols-3 { grid-template-columns: repeat(3, 1fr); }
.ml-cols-2 { grid-template-columns: repeat(2, 1fr); }

.ml-product-card {
    background: #fff;
    border: 1px solid #E8E8E8;
    border-radius: 16px;
    padding: 16px;
    position: relative;
    transition: transform 0.2s, box-shadow 0.2s;
}
.ml-product-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 48px rgba(0,0,0,0.08);
}
.ml-product-card a { text-decoration: none; color: inherit; display: block; }
.ml-card-img img { width: 100%; height: auto; border-radius: 8px; transition: transform 0.2s; }
.ml-product-card:hover .ml-card-img img { transform: scale(1.05); }
.ml-card-cat { color: #0F5132; font-size: 11px; text-transform: uppercase; font-weight: 600; margin-top: 12px; }
.ml-card-title { font-size: 14px; color: #1a1a1a; margin: 4px 0; font-weight: 600; }
.ml-card-price { color: #0F5132; font-size: 17px; font-weight: 700; }

.ml-add-to-cart {
    position: absolute;
    bottom: 16px; right: 16px;
    width: 40px; height: 40px;
    border-radius: 50%;
    background: #0F5132; color: #fff;
    border: none; cursor: pointer;
    font-size: 20px;
    transition: transform 0.2s;
}
.ml-add-to-cart:hover { transform: scale(1.08); }

.ml-search-wrapper { position: relative; display: flex; }
.ml-search-input { width: 100%; padding: 12px; border: 1px solid #E0E0E0; border-radius: 12px 0 0 12px; }
.ml-search-btn { background: #0F5132; color: #fff; border: none; padding: 0 20px; border-radius: 0 12px 12px 0; cursor: pointer; }
.ml-search-results { position: absolute; top: 100%; left: 0; right: 0; background: #fff; box-shadow: 0 8px 24px rgba(0,0,0,0.1); border-radius: 12px; z-index: 10; display: none; }
.ml-search-item { display: flex; align-items: center; padding: 10px; text-decoration: none; color: #1a1a1a; font-size: 13px; }
.ml-search-item img { width: 40px; height: 40px; object-fit: cover; margin-right: 10px; }
.ml-search-item:hover { background: #E8F5E9; }

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