.products-page{min-height:calc(100vh - 140px);padding:3rem 1.5rem}.products-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.products-header h1{font-family:var(--font-heading);font-size:2rem}.sort-container{align-items:center;gap:1rem;display:flex}.sort-select{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);color:var(--text-main);font-family:var(--font-body);outline:none;padding:.5rem 1rem}.products-layout{grid-template-columns:260px 1fr;align-items:start;gap:2rem;display:grid}.filters-sidebar{border-radius:var(--radius-lg);padding:1.5rem;position:sticky;top:90px}.filter-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.filter-group{margin-bottom:1.5rem}.filter-title{color:var(--text-main);margin-bottom:1rem;font-weight:600}.filter-options{flex-direction:column;gap:.75rem;display:flex}.checkbox-label{cursor:pointer;color:var(--text-muted);align-items:center;gap:.5rem;font-size:.95rem;display:flex}.price-slider{width:100%;accent-color:var(--primary)}@media (max-width:992px){.products-layout{grid-template-columns:1fr}.filters-sidebar{position:static}}.products-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;display:grid}@media (min-width:1200px){.products-grid{grid-template-columns:repeat(4,1fr)}}.pf-card{color:inherit;cursor:pointer;background:#fff;border:1px solid #e8f5e9;border-radius:16px;flex-direction:column;text-decoration:none;transition:transform .28s,box-shadow .28s;display:flex;overflow:hidden;box-shadow:0 2px 12px #1665340f}.pf-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px #16653424}.pf-card-image-wrap{background:linear-gradient(135deg,#f0fdf4 0%,#dcfce7 100%);width:100%;padding-top:100%;position:relative;overflow:hidden}.pf-card-img{object-fit:cover;object-position:center;width:100%;height:100%;transition:transform .4s;position:absolute;inset:0}.pf-card:hover .pf-card-img{transform:scale(1.07)}.pf-card-no-image{color:var(--text-muted);background:linear-gradient(135deg,#f0fdf4,#dcfce7);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;font-size:.8rem;display:flex;position:absolute;inset:0}.pf-card-no-image span:first-child{opacity:.5;font-size:2.5rem}.pf-card-overlay{opacity:0;background:linear-gradient(#0000 40%,#166534b3 100%);justify-content:center;align-items:flex-end;padding:1rem;transition:opacity .3s;display:flex;position:absolute;inset:0}.pf-card:hover .pf-card-overlay{opacity:1}.pf-view-btn{color:#fff;letter-spacing:.02em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff3;border:1px solid #fff6;border-radius:99px;padding:.45rem 1.2rem;font-size:.9rem;font-weight:700}.pf-card-badges{z-index:2;flex-direction:column;gap:.35rem;display:flex;position:absolute;top:.65rem;left:.65rem}.pf-badge{letter-spacing:.06em;text-transform:uppercase;border-radius:99px;padding:.18rem .55rem;font-size:.68rem;font-weight:800;display:inline-block}.pf-badge-offer{color:#fff;background:#ef4444}.pf-badge-variants{color:#fff;background:#166534}.pf-card-body{flex-direction:column;flex:1;padding:1rem 1.1rem 1.1rem;display:flex}.pf-card-brand{letter-spacing:.08em;text-transform:uppercase;color:var(--primary);margin-bottom:.3rem;font-size:.7rem;font-weight:800}.pf-card-title{color:var(--text-main);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.55rem;font-size:.95rem;font-weight:600;line-height:1.35;display:-webkit-box;overflow:hidden}.pf-card-rating{align-items:center;gap:.15rem;margin-bottom:.75rem;display:flex}.pf-rating-count{color:var(--text-muted);margin-left:.25rem;font-size:.75rem}.pf-card-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-top:auto;display:flex}.pf-price-wrap{align-items:baseline;gap:.4rem;display:flex}.pf-price{color:var(--text-main);font-size:1.15rem;font-weight:800}.pf-original-price{color:var(--text-muted);font-size:.8rem;text-decoration:line-through}.pf-free-delivery{color:var(--success);background:#dcfce7;border-radius:99px;padding:.15rem .55rem;font-size:.72rem;font-weight:700}.pf-delivery-fee{color:var(--text-muted);font-size:.72rem}.products-skeleton-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;width:100%;display:grid}.skeleton-card{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%) 0 0/200% 100%;border-radius:16px;height:320px;animation:1.4s infinite skeleton-shimmer}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
