/* ===== PRODUCTS PAGE ===== */
.products-layout { display: grid; grid-template-columns: 220px 1fr; gap: var(--space-8); align-items: start; }
.products-sidebar { background: white; border-radius: var(--radius-lg); padding: var(--space-5); box-shadow: var(--shadow-sm); position: sticky; top: calc(var(--header-height) + var(--space-4)); z-index: 10; overflow: hidden; }
.sidebar-section { margin-bottom: var(--space-6); padding-bottom: var(--space-6); border-bottom: 1px solid var(--color-border-light); }
.sidebar-section:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.sidebar-title { font-size: var(--font-size-sm); font-weight: 700; color: var(--color-title); margin-bottom: var(--space-3); text-transform: uppercase; letter-spacing: 0.5px; }
.sidebar-cat-item { display: flex; align-items: center; justify-content: space-between; padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); cursor: pointer; transition: all var(--transition-fast); font-size: var(--font-size-sm); color: var(--color-body); }
.sidebar-cat-item:hover { background: rgba(196, 30, 58, 0.06); color: var(--color-primary); }
.sidebar-cat-item.active { background: rgba(196, 30, 58, 0.08); color: var(--color-primary); font-weight: 600; }
.sidebar-cat-count { font-size: var(--font-size-xs); color: var(--color-muted); background: var(--color-bg-light); padding: 2px 6px; border-radius: var(--radius-full); }
.price-range { display: flex; align-items: center; gap: var(--space-2); }
.price-range input { flex: 1; min-width: 0; padding: 7px var(--space-2); border: 1.5px solid var(--color-border); border-radius: var(--radius-md); font-size: var(--font-size-sm); outline: none; width: 0; }
.price-range input:focus { border-color: var(--color-primary); }
.price-range-sep { color: var(--color-muted); font-size: var(--font-size-sm); }

.products-main {}
.products-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-5); flex-wrap: wrap; gap: var(--space-3); }
.products-count { font-size: var(--font-size-sm); color: var(--color-muted); }
.products-sort { display: flex; align-items: center; gap: var(--space-2); }
.sort-label { font-size: var(--font-size-sm); color: var(--color-muted); }
.sort-select { padding: 6px var(--space-3); border: 1.5px solid var(--color-border); border-radius: var(--radius-md); font-size: var(--font-size-sm); outline: none; cursor: pointer; }
.sort-select:focus { border-color: var(--color-primary); }
.products-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }

/* ===== PRODUCT DETAIL PAGE ===== */
.product-detail-layout { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-10); align-items: start; }
.product-gallery { position: sticky; top: calc(var(--header-height) + var(--space-4)); }
.product-main-image { aspect-ratio: 1; border-radius: var(--radius-xl); overflow: hidden; background: var(--color-bg-light); margin-bottom: var(--space-3); }
.product-main-image img { width: 100%; height: 100%; object-fit: cover; }
.product-thumbs { display: flex; gap: var(--space-2); }
.product-thumb { width: 72px; height: 72px; border-radius: var(--radius-md); overflow: hidden; cursor: pointer; border: 2px solid transparent; transition: border-color var(--transition-fast); flex-shrink: 0; }
.product-thumb.active { border-color: var(--color-primary); }
.product-thumb img { width: 100%; height: 100%; object-fit: cover; }

.product-info {}
.product-title { font-size: var(--font-size-2xl); font-weight: 700; color: var(--color-title); margin-bottom: var(--space-3); line-height: 1.3; }
.product-price-row { display: flex; align-items: baseline; gap: var(--space-3); margin-bottom: var(--space-4); }
.product-price { font-size: var(--font-size-4xl); font-weight: 900; color: var(--color-primary); }
.product-original-price { font-size: var(--font-size-lg); color: var(--color-muted); text-decoration: line-through; }
.product-discount { background: var(--color-primary); color: white; font-size: var(--font-size-xs); font-weight: 700; padding: 3px 8px; border-radius: var(--radius-sm); }
.product-meta-row { display: flex; align-items: center; gap: var(--space-5); padding: var(--space-4) 0; border-top: 1px solid var(--color-border-light); border-bottom: 1px solid var(--color-border-light); margin-bottom: var(--space-5); }
.product-meta-item { display: flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-sm); color: var(--color-muted); }
.product-meta-item strong { color: var(--color-title); }

.product-spec-section { margin-bottom: var(--space-5); }
.product-spec-title { font-size: var(--font-size-sm); font-weight: 700; color: var(--color-title); margin-bottom: var(--space-3); }
.spec-options { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.spec-option { padding: 6px var(--space-4); border: 1.5px solid var(--color-border); border-radius: var(--radius-md); font-size: var(--font-size-sm); cursor: pointer; transition: all var(--transition-fast); }
.spec-option:hover { border-color: var(--color-primary); color: var(--color-primary); }
.spec-option.active { border-color: var(--color-primary); background: rgba(196, 30, 58, 0.06); color: var(--color-primary); font-weight: 600; }

.product-qty-row { display: flex; align-items: center; gap: var(--space-4); margin-bottom: var(--space-5); }
.product-qty-label { font-size: var(--font-size-sm); font-weight: 600; color: var(--color-title); }
.product-actions { display: flex; gap: var(--space-3); margin-bottom: var(--space-6); }
.product-actions .btn { flex: 1; padding: 14px; font-size: var(--font-size-base); }

.product-shop-card { border: 1.5px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-4); display: flex; align-items: center; gap: var(--space-4); }
.product-shop-logo { width: 48px; height: 48px; border-radius: var(--radius-md); background: var(--color-bg-light); display: flex; align-items: center; justify-content: center; font-size: 24px; flex-shrink: 0; }
.product-shop-info { flex: 1; }
.product-shop-name { font-weight: 700; color: var(--color-title); font-size: var(--font-size-base); }
.product-shop-meta { font-size: var(--font-size-xs); color: var(--color-muted); margin-top: 2px; }

/* Product detail tabs */
.detail-tabs { margin-top: var(--space-10); }
.tab-nav { display: flex; border-bottom: 2px solid var(--color-border); margin-bottom: var(--space-6); }
.tab-btn { padding: var(--space-3) var(--space-6); font-size: var(--font-size-base); font-weight: 600; color: var(--color-muted); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -2px; transition: all var(--transition-fast); background: none; border-top: none; border-left: none; border-right: none; }
.tab-btn:hover { color: var(--color-primary); }
.tab-btn.active { color: var(--color-primary); border-bottom-color: var(--color-primary); }
.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* Mobile sticky buy bar */
.mobile-buy-bar { display: none; position: fixed; bottom: 0; left: 0; right: 0; background: white; border-top: 1px solid var(--color-border); padding: var(--space-3) var(--space-4); z-index: var(--z-sticky); box-shadow: 0 -4px 12px rgba(0,0,0,0.1); }
.mobile-buy-bar-inner { display: flex; gap: var(--space-3); align-items: center; }
.mobile-buy-bar .btn { flex: 1; }
