*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;color:#333;line-height:1.6}a{text-decoration:none;color:inherit}ul,ol{list-style:none}button{font-family:inherit;font-size:inherit}#root{width:100%;height:100%}.product-card{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;height:100%;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;background-color:#fff}.product-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000026}.product-image-container{position:relative;width:100%;height:200px;overflow:hidden;background-color:#f5f5f5}.product-image{width:100%;height:100%;object-fit:contain;padding:8px;transition:transform .3s ease}.product-card:hover .product-image{transform:scale(1.05)}.product-badge{position:absolute;top:8px;right:8px;background-color:#ff9800;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:700}.product-content{flex:1;padding:16px;display:flex;flex-direction:column}.product-category{display:inline-block;background-color:#f0f0f0;color:#666;padding:4px 8px;border-radius:4px;font-size:12px;margin-bottom:8px;font-weight:600;text-transform:capitalize;width:fit-content}.product-title{font-size:16px;font-weight:600;color:#333;margin:8px 0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:40px}.product-description{font-size:14px;color:#666;line-height:1.5;margin:8px 0;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.ai-description-container{background:linear-gradient(135deg,#f5f5f5,#efefef);border-left:4px solid #4caf50;padding:12px;border-radius:4px;margin:12px 0;flex:1;overflow-y:auto;max-height:400px}.ai-badge{display:inline-block;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;padding:4px 12px;border-radius:4px;font-size:12px;font-weight:700;margin-bottom:8px}.ai-section{margin-bottom:12px}.ai-section h4{font-size:13px;font-weight:700;color:#333;margin-bottom:6px}.ai-section p{font-size:13px;color:#555;line-height:1.4}.suggestions-list li{font-size:13px;color:#555;padding:4px 0;line-height:1.4}.product-footer{margin:12px 0 0;padding-top:12px;border-top:1px solid #e0e0e0}.product-price-rating{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.product-price{font-size:20px;font-weight:700;color:#2196f3}.product-rating{font-size:13px;color:#ff9800}.product-actions{display:grid;margin-top:12px}.btn{padding:10px 12px;border:none;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.btn-primary{background-color:#2196f3;color:#fff}.btn.btn-primary:hover:not(:disabled){background-color:#1976d2}.error-message{color:#f44336;font-size:12px;margin-top:8px;padding:8px;background-color:#ffebee;border-radius:4px;border-left:3px solid #f44336}@media (max-width: 768px){.product-card{margin-bottom:12px}.product-title{font-size:14px}.btn{font-size:12px;padding:8px 10px}.ai-description-container{max-height:300px}}@media (max-width: 480px){.product-actions{grid-template-columns:1fr}.btn{font-size:11px}.product-price-rating{flex-direction:column;align-items:flex-start}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:8px;max-width:1000px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 10px 40px #0003}.modal-close{position:sticky;background:#f5f5f5;border:none;font-size:24px;width:40px;height:40px;cursor:pointer;border-radius:4px;transition:background-color .2s;display:flex;align-items:center;justify-content:center;z-index:1001;position:absolute;top:16px;right:16px}.modal-close:hover{background-color:#e0e0e0}.detail-container{display:grid;grid-template-columns:1fr 1fr;gap:40px;padding:40px}.detail-image-section{position:relative;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5;border-radius:8px;min-height:400px}.detail-image{max-width:100%;max-height:100%;object-fit:contain;padding:20px}.detail-badge{position:absolute;top:16px;right:16px;background-color:#ff9800;color:#fff;padding:8px 12px;border-radius:4px;font-weight:700}.detail-content{display:flex;flex-direction:column}.detail-header{margin-bottom:24px}.detail-category{display:inline-block;background-color:#f0f0f0;color:#666;padding:6px 12px;border-radius:4px;font-size:13px;font-weight:600;text-transform:capitalize;margin-bottom:12px}.detail-title{font-size:28px;font-weight:700;color:#333;margin:0;line-height:1.4}.detail-price-rating{display:flex;align-items:center;gap:24px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #e0e0e0}.detail-price{font-size:32px;font-weight:700;color:#2196f3}.detail-rating{display:flex;align-items:center;gap:8px;font-size:18px;color:#ff9800;font-weight:600}.detail-rating-count{display:block;font-size:13px;color:#999;font-weight:400}.detail-description{margin-bottom:24px}.detail-description h3{font-size:18px;font-weight:600;color:#333;margin:0 0 12px}.detail-description p{font-size:15px;line-height:1.6;color:#666;margin:0}.ai-description{background:linear-gradient(135deg,#f5f5f5,#efefef);border-left:4px solid #4caf50;padding:20px;border-radius:8px;margin-bottom:24px}.ai-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.ai-badge{display:inline-block;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;padding:6px 14px;border-radius:4px;font-size:13px;font-weight:700}.btn-close-ai{background:none;border:none;font-size:20px;cursor:pointer;color:#999;transition:color .2s}.btn-close-ai:hover{color:#333}.ai-section{margin-bottom:16px}.ai-section:last-child{margin-bottom:0}.ai-section h4{font-size:15px;font-weight:700;color:#333;margin:0 0 8px}.ai-section p{font-size:14px;color:#555;line-height:1.6;margin:0}.suggestions-list{list-style:none;padding:0;margin:0}.suggestions-list li{font-size:14px;color:#555;padding:6px 0;line-height:1.5}.suggestions-list li:before{content:"→ ";color:#4caf50;font-weight:700;margin-right:6px}.error-message{color:#f44336;font-size:14px;margin-bottom:16px;padding:12px;background-color:#ffebee;border-radius:4px;border-left:4px solid #f44336}.detail-actions{display:flex;gap:12px;margin-top:auto;padding-top:24px;border-top:1px solid #e0e0e0}.detail-actions .btn{flex:1;padding:14px;font-size:15px;border:none;border-radius:4px;font-weight:600;cursor:pointer;transition:all .3s ease}.detail-actions .btn-primary{background-color:#2196f3;color:#fff}.detail-actions .btn-primary:hover:not(:disabled){background-color:#1976d2}.detail-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}.detail-actions .btn-primary.loading{background-color:#ff9800}.detail-actions .btn-secondary{background-color:#f5f5f5;color:#333;border:1px solid #e0e0e0}.detail-actions .btn-secondary:hover{background-color:#e8e8e8}@media (max-width: 768px){.detail-container{grid-template-columns:1fr;gap:24px;padding:20px}.detail-image-section{min-height:300px}.detail-title{font-size:22px}.detail-price{font-size:24px}.detail-actions{flex-direction:column}.detail-actions .btn{flex:none}.modal-content{margin:0;border-radius:8px}}@media (max-width: 480px){.modal-overlay{padding:0}.modal-content{max-width:100%;border-radius:0;max-height:100vh}.detail-container{gap:16px;padding:16px}.detail-title{font-size:18px}.detail-price-rating{flex-direction:column;align-items:flex-start;gap:12px}}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-bottom:40px}.product-list{display:flex;flex-direction:column;gap:16px;margin-bottom:40px}.product-list .product-card{flex-direction:row;height:auto}.product-list .product-image-container{width:150px;height:150px;flex-shrink:0}.product-list .product-content{flex:1;padding:16px}.empty-state{text-align:center;padding:60px 20px;color:#999}.empty-icon{font-size:48px;margin-bottom:16px}.empty-state h3{font-size:24px;color:#333;margin-bottom:8px}.empty-state p{font-size:16px;color:#999}@media (max-width: 1200px){.product-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}}@media (max-width: 768px){.product-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.product-list .product-card{flex-direction:column;height:auto}.product-list .product-image-container{width:100%;height:150px}}@media (max-width: 480px){.product-grid{grid-template-columns:1fr;gap:12px}.empty-state{padding:40px 16px}.empty-state h3{font-size:20px}.empty-state p{font-size:14px}}.search-bar{margin-bottom:24px}.search-input-container{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:16px;font-size:18px;color:#999;pointer-events:none}.search-input{width:100%;padding:12px 16px 12px 44px;border:1px solid #ddd;border-radius:4px;font-size:16px;transition:all .3s ease;background-color:#fff}.search-input:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.search-input:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.search-clear{position:absolute;right:12px;background:none;border:none;font-size:18px;cursor:pointer;color:#999;transition:color .2s;padding:4px 8px;display:flex;align-items:center;justify-content:center}.search-clear:hover:not(:disabled){color:#333}.search-clear:disabled{cursor:not-allowed;opacity:.5}@media (max-width: 480px){.search-input{font-size:14px;padding:10px 14px 10px 40px}.search-icon{left:12px;font-size:16px}.search-clear{right:8px}}.category-filter{margin-bottom:24px;padding:20px;background-color:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0}.filter-title{font-size:18px;font-weight:600;color:#333;margin:0 0 16px}.category-buttons{display:flex;flex-wrap:wrap;gap:12px}.category-button{padding:10px 16px;background-color:#fff;border:1px solid #ddd;border-radius:4px;font-size:14px;font-weight:500;color:#333;cursor:pointer;transition:all .3s ease;white-space:nowrap;text-transform:capitalize}.category-button:hover:not(:disabled){border-color:#2196f3;background-color:#f5f5f5}.category-button.active{background-color:#2196f3;color:#fff;border-color:#2196f3;box-shadow:0 2px 8px #2196f34d}.category-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.category-filter{padding:16px;margin-bottom:20px}.category-buttons{gap:10px}.category-button{padding:8px 14px;font-size:13px}}@media (max-width: 480px){.category-filter{padding:12px;margin-bottom:16px}.filter-title{font-size:16px;margin-bottom:12px}.category-buttons{gap:8px;display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.category-button{padding:8px 12px;font-size:12px}}.sort-bar{margin-bottom:20px;padding:16px;background-color:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0}.sort-controls{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}.sort-group{display:flex;align-items:center;gap:12px}.sort-group label{font-weight:600;color:#333;font-size:14px}.sort-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:#fff;cursor:pointer;transition:all .3s ease}.sort-select:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.sort-select:hover:not(:disabled){border-color:#2196f3}.sort-select:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.view-mode-group{display:flex;align-items:center;gap:8px}.view-label{font-weight:600;color:#333;font-size:14px;margin-right:8px}.view-buttons{display:flex;gap:4px;background-color:#fff;border:1px solid #ddd;border-radius:4px;padding:2px}.view-button{padding:8px 12px;background:none;border:none;font-size:16px;cursor:pointer;color:#999;transition:all .2s ease;border-radius:2px}.view-button:hover:not(:disabled){color:#333;background-color:#f5f5f5}.view-button.active{background-color:#2196f3;color:#fff}.view-button:disabled{cursor:not-allowed;opacity:.6}@media (max-width: 768px){.sort-controls{gap:12px}.sort-group{gap:8px;flex:1;min-width:200px}.sort-select{flex:1}}@media (max-width: 480px){.sort-bar{padding:12px;margin-bottom:16px}.sort-controls{flex-direction:column;gap:12px}.sort-group,.sort-select{width:100%}.view-mode-group{width:100%;justify-content:space-between}}@keyframes skeleton-loading{0%{background-color:#e0e0e0}50%{background-color:#f0f0f0}to{background-color:#e0e0e0}}.skeleton{animation:skeleton-loading 1.5s infinite;background-color:#e0e0e0;border-radius:4px}.product-card-skeleton{border:1px solid #e0e0e0;border-radius:8px;padding:16px;display:flex;flex-direction:column}.skeleton-image{width:100%;height:200px;border-radius:4px;margin-bottom:12px}.skeleton-content{flex:1;display:flex;flex-direction:column}.skeleton-title{height:16px;margin-bottom:8px;width:100%}.skeleton-text{height:12px;margin-bottom:8px;width:90%}.skeleton-price{height:20px;width:60px;margin-bottom:12px}.skeleton-button{height:38px;border-radius:4px;width:100%}.products-page{min-height:100vh;background-color:#fff}.page-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:60px 20px;text-align:center;margin-bottom:40px}.page-title{font-size:48px;font-weight:700;margin:0 0 12px}.page-subtitle{font-size:20px;opacity:.9;margin:0}.page-container{max-width:1400px;margin:0 auto;padding:0 20px}.results-info{font-size:14px;color:#666;margin-bottom:20px;padding:12px 16px;background-color:#f0f0f0;border-radius:4px;border-left:4px solid #2196f3}.error-container{text-align:center;padding:60px 20px;background-color:#ffebee;border-radius:8px;margin-bottom:40px}.error-icon{font-size:54px;margin-bottom:16px}.error-container h2{font-size:24px;color:#c62828;margin:0 0 12px}.error-container p{font-size:16px;color:#b71c1c;margin:0 0 20px}.btn-retry{padding:12px 24px;background-color:#f44336;color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-retry:hover{background-color:#d32f2f;transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}@media (max-width: 1200px){.page-container{padding:0 16px}}@media (max-width: 768px){.page-header{padding:40px 16px;margin-bottom:24px}.page-title{font-size:36px}.page-subtitle{font-size:16px}.page-container{padding:0 16px}}@media (max-width: 480px){.page-header{padding:32px 12px;margin-bottom:20px}.page-title{font-size:28px}.page-subtitle{font-size:14px}.page-container{padding:0 12px}.results-info{font-size:12px;padding:10px 12px}.error-container{padding:40px 16px}.error-container h2{font-size:20px}.error-container p{font-size:14px}.btn-retry{padding:10px 20px;font-size:14px}}
