.catalog{max-width:var(--max-width);margin:0 auto;padding-top:calc(var(--section-padding) / 2);padding-inline:var(--global-padding-margin--inline)}.catalog__header{text-align:center;margin-bottom:3rem}.catalog__container{display:grid;grid-template-columns:280px 1fr;gap:4rem}@media (max-width: 1024px){.catalog__container{grid-template-columns:1fr;gap:2rem}}.catalog__sidebar{background:#f9f9f9;padding:2rem;border-radius:8px;height:-moz-fit-content;height:fit-content}@media (max-width: 1024px){.catalog__sidebar{padding:1.5rem}}.filter-section{margin-bottom:2rem}.filter-section:last-child{margin-bottom:0}.filter-title-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.filter-title{font-size:1.3rem;font-weight:600;margin:0;color:var(--text-color)}.filter-group{display:flex;flex-direction:column;gap:.75rem}.filter-item{display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:color .2s;padding:.5rem .75rem;border-radius:6px;transition:all .2s ease}.filter-item:hover{color:var(--primary-color);background-color:#ba9b7a1a}.filter-item input[type=radio]{margin:0}.filter-label{font-size:1.1rem;line-height:1.4;text-transform:capitalize}.filter-reset{width:100%;background:var(--primary-color);color:#fff;border:none;padding:.75rem 1rem;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:background-color .2s}.filter-reset:hover{background:#9a7c5f}.filter-reset svg{fill:currentColor}.filter-reset-small{background:var(--primary-color);color:#fff;border:none;padding:.4rem .6rem;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:.3rem;font-size:.8rem;font-weight:500;transition:background-color .2s;flex-shrink:0}.filter-reset-small:hover{background:#9a7c5f}.filter-reset-small svg{fill:currentColor}.price-range-container{padding:1rem 0}.price-range-values{display:flex;justify-content:space-between;margin-bottom:1rem;font-weight:600;font-size:1.1rem;color:var(--primary-color)}.price-range-slider{position:relative;height:20px;margin-bottom:1rem}.price-range-slider input[type=range]{position:absolute;width:100%;height:4px;background:none;pointer-events:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.price-range-slider input[type=range]::-webkit-slider-track{height:6px;background:#ddd;border-radius:3px}.price-range-slider input[type=range]::-webkit-slider-thumb{height:18px;width:18px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:2px solid white;box-shadow:0 2px 4px #0003;-webkit-appearance:none;pointer-events:all;position:relative;z-index:2}.price-range-slider input[type=range]::-moz-range-track{height:6px;background:#ddd;border-radius:3px;border:none}.price-range-slider input[type=range]::-moz-range-thumb{height:18px;width:18px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:2px solid white;box-shadow:0 2px 4px #0003;pointer-events:all}.category-group{margin-bottom:.5rem}.category-header{display:flex;align-items:center;justify-content:space-between}.category-item{flex:1}.category-toggle{background:none;border:none;cursor:pointer;padding:.25rem;margin-left:.5rem;border-radius:3px;transition:background-color .2s,transform .2s}.category-toggle:hover{background-color:#0000001a}.category-toggle.expanded{transform:rotate(180deg)}.category-toggle svg{fill:#666}.subcategory-list{margin-left:1.5rem;margin-top:.5rem;padding-left:1rem;border-left:2px solid #eee;transition:all .3s ease;overflow:hidden}.subcategory-item{margin-bottom:.25rem;font-size:.95rem;transition:background-color .2s;padding:.4rem .5rem;border-radius:4px}.subcategory-item:hover{background-color:#ba9b7a14}.subcategory-item .filter-label{color:#666;font-size:1rem}.subcategory-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-color);flex-shrink:0;min-width:16px}.subcategory-item input[type=checkbox]:checked+.filter-label{color:var(--primary-color);font-weight:500}.subcategory-list:has(input[type=checkbox]:checked) .subcategory-header{background-color:#ba9b7a1a;padding:.5rem;margin:0 -.5rem .5rem;border-radius:4px}.category-group:not(:last-child){border-bottom:1px solid #f0f0f0;padding-bottom:1rem;margin-bottom:1rem}.filter-item input[type=radio],.filter-item input[type=checkbox]{width:18px;height:18px;margin:0;accent-color:var(--primary-color);flex-shrink:0;min-width:18px}.category-item .filter-label{font-weight:600;font-size:1.15rem}.catalog__content{min-width:0}.catalog__controls{display:flex;gap:1rem;margin-bottom:2rem;align-items:center;justify-content:space-between}.controls-right{display:flex;gap:1rem;align-items:center}@media (max-width: 768px){.catalog__controls{flex-direction:column;align-items:stretch}.controls-right{flex-direction:column;gap:.5rem}.catalog__pagination--top{align-self:center}}.search-box{position:relative;flex:1;max-width:400px}@media (max-width: 768px){.search-box{max-width:none}}.search-box input{width:100%;padding:.75rem 1rem .75rem 2.5rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.search-box input:focus{outline:none;border-color:var(--primary-color)}.search-box .search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:16px;height:16px;fill:#666}#sort-select{padding:.75rem 1rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;background:#fff;min-width:200px}@media (max-width: 768px){#sort-select{min-width:auto}}#sort-select:focus{outline:none;border-color:var(--primary-color)}.catalog__products{position:relative;min-height:400px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.no-results{text-align:center;padding:4rem 2rem;color:#666}.no-results svg{fill:#ccc;margin-bottom:1rem}.no-results h3{margin-bottom:.5rem}#products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;transition:opacity .3s;align-items:stretch}@media (max-width: 768px){#products-grid{grid-template-columns:repeat(2,1fr);gap:2rem}}@media (max-width: 480px){#products-grid{grid-template-columns:1fr;gap:1rem}}.product-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;height:100%}.product-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.product-link{display:flex;flex-direction:column;height:100%;text-decoration:none;color:inherit}.product-image{aspect-ratio:4/3;background:#ebebeb;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;border-radius:8px 8px 0 0;border:2px solid #e0e0e0;border-bottom:none;transition:border-color .3s,box-shadow .3s;cursor:pointer}.product-card:hover .product-image{border-color:var(--primary-color);box-shadow:0 4px 12px #ba9b7a33}.product-card:hover .product-info{border-color:var(--primary-color)}.product-image img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;transition:transform .4s ease}.product-card:hover .product-image img{transform:scale(1.05)}.product-image:after{content:"";position:absolute;top:12px;right:12px;width:28px;height:28px;background:#ffffffe6;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:all .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px #0000001a;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' fill='%23ba9b7a'%3E%3Cpath d='M320 0c-17.7 0-32 14.3-32 32s14.3 32 32 32h82.7L201.4 265.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L448 109.3V192c0 17.7 14.3 32 32 32s32-14.3 32-32V32c0-17.7-14.3-32-32-32H320zM80 32C35.8 32 0 67.8 0 112V432c0 44.2 35.8 80 80 80H400c44.2 0 80-35.8 80-80V320c0-17.7-14.3-32-32-32s-32 14.3-32 32V432c0 8.8-7.2 16-16 16H80c-8.8 0-16-7.2-16-16V112c0-8.8 7.2-16 16-16H192c17.7 0 32-14.3 32-32s-14.3-32-32-32H80z'/%3E%3C/svg%3E");background-size:16px 16px;background-repeat:no-repeat;background-position:center}.product-card:hover .product-image:after{opacity:1;transform:scale(1);animation:linkPulse 2s infinite}@keyframes linkPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.product-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.product-placeholder svg{width:48px;height:48px;fill:#ccc}.product-info{padding:1rem;flex:1;display:flex;flex-direction:column;border:2px solid #e0e0e0;border-top:none;border-radius:0 0 8px 8px}.product-title{font-size:1.1rem;font-weight:600;margin-bottom:.5rem;line-height:1.3;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-category{font-size:.9rem;color:#666;margin-bottom:.25rem}.product-price{font-size:1.3rem;font-weight:600;color:var(--primary-color);margin-top:auto}.catalog__pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:3rem;padding-top:2rem}.catalog__pagination button{padding:.75rem 1.5rem;border:1px solid #ddd;background:#fff;color:var(--text-color);border-radius:4px;cursor:pointer;transition:all .2s}.catalog__pagination button:hover:not(:disabled){background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.catalog__pagination button:disabled{opacity:.5;cursor:not-allowed}#page-info{font-weight:500;color:#666}.catalog__pagination--top{margin:0;padding:0;border:none;gap:.5rem}.catalog__pagination--top button{padding:.4rem .8rem;font-size:.9rem;min-width:32px}.catalog__pagination--top span{font-size:.9rem;font-weight:500;color:#666;white-space:nowrap}
