.product-catalog-container{max-width:1200px;margin:0 auto;padding:20px}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.product-card{background:#fff;border:1px solid #ddd;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px rgb(0 0 0 / .1);display:flex;flex-direction:column;transition:transform 0.2s,box-shadow 0.2s}.product-card:hover{transform:translateY(-5px);box-shadow:0 4px 8px rgb(0 0 0 / .2)}.product-image-container{position:relative;width:100%;height:auto;overflow:hidden}.product-image{width:100%;height:200px;object-fit:cover;display:block}.no-image-placeholder{width:100%;height:200px;background:#f0f0f0;display:flex;align-items:center;justify-content:center;font-size:40px;color:#999}.product-plan{position:absolute;top:10px;right:10px;background:#007bff;color:#fff;padding:5px 10px;border-radius:4px;border:1px solid #0056b3;font-size:14px;z-index:5}.product-info{padding:15px;flex-grow:1;display:flex;flex-direction:column;min-height:150px}.product-title{margin:0 0 10px;font-size:20px;color:#333}.product-category{margin:0 0 10px;font-size:16px;color:#666;display:block;z-index:2}.product-description{margin:0 0 10px;font-size:14px;color:#555;flex-grow:1;display:block;z-index:2}.product-footer{margin-top:auto;display:flex;justify-content:flex-end;align-items:center}.product-catalog-order-button{background:#106EBE;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:14px;transition:background 0.2s;pointer-events:auto;touch-action:manipulation;position:relative;z-index:10}.product-catalog-order-button:hover{background:#0d5a9e}.popup-container{position:fixed;top:0;left:0;width:100%;height:100%;background:rgb(0 0 0 / .5);display:flex;justify-content:center;align-items:center;z-index:1001;opacity:1;visibility:visible}.popup-content{background:#fff;padding:15px;border-radius:8px;text-align:center;max-width:350px;width:90%;box-shadow:0 4px 8px rgb(0 0 0 / .2)}.popup-content h3{margin:0 0 10px;font-size:22px;color:#333}.popup-content p{margin:0 0 15px;font-size:14px;color:#555}.popup-close-button{background:#106EBE;color:#fff;border:none;padding:8px 15px;border-radius:5px;cursor:pointer;font-size:14px}.popup-close-button:hover{background:#0d5a9e}.order-form-container{position:fixed;top:0;left:0;width:100%;height:100%;background:rgb(0 0 0 / .5);display:flex;justify-content:center;align-items:flex-start;padding-top:20px;z-index:1001;overflow-y:auto;opacity:1;visibility:visible}.order-form{background:#fff;padding:15px;border-radius:8px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 4px 8px rgb(0 0 0 / .2);pointer-events:auto}.order-form-header{display:flex;justify-content:space-between;align-items:center;background:#f8f9fa;padding:8px 15px;border-bottom:1px solid #ddd;flex-wrap:wrap}.order-form-header h3{margin:0;font-size:18px;flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.close-form-button{background:none;border:none;font-size:22px;cursor:pointer;color:#333;pointer-events:auto;z-index:1002}.form-group{margin-bottom:12px}.form-group label{display:block;margin-bottom:4px;font-size:13px;color:#333}.form-group input,.form-group textarea{width:100%;padding:6px;border:1px solid #ddd;border-radius:4px;font-size:13px;pointer-events:auto}.form-group input.error,.form-group textarea.error{border-color:#dc3545}.form-actions{text-align:right}.submit-button{background:#106EBE;color:#fff;border:none;padding:8px 15px;border-radius:5px;cursor:pointer;font-size:13px;pointer-events:auto;display:flex;align-items:center;justify-content:center;gap:8px;position:relative;width:100%}.submit-button:hover:not(:disabled){background:#0d5a9e}.submit-button:disabled{background:#6c757d;cursor:not-allowed;pointer-events:none}.spinner{width:16px;height:16px;border:2px solid #fff;border-top:2px solid #fff0;border-radius:50%;animation:spin 1s linear infinite;opacity:.5}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.form-message.error{color:#dc3545;background:#f8d7da;padding:8px;border-radius:4px;margin-bottom:12px;font-size:13px}.form-message.success{color:#28a745;background:#d4edda;padding:8px;border-radius:4px;margin-bottom:12px;font-size:13px}@media (max-width:768px){.product-grid{grid-template-columns:1fr;gap:12px}.product-card{margin:0 auto;max-width:100%}.product-card:hover{transform:none}.product-image-container{height:auto}.product-image,.no-image-placeholder{height:150px}.product-plan{font-size:12px;padding:4px 8px;top:8px;right:8px}.product-title{font-size:18px}.product-category,.product-description{font-size:13px;margin:5px 0}.product-info{min-height:120px}.product-catalog-order-button{width:100%;padding:10px;font-size:13px;z-index:10}.popup-content{width:90%;max-width:320px;padding:12px}.popup-content h3{font-size:20px}.popup-content p{font-size:13px}.popup-close-button{width:100%;padding:10px;font-size:13px}.order-form-container{padding-top:15px}.order-form{width:90vw;max-width:400px;padding:12px;max-height:80vh}.order-form-header h3{font-size:16px}.close-form-button{font-size:20px}.form-group label{font-size:12px}.form-group input,.form-group textarea{font-size:12px;padding:5px}.submit-button{padding:10px;font-size:12px}.spinner{width:14px;height:14px}}@media (max-width:480px){.product-image,.no-image-placeholder{height:120px}.product-plan{font-size:11px;padding:3px 6px;top:6px;right:6px}.product-title{font-size:16px}.product-category,.product-description{font-size:12px;margin:4px 0}.product-info{min-height:100px}.popup-content{width:85%;padding:10px}.popup-content h3{font-size:18px}.popup-content p{font-size:12px}.order-form{width:85vw;padding:10px}.order-form-header h3{font-size:14px}.close-form-button{font-size:18px}.spinner{width:12px;height:12px}}