.shop-layout { display: grid; grid-template-columns: 260px 1fr; gap: 56px; align-items: start; max-width: var(--max-w); margin: 0 auto; padding: 64px var(--pad-x); }
.filter-sidebar {}
.filter-sticky { position: sticky; top: 100px; }
.filter-section { margin-bottom: 36px; border-bottom: 1px solid var(--border); padding-bottom: 28px; }
.filter-section:last-child { border-bottom: none; }
.filter-heading { font-size: 11px; letter-spacing: .17em; text-transform: uppercase; color: var(--coal); font-weight: 500; margin-bottom: 18px; }
.filter-option { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; cursor: pointer; }
.filter-option input[type="checkbox"] { width: 15px; height: 15px; accent-color: var(--coal); cursor: pointer; }
.filter-option label { font-size: 13.5px; color: var(--ink2); cursor: pointer; font-weight: 300; transition: color .2s; }
.filter-option:hover label { color: var(--coal); }
.filter-count { font-size: 11px; color: var(--stone); margin-left: auto; }
.filter-clear { font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--stone); border: none; background: none; cursor: pointer; padding: 0; transition: color .2s; }
.filter-clear:hover { color: var(--coal); }

.shop-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 36px; }
.shop-count { font-size: 13px; color: var(--ink2); font-weight: 300; }
.shop-sort { display: flex; align-items: center; gap: 12px; }
.shop-sort label { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink2); }
.shop-sort select { font-size: 13px; color: var(--coal); border: none; border-bottom: 1px solid var(--border); background: transparent; padding: 6px 24px 6px 0; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23B5A898' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 2px center; cursor: pointer; outline: none; }

.shop-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; transition: opacity .3s; }
.shop-grid .prod-card-img { aspect-ratio: 4/5; }

/* Color gradients for products */
.bg-olive-sm { background: linear-gradient(150deg,#B8C0A0,#8A9A70,#607250); }
.bg-olive-md { background: linear-gradient(150deg,#B0BA98,#829068,#5C6A48); }
.bg-olive-lg { background: linear-gradient(150deg,#C0C8A8,#92A278,#688058); }
.bg-palm-sm  { background: linear-gradient(150deg,#A0BEAE,#70927C,#487062); }
.bg-palm-md  { background: linear-gradient(150deg,#98B8A8,#688A78,#486858); }
.bg-fiddle   { background: linear-gradient(150deg,#C8C098,#A09868,#787048); }
.bg-boxwood  { background: linear-gradient(150deg,#B0BE98,#8A9878,#627258); }
.bg-banana   { background: linear-gradient(150deg,#BCBC8E,#989060,#6E6A40); }
.bg-monstera { background: linear-gradient(150deg,#A8C0A0,#788A70,#507058); }

.category-anchor { scroll-margin-top: 90px; }

/* Banner */
.shop-banner { background: var(--bg2); border: 1px solid var(--border); padding: 20px 24px; display: flex; align-items: center; justify-content: space-between; margin-bottom: 36px; }
.shop-banner p { font-size: 13px; color: var(--ink2); font-weight: 300; }
.shop-banner a { font-size: 11px; letter-spacing: .13em; text-transform: uppercase; color: var(--coal); font-weight: 500; white-space: nowrap; text-decoration: none; border-bottom: 1px solid var(--coal); }

/* Load more */
.load-more { text-align: center; margin-top: 56px; padding-top: 48px; border-top: 1px solid var(--border); }

@media (max-width: 960px) {
  .shop-layout { grid-template-columns: 1fr; }
  .filter-sticky { position: static; }
  .filter-sidebar { display: none; }
  .shop-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .shop-grid { grid-template-columns: 1fr; }
}
