:root{--primary:#4CAF50;--secondary:#388E3C;--accent:#8BC34A;--dark:#5D4037;--darker:#3E2723;--light:#F1F8E9;--cream:#FFF8E1;--white:#FFFFFF;--text:#212121;--text-light:#757575;--border:#E0E0E0;--nav-menu-height:60px;--stock-color:#4CAF50;--out-of-stock-color:#F44336;--bestseller-color:#FF9800;--new-color:#2196F3;--discount-color:#FF5722;--radius:12px;--gray-bg:#f7f7f7}
.df-sorting-section{display:none!important}
.df-page-container{max-width:1600px;margin:0 auto;padding:0 16px 20px;background:var(--white)}
@media(max-width:992px){.df-page-container{padding:0;width:100%;max-width:100%}}
@media(min-width:993px){.filters-btn-text{display:none!important}}
.df-sorting-section{display:flex;align-items:center;gap:12px;padding:12px 16px;margin:8px 0;background:#fff;border:1px solid #e8e8e8;border-radius:10px;flex-wrap:wrap}
.sort-label{font-weight:600;color:#222;font-size:14px}.sort-controls{display:flex;gap:8px;align-items:center}
.sort-select,.sort-dir-select{padding:6px 12px;border:1px solid var(--border);border-radius:6px;font-size:13px;background:var(--white);cursor:pointer;transition:border-color .2s}
.sort-select:hover,.sort-dir-select:hover{border-color:var(--primary)}
.active-filters-section{display:flex;flex-wrap:nowrap;align-items:center;gap:8px;padding:10px 14px;margin:8px 0 4px;background:#fff;border:1px solid #e8e8e8;border-radius:10px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.active-filters-section::-webkit-scrollbar{display:none}.active-filters-section:empty{display:none!important}
@media(max-width:992px){.active-filters-section{margin:8px 12px 4px;padding:8px 12px;border-radius:8px}}
.filter-tag{display:inline-flex;align-items:center;gap:6px;flex-shrink:0;white-space:nowrap;background:#f7f7f7;color:#333;padding:5px 10px 5px 12px;border-radius:5px;font-size:10px;font-weight:500;border:1px solid #e0e0e0;transition:border-color .2s,background .2s}
.filter-tag:hover{border-color:#bbb;background:#f0f0f0}
.remove-filter{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#ddd;color:#555;font-size:10px;font-weight:700;cursor:pointer;line-height:1;flex-shrink:0;transition:background .2s,color .2s}
.remove-filter:hover{background:#bbb;color:#222}
.df-container{display:flex;gap:24px;align-items:flex-start;background:var(--white)}
@media(max-width:992px){.df-container{flex-direction:column;gap:0;width:100%}}
/* Товары в DOM первые, но визуально правее фильтров */
.df-products-wrapper{order:2}
.df-left-sidebar{order:1;width:280px;flex-shrink:0;background:var(--white)}
/* На мобилке сайдбар полностью скрыт из потока — не тратим время на рендер */
@media(max-width:992px){
  .df-left-sidebar{width:0;height:0;overflow:visible;padding:0;margin:0;order:1}
  .df-products-wrapper{order:1;width:100%}
}
.df-filters.filters-block{width:280px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 2px 12px rgba(0,0,0,.08);position:sticky;top:calc(var(--nav-menu-height) + 20px)}
@media(max-width:992px){.df-filters.filters-block{position:fixed;top:0;left:0;width:85vw;max-width:380px;height:100dvh;z-index:1000;border-radius:0 16px 16px 0;box-shadow:4px 0 24px rgba(0,0,0,.15);overflow-y:auto;display:none;flex-direction:column;transition:none}.df-filters.filters-block.active{display:flex;transform:translateX(0);transition:transform .35s cubic-bezier(.4,0,.2,1)}}
.df-filters-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);z-index:999;opacity:0;transition:opacity .35s ease}
.df-filters-overlay.visible{opacity:1}
.filters-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--white);position:sticky;top:0;z-index:10}
.filters-toggle{font-weight:600;color:#222;font-size:15px}
.df-reset{background:#f5f5f5;color:#555;border:1px solid #ccc;border-radius:6px;padding:7px 13px;font-weight:500;font-size:13px;cursor:pointer;transition:all .2s ease}
.df-reset:hover{background:#e0e0e0;color:#333;border-color:#999}
.df-filters-close{display:none}
@media(max-width:992px){.df-filters-close{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:#f0f0f0;border-radius:50%;cursor:pointer;color:#444;font-size:18px;flex-shrink:0}}
.filters-content{padding:12px}
@media(max-width:992px){.filters-content{flex:1;overflow-y:auto}}
.filter-group{margin-bottom:10px;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--white)}
.filter-title{padding:12px 14px;font-weight:600;color:#222;background:var(--white);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:14px;transition:background .2s ease}
.filter-title:hover{background:#fafafa}
.filter-group:not(.category-block):not(.labels-block):not(.price-block) .filter-title{padding-right:36px;position:relative}
.filter-group:not(.category-block):not(.labels-block):not(.price-block) .filter-title::after{content:"";position:absolute;right:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8.5 5L15.5 12L8.5 19' stroke='%23777' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;transition:transform .3s ease}
.filter-group:not(.category-block):not(.labels-block):not(.price-block).active .filter-title::after{transform:translateY(-50%) rotate(90deg)}
.filter-options{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease;padding:0 14px;background:var(--white)}
.filter-group.active .filter-options{padding:8px 14px 12px;overflow:hidden}
.filter-group.active .filter-options.has-scroll{overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:#ccc #f5f5f5}
.filter-group.active .filter-options.has-scroll::-webkit-scrollbar{width:4px}
.filter-group.active .filter-options.has-scroll::-webkit-scrollbar-track{background:#f5f5f5}
.filter-group.active .filter-options.has-scroll::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}
.filter-group.price-block .filter-options{max-height:none!important;overflow:visible!important;padding:8px 14px 12px}
.filter-options label:not(.label-option){display:block;padding:6px 0;font-size:13px;cursor:pointer;opacity:0;transform:translateY(6px);transition:opacity .25s ease,transform .25s ease}
.filter-group.active .filter-options label:not(.label-option){opacity:1;transform:translateY(0)}
.filter-options label:not(.label-option):hover{color:var(--primary)}
.labels-group{margin-bottom:10px}.labels-grid{display:grid;grid-template-columns:1fr;gap:6px}
.labels-block .filter-options{max-height:none!important;overflow:visible!important;padding:8px 12px 12px!important}
.label-option{display:flex;align-items:center;padding:10px 12px;cursor:pointer;border-radius:8px;border:1px solid var(--border);background:var(--white);transition:all .2s ease;font-size:13px;margin:0}
.label-option:hover{background:#fafafa;border-color:var(--accent)}
.label-option input{display:none}
.label-icon{width:20px;height:20px;margin-right:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.label-text{flex:1;color:#222;font-weight:500}
.filter-count{color:var(--secondary);font-size:12px;margin-left:6px;background:var(--light);padding:2px 7px;border-radius:10px}
.label-option[data-label="in_stock"] .label-icon{color:var(--stock-color)}
.label-option[data-label="out_of_stock"] .label-icon{color:var(--out-of-stock-color)}
.label-option[data-label="bestseller"] .label-icon{color:var(--bestseller-color)}
.label-option[data-label="new"] .label-icon{color:var(--new-color)}
.label-option[data-label="discount"] .label-icon{color:var(--discount-color)}
.range-inputs{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.range-inputs input{width:70px;padding:7px;border:1px solid var(--border);border-radius:6px;text-align:center;font-size:13px;background:var(--white);transition:border-color .2s ease}
.range-inputs input:focus{outline:none;border-color:var(--primary)}
.range-slider{position:relative;height:4px;background:#e0e0e0;border-radius:4px;margin:18px 0}
.slider-track{position:absolute;height:100%;background:var(--primary);border-radius:4px;z-index:1}
.range-slider input[type="range"]{position:absolute;width:100%;height:4px;background:transparent;pointer-events:none;-webkit-appearance:none;z-index:2}
.range-slider input[type="range"]::-webkit-slider-thumb{pointer-events:all;width:16px;height:16px;border-radius:50%;background:var(--white);border:2px solid var(--primary);box-shadow:0 2px 4px rgba(0,0,0,.15);cursor:pointer;-webkit-appearance:none;transition:transform .2s ease}
.range-slider input[type="range"]::-webkit-slider-thumb:hover{transform:scale(1.2)}
.range-values{text-align:center;margin-top:10px;font-size:12px;color:var(--text-light)}
.filter-disabled{opacity:.4!important;pointer-events:none!important}
.df-products-wrapper{flex:1;background:var(--white);min-width:0;transition:opacity .2s ease}
@media(max-width:992px){.df-products-wrapper{width:100%;padding:0 12px;box-sizing:border-box}.df-products-wrapper>.df-products,.df-products-wrapper .ms2Results,.df-products-wrapper .products-list{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:12px!important;width:100%!important}.df-products-wrapper .ms2Results>*,.df-products-wrapper .products-list>*{width:100%!important;max-width:100%!important}}
.df-products{width:100%;background:var(--white)}
.df-pagination-wrapper{display:flex;justify-content:center;margin-top:32px;margin-bottom:32px;padding:0 10px}
.df-pagination{display:flex;justify-content:center;align-items:center;gap:6px;flex-wrap:wrap}
.df-pagination a,.df-pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 12px;border:1px solid var(--border);border-radius:8px;text-decoration:none;color:var(--text);font-size:14px;font-weight:500;transition:all .2s ease;background:var(--white)}
.df-pagination a:hover{background:var(--light);border-color:var(--accent);color:var(--darker)}
.df-pagination-current{background:var(--primary)!important;color:var(--white)!important;border-color:var(--primary)!important}
.df-pagination-dots{border:none!important;background:transparent;min-width:20px!important;color:var(--text-light)}
.df-pagination-prev,.df-pagination-next{background:var(--cream);font-weight:600;font-size:13px}
@media(max-width:992px){.df-pagination-wrapper{overflow-x:auto;justify-content:flex-start}.df-pagination{flex-wrap:nowrap;gap:4px}.df-pagination a,.df-pagination span{min-width:34px;height:34px;font-size:13px;padding:0 10px}}
/* Скелетон — показывается пока грузятся реальные карточки */
.df-skeleton-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:0}
@media(min-width:993px){.df-skeleton-grid{grid-template-columns:repeat(4,1fr)}}
.df-skeleton-card{background:#fff;border-radius:8px;overflow:hidden;border:1px solid #eee}
.df-skeleton-img{width:100%;aspect-ratio:1/1;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.2s infinite}
.df-skeleton-body{padding:8px}
.df-skeleton-line{height:12px;border-radius:4px;margin-bottom:6px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.2s infinite}
.df-skeleton-line.short{width:60%}
.df-skeleton-line.price{width:40%;height:16px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@media(prefers-reduced-motion:reduce){.df-skeleton-img,.df-skeleton-line{animation:none}}