.catalog{background:#f9fafb;padding:clamp(2rem,5vw,4rem) 0}.catalog-header{text-align:center;max-width:800px;margin:0 auto 3rem}.catalog-header .tag{display:inline-block;font-size:.875rem;font-weight:600;color:#2563eb;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.catalog-header h1{font-size:clamp(1.75rem,5vw,2.5rem);margin:0 0 1rem;color:#0f172a}.catalog-header p{font-size:1.0625rem;color:#64748b;line-height:1.6;margin-bottom:1.5rem}.catalog-info-box{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;text-align:left;margin-top:1.5rem}.catalog-info-box svg{flex-shrink:0;color:#2563eb;margin-top:.125rem}.catalog-info-box p{margin:0;font-size:.9375rem;color:#1e40af;line-height:1.5}.catalog-info-box strong{font-weight:600}.catalog-layout{display:grid;grid-template-columns:260px 1fr;gap:2rem;max-width:1400px;margin:0 auto;align-items:start}@media (max-width: 1000px){.catalog-layout{grid-template-columns:1fr}}.catalog-sidebar{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000f;position:sticky;top:100px;height:fit-content}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.catalog-sidebar h2{font-size:1.125rem;margin:0;color:#0f172a}.sidebar-toggle{display:none;background:none;border:none;padding:.5rem;cursor:pointer;color:#64748b;transition:transform .3s,color .2s}.sidebar-toggle:hover{color:#2563eb}.sidebar-toggle svg{transition:transform .3s}.catalog-sidebar.is-collapsed .sidebar-toggle svg{transform:rotate(-180deg)}@media (max-width: 1000px){.catalog-sidebar{position:static}}.filter-form{display:grid;gap:1.5rem}fieldset{border:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.625rem}legend{font-weight:600;margin-bottom:.5rem;font-size:.9375rem;color:#0f172a}.checkbox{display:flex;align-items:center;gap:.625rem;font-size:.9375rem;cursor:pointer}.checkbox input{width:16px;height:16px;cursor:pointer}.checkbox span{color:#475569}.checkbox input:checked+span{color:#0f172a;font-weight:500}.catalog-main{display:grid;gap:1.5rem}.catalog-toolbar{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1.25rem}@media (min-width: 1024px){.catalog-toolbar{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end}}.search-group{flex:1;min-width:220px}@media (min-width: 1024px){.search-group{grid-column:1;grid-row:1}}.search-group input{width:100%;padding:.75rem 1.25rem;border-radius:999px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 3px #0000000d;font-size:.9375rem;transition:border-color .2s,box-shadow .2s}.search-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.toolbar-controls{display:flex;align-items:flex-start;gap:1.25rem;flex-wrap:wrap}@media (min-width: 1024px){.toolbar-controls{grid-column:2;grid-row:1;justify-content:flex-end}}.toolbar-controls label{display:flex;flex-direction:column;gap:.5rem;font-weight:600;font-size:.875rem;color:#0f172a;white-space:nowrap}.toolbar-controls select{padding:.625rem .875rem;border-radius:8px;border:1px solid #e2e8f0;background:#fff;font-size:.9375rem;cursor:pointer;transition:border-color .2s;min-width:160px}.toolbar-controls select:focus{outline:none;border-color:#2563eb}.view-toggle-group{display:flex;flex-direction:column;gap:.5rem}.view-toggle-group>div{display:flex;gap:.5rem}.view-toggle-group button{padding:.625rem .875rem;border:1px solid #e2e8f0;background:#fff;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;color:#64748b;height:40px}.view-toggle-group button:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}.view-toggle-group button.is-active{background:#2563eb;color:#fff;border-color:#2563eb}.view-toggle-group button svg{width:20px;height:20px}.catalog-result{margin:0;color:var(--color-muted)}.catalog .product-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));align-items:stretch;grid-auto-rows:1fr}.catalog .product-grid.is-list{grid-template-columns:1fr;gap:1rem;align-items:start;grid-auto-rows:auto}@media (max-width: 640px){.catalog .product-grid{grid-template-columns:1fr}}.catalog .product-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;align-self:stretch;height:100%;transition:transform .2s,box-shadow .2s;padding:0}.catalog .product-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.catalog .product-grid.is-list .product-card{flex-direction:row;height:auto;min-height:120px;max-height:none;align-self:start;border:none;box-shadow:0 2px 8px #0000000f;transform:none;align-items:center;padding:16px;gap:16px}.catalog .product-grid.is-list .product-card:hover{transform:translate(3px);box-shadow:0 6px 18px #0f172a14}.catalog .product-image{width:100%;height:200px;overflow:hidden;background:#f1f5f9;flex-shrink:0}.catalog .product-image img{width:100%;height:100%;object-fit:cover}.catalog .product-grid.is-list .product-image{width:90px;height:90px;min-width:90px;min-height:90px;max-height:90px;flex-shrink:0;border-radius:12px;overflow:hidden;box-shadow:0 2px 6px #0f172a14;background:#fff;display:flex;align-items:center;justify-content:center;border:1px solid #e2e8f0}.catalog .product-grid.is-list .product-image img{width:100%;height:100%;object-fit:contain;padding:8px}.image-fallback{width:100%;height:100%;background:linear-gradient(135deg,#e0f2fe,#dbeafe);display:flex;align-items:center;justify-content:center}.catalog .product-body{padding:1.25rem;flex:1;display:flex;flex-direction:column;gap:.75rem}.catalog .product-grid.is-list .product-body{padding:0;overflow:hidden;flex:1;min-width:0;display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;column-gap:12px;row-gap:6px;align-content:center}.catalog .product-body h3{font-size:1.0625rem;margin:0;color:#0f172a;line-height:1.4;min-height:2.8em;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.catalog .product-grid.is-list .product-body h3{font-size:.9375rem;font-weight:600;min-height:auto;-webkit-line-clamp:1;line-clamp:1;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;margin:0;color:#0f172a;line-height:1.3;grid-column:1;grid-row:1}.catalog .product-summary{margin:0;font-size:.875rem;color:#64748b;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex-shrink:0}.catalog .product-grid.is-list .product-summary{display:-webkit-box;font-size:.8125rem;line-height:1.5;color:#64748b;margin:0;overflow:hidden;text-overflow:ellipsis;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;grid-column:1 / -1;grid-row:2}.catalog .product-presentations-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto;min-height:2rem;align-content:flex-start}.catalog .product-grid.is-list .product-presentations-list{margin-top:0;min-height:auto;display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:flex-end;grid-column:2;grid-row:1}.catalog .product-grid.is-list .presentation-badge{font-size:.6875rem;padding:.15rem .45rem;line-height:1.2;border-radius:999px;white-space:nowrap}@media (max-width: 720px){.catalog .product-grid.is-list{gap:.75rem}.catalog .product-grid.is-list .product-card{height:92px;min-height:92px;max-height:92px;align-items:center}.catalog .product-grid.is-list .product-image{width:64px;height:64px;min-height:64px;max-height:64px;margin-left:10px;border-radius:10px}.catalog .product-grid.is-list .product-image img{padding:4px}.catalog .product-grid.is-list .product-body{grid-template-columns:1fr;grid-template-rows:auto auto auto;padding:0 10px;row-gap:4px}.catalog .product-grid.is-list .product-body h3{font-size:.9rem}.catalog .product-grid.is-list .product-summary{display:none}.catalog .product-grid.is-list .product-presentations-list{grid-column:1;grid-row:2;margin-top:0;display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;gap:6px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.catalog .product-grid.is-list .product-presentations-list::-webkit-scrollbar{display:none}.catalog .product-grid.is-list .presentation-badge{font-size:.66rem;padding:.14rem .42rem}.catalog .product-grid.is-list .product-actions{padding:10px;min-width:108px;max-width:108px;gap:8px}.catalog .product-grid.is-list .product-actions .btn{font-size:.78rem;padding:.4rem .55rem}}.catalog .presentation-badge{padding:.25rem .625rem;border-radius:6px;background:#eff6ff;color:#1e40af;font-weight:500;font-size:.8125rem;border:1px solid #bfdbfe}.catalog .product-actions{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid #e2e8f0}.catalog .product-grid.is-list .product-actions{border-top:none;border-left:1px solid #e2e8f0;padding:0 0 0 16px;margin-left:16px;min-width:100px;max-width:100px;flex-direction:column;gap:6px;justify-content:center;align-self:stretch;background:transparent;display:flex}.catalog .product-grid.is-list .product-actions .btn{font-size:.75rem;padding:.4rem .65rem;white-space:nowrap;width:100%;justify-content:center}.catalog .product-actions .btn{margin:0}.catalog .filter-empty{margin:0;color:var(--color-muted);font-size:.85rem}.pagination{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;padding-top:2rem}.pagination button{min-width:40px;height:40px;padding:0 .75rem;border-radius:8px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;font-weight:500;font-size:.9375rem;color:#475569;transition:all .2s}.pagination button:hover:not(:disabled){border-color:#2563eb;color:#2563eb;background:#eff6ff}.pagination button.is-active{background:#2563eb;color:#fff;border-color:#2563eb}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination button.is-ellipsis{opacity:1;cursor:default;border-color:transparent;background:transparent;color:#94a3b8}.empty-state{margin:1rem 0 0;color:var(--color-muted)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@media (max-width: 768px){.catalog{padding:clamp(1.5rem,4vw,3rem) 0}.catalog-header{margin-bottom:2rem;padding:0 1rem}.catalog-header h1{font-size:clamp(1.5rem,6vw,2rem)}.catalog-header p{font-size:1rem}.catalog-info-box{padding:.875rem 1rem;font-size:.875rem}.catalog-layout{padding:0 1rem}.catalog-sidebar{margin-bottom:1.25rem}.sidebar-toggle{display:flex;align-items:center;justify-content:center}.catalog-toolbar{display:flex;flex-direction:column;gap:1rem}.toolbar-controls{order:1}.search-group{order:2}.filter-form{overflow:hidden;max-height:2000px;transition:max-height .4s ease-in-out,opacity .3s ease-in-out;opacity:1}.catalog-sidebar.is-collapsed .filter-form{max-height:0;opacity:0;margin-top:0}.catalog-sidebar.is-collapsed .sidebar-header{margin-bottom:0}.catalog .product-grid{gap:1.25rem}.catalog .product-card{box-shadow:0 1px 4px #00000014}.catalog .product-image{height:180px}.catalog .product-body{padding:1rem;gap:.625rem}.catalog .product-body h3{font-size:1rem}.catalog .product-summary{font-size:.8125rem}.catalog .presentation-badge{font-size:.75rem;padding:.2rem .5rem}.catalog .product-actions{padding:.875rem 1rem;gap:.625rem}.pagination{padding-top:1.5rem;gap:.375rem}.pagination button{min-width:36px;height:36px;padding:0 .625rem;font-size:.875rem}}@media (max-width: 600px){.catalog-header,.catalog-layout{padding:0 .75rem}.catalog-toolbar{flex-direction:column;align-items:stretch;gap:.75rem}.search-group{min-width:100%}.toolbar-controls{width:100%;flex-direction:column;gap:.75rem}.toolbar-controls label,.toolbar-controls select{width:100%}.catalog .product-image{height:160px}.catalog .product-body h3{font-size:.9375rem}fieldset legend,.checkbox{font-size:.875rem}}@media (max-width: 400px){.catalog-header h1{font-size:1.375rem}.catalog .product-actions{grid-template-columns:1fr}.pagination button{min-width:32px;height:32px;font-size:.8125rem}}
