*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}#root{height:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-center{display:flex;justify-content:center;align-items:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-column{display:flex;flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.w-full{width:100%}.h-full{height:100%}.mb-0{margin-bottom:0!important}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.mt-0{margin-top:0!important}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.p-0{padding:0!important}.p-1{padding:8px}.p-2{padding:16px}.p-3{padding:24px}.p-4{padding:32px}.grid{display:grid;gap:16px}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.grid-cols-5{grid-template-columns:repeat(5,1fr)}.grid-cols-6{grid-template-columns:repeat(6,1fr)}@media (max-width: 576px){.grid-cols-sm-1{grid-template-columns:repeat(1,1fr)}.grid-cols-sm-2{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-cols-md-1{grid-template-columns:repeat(1,1fr)}.grid-cols-md-2{grid-template-columns:repeat(2,1fr)}.grid-cols-md-3{grid-template-columns:repeat(3,1fr)}}@media (max-width: 992px){.grid-cols-lg-1{grid-template-columns:repeat(1,1fr)}.grid-cols-lg-2{grid-template-columns:repeat(2,1fr)}.grid-cols-lg-3{grid-template-columns:repeat(3,1fr)}.grid-cols-lg-4{grid-template-columns:repeat(4,1fr)}}.card-hover{transition:all .3s ease;cursor:pointer}.card-hover:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.price{color:#ff4d4f;font-weight:600;font-size:16px}.price-large{font-size:20px}.price-small{font-size:14px}.original-price{color:#999;text-decoration:line-through;font-size:12px;margin-left:8px}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;line-height:1.5}.badge-success{background-color:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}.badge-warning{background-color:#fffbe6;color:#faad14;border:1px solid #ffe58f}.badge-error{background-color:#fff2f0;color:#ff4d4f;border:1px solid #ffccc7}.badge-info{background-color:#e6f7ff;color:#1890ff;border:1px solid #91d5ff}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffc;display:flex;justify-content:center;align-items:center;z-index:10}.empty-state{text-align:center;padding:40px 20px;color:#999}.empty-state .empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state .empty-text{font-size:14px;margin-bottom:16px}.ant-layout{min-height:100%}.ant-layout-header{padding:0 24px;box-shadow:0 2px 8px #0000000f;position:sticky;top:0;z-index:100}.ant-layout-content{padding:24px;min-height:calc(100vh - 64px)}.ant-layout-footer{text-align:center;background:#f5f5f5;border-top:1px solid #e8e8e8}.product-card{border-radius:8px;overflow:hidden;transition:all .3s ease;border:1px solid #f0f0f0}.product-card:hover{border-color:#1890ff;box-shadow:0 4px 12px #1890ff26}.product-image{width:100%;height:200px;object-fit:cover;background:#f5f5f5}.product-info{padding:16px}.product-title{font-size:14px;font-weight:500;color:#333;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;height:2.8em}.product-price{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}@media (max-width: 768px){.ant-layout-content{padding:16px}.ant-layout-header{padding:0 16px}.product-image{height:160px}.product-info{padding:12px}}
