:root{color:#1d2420;background:#f6f7f4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;background:#f6f7f4}button,select{font:inherit}button{cursor:pointer}button:disabled{cursor:default}.catalog-shell{width:min(1440px,100%);margin:0 auto;padding:24px}.catalog-header{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:20px}.eyebrow{margin:0 0 4px;color:#68736b;font-size:13px;font-weight:700;letter-spacing:0;text-transform:uppercase}h1{margin:0;color:#17211b;font-size:clamp(28px,4vw,44px);line-height:1.05;letter-spacing:0}.summary{display:flex;align-items:baseline;gap:8px;color:#68736b;white-space:nowrap}.summary span{color:#17211b;font-size:28px;font-weight:800}.filters{position:sticky;top:0;z-index:10;display:grid;grid-template-columns:auto minmax(180px,280px) minmax(200px,340px);gap:12px;align-items:end;margin:0 -24px 24px;padding:12px 24px;background:#f6f7f4f0;border-top:1px solid #e2e6dd;border-bottom:1px solid #d8ded3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.filters label{display:grid;gap:6px;color:#5b665e;font-size:12px;font-weight:700}.filters select{width:100%;height:42px;padding:0 36px 0 12px;color:#17211b;background:#fff;border:1px solid #cbd3c5;border-radius:8px}.segmented{display:grid;grid-template-columns:repeat(3,minmax(70px,1fr));height:42px;padding:3px;background:#e6eadf;border:1px solid #d2dacb;border-radius:8px}.segmented button{min-width:0;color:#536057;background:transparent;border:0;border-radius:6px;font-size:14px;font-weight:700}.segmented button.active{color:#fff;background:#276749;box-shadow:0 1px 3px #17211b2e}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px}.product-card{overflow:hidden;background:#fff;border:1px solid #e0e4dc;border-radius:8px;box-shadow:0 2px 10px #1f28220d}.image-button{display:block;width:100%;aspect-ratio:1 / 1;padding:0;overflow:hidden;background:#f0f2ed;border:0}.image-button img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .18s ease}.product-card:hover .image-button img{transform:scale(1.03)}.placeholder{display:grid;width:100%;height:100%;place-items:center;color:#6f7b72;background:linear-gradient(135deg,#eef1ea,#dfe6d8)}.placeholder span{display:grid;width:68px;height:68px;place-items:center;color:#fff;background:#718573;border-radius:50%;font-size:24px;font-weight:800;text-transform:uppercase}.product-body{display:grid;gap:10px;padding:12px}.meta-row,.attributes{display:flex;align-items:center;justify-content:space-between;gap:8px}.status{font-size:12px;font-weight:800}.status.available{color:#1f7a4a}.status.unavailable{color:#a04736}.qty,.attributes{color:#6c756d;font-size:12px}.title-button{min-height:58px;padding:0;color:#17211b;background:transparent;border:0;font-size:14px;font-weight:700;line-height:1.35;text-align:left;letter-spacing:0;display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:3}.attributes{min-width:0}.attributes span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notice{margin:24px 0;padding:16px;color:#536057;background:#fff;border:1px solid #dfe5da;border-radius:8px}.notice.error{color:#8f2c1e;background:#fff5f2;border-color:#efc6bb}.load-more{min-height:56px;display:grid;place-items:center;color:#6c756d;font-size:14px}.skeleton{padding-bottom:12px}.skeleton-image,.skeleton-line{background:linear-gradient(90deg,#e8ece3,#f5f6f1,#e8ece3);background-size:220% 100%;animation:pulse 1.3s ease-in-out infinite}.skeleton-image{aspect-ratio:1 / 1}.skeleton-line{height:14px;margin:12px 12px 0;border-radius:6px}.skeleton-line.short{width:44%}@keyframes pulse{0%{background-position:100% 0}to{background-position:-100% 0}}@media(max-width:760px){.catalog-shell{padding:16px}.catalog-header{align-items:start;flex-direction:column}.filters{grid-template-columns:1fr;margin:0 -16px 18px;padding:12px 16px}.grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.product-body{padding:10px}.title-button{min-height:76px;font-size:13px;-webkit-line-clamp:4}.attributes{display:grid;gap:4px}}
