:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}body{min-height:100vh;margin:0}#root{min-height:100vh}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#667eea;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#5568d3}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app{background:#f5f7fa;min-height:100vh}.main-content{max-width:1400px;margin:0 auto;padding:2rem}.products-header{text-align:center;margin-bottom:2rem}.products-header h2{color:#2d3748;font-size:1.5rem;font-weight:600}.loading{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:400px;display:flex}.spinner{border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;width:50px;height:50px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading p{color:#4a5568;font-size:1.1rem}.error{text-align:center;background:#fff;border-radius:12px;margin:2rem;padding:3rem;box-shadow:0 4px 6px #0000001a}.error p{color:#e53e3e;font-size:1.1rem}.pagination{justify-content:center;align-items:center;gap:2rem;margin-top:3rem;padding:2rem 0;display:flex}.pagination-btn{color:#667eea;cursor:pointer;background:#fff;border:2px solid #667eea;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .3s}.pagination-btn:hover:not(:disabled){color:#fff;background:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.pagination-btn:disabled{opacity:.4;cursor:not-allowed;color:#cbd5e0;border-color:#cbd5e0}.pagination-info{align-items:center;gap:1rem;display:flex}.page-number{color:#2d3748;background:#fff;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;box-shadow:0 2px 4px #0000001a}@media (width<=768px){.main-content{padding:1rem}.pagination{gap:1rem}.pagination-btn,.page-number{padding:.5rem 1rem;font-size:.9rem}}.product-card{background:#fff;border-radius:12px;flex-direction:column;transition:all .3s;display:flex;overflow:hidden;box-shadow:0 2px 8px #0000001a}.product-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.product-card.list{flex-direction:row}.product-card.list .product-image-container{flex-shrink:0;width:250px}.product-card.list .product-info{flex:1}.product-image-container{background:#f7fafc;width:100%;padding-top:100%;position:relative;overflow:hidden}.product-image{object-fit:cover;width:100%;height:100%;transition:transform .3s;position:absolute;top:0;left:0}.product-card:hover .product-image{transform:scale(1.05)}.discount-badge{color:#fff;z-index:1;background:#e53e3e;border-radius:6px;padding:.4rem .8rem;font-size:.9rem;font-weight:700;position:absolute;top:12px;right:12px;box-shadow:0 2px 8px #e53e3e4d}.product-info{flex-direction:column;flex:1;gap:.75rem;padding:1.5rem;display:flex}.product-category{text-transform:uppercase;color:#667eea;letter-spacing:.5px;font-size:.75rem;font-weight:700}.product-title{color:#2d3748;margin:0;font-size:1.25rem;font-weight:700;line-height:1.3}.product-description{color:#718096;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.9rem;line-height:1.5;display:-webkit-box;overflow:hidden}.product-rating{align-items:center;gap:.5rem;display:flex}.stars{gap:2px;display:flex}.star{color:#e2e8f0;font-size:1rem}.star.filled{color:#fbbf24}.star.half{background:linear-gradient(90deg,#fbbf24 50%,#e2e8f0 50%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.rating-value{color:#4a5568;font-size:.9rem;font-weight:600}.product-brand{gap:.5rem;font-size:.9rem;display:flex}.brand-label{color:#718096}.brand-name{color:#2d3748;font-weight:600}.product-stock{font-size:.85rem}.in-stock{color:#38a169;font-weight:600}.out-of-stock{color:#e53e3e;font-weight:600}.product-footer{border-top:1px solid #e2e8f0;margin-top:auto;padding-top:1rem}.product-pricing{margin-bottom:1rem}.price-row{align-items:center;gap:.75rem;margin-bottom:.25rem;display:flex}.current-price{color:#2d3748;font-size:1.75rem;font-weight:700}.original-price{color:#a0aec0;font-size:1.1rem;text-decoration:line-through}.savings{color:#38a169;font-size:.85rem;font-weight:600}.add-to-cart-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;width:100%;padding:.875rem;font-size:1rem;font-weight:600;transition:all .3s}.add-to-cart-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.add-to-cart-btn:disabled{cursor:not-allowed;background:#cbd5e0}.add-to-cart-btn.adding{background:#38a169}@media (width<=768px){.product-card.list{flex-direction:column}.product-card.list .product-image-container{width:100%}}.product-list{gap:2rem;margin-bottom:2rem;display:grid}.product-list.grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.product-list.list{grid-template-columns:1fr;max-width:900px;margin:0 auto 2rem}@media (width<=768px){.product-list.grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.product-list.list{gap:1.5rem}}@media (width<=480px){.product-list.grid{grid-template-columns:1fr}}.cart-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:flex-end;animation:.3s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.cart-panel{background:#fff;flex-direction:column;width:100%;max-width:500px;animation:.3s slideIn;display:flex;box-shadow:-4px 0 24px #0003}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.cart-header{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.cart-header h2{margin:0;font-size:1.5rem}.close-btn{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.5rem;transition:all .3s;display:flex}.close-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.cart-items{flex:1;padding:1.5rem;overflow-y:auto}.cart-item{background:#f7fafc;border-radius:12px;gap:1rem;margin-bottom:1rem;padding:1rem;transition:all .3s;display:flex}.cart-item:hover{background:#edf2f7;transform:translate(4px)}.cart-item-image{object-fit:cover;background:#fff;border-radius:8px;width:80px;height:80px}.cart-item-details{flex:1;min-width:0}.cart-item-details h4{color:#2d3748;white-space:nowrap;text-overflow:ellipsis;margin:0 0 .25rem;font-size:1rem;overflow:hidden}.cart-item-brand{color:#718096;margin-bottom:.5rem;font-size:.85rem}.cart-item-price{align-items:center;gap:.5rem;display:flex}.cart-item-price .price{color:#2d3748;font-size:1.1rem;font-weight:700}.cart-item-price .original{color:#a0aec0;font-size:.9rem;text-decoration:line-through}.cart-item-actions{flex-direction:column;align-items:flex-end;gap:.5rem;display:flex}.quantity-controls{background:#fff;border-radius:8px;align-items:center;gap:.5rem;padding:.25rem;display:flex}.qty-btn{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:6px;width:28px;height:28px;font-size:1rem;font-weight:700;transition:all .3s}.qty-btn:hover:not(:disabled){background:#5568d3;transform:scale(1.1)}.qty-btn:disabled{cursor:not-allowed;background:#cbd5e0}.quantity{text-align:center;color:#2d3748;min-width:30px;font-weight:600}.item-total{color:#2d3748;font-size:1.1rem;font-weight:700}.remove-btn{cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.2rem;transition:all .3s}.remove-btn:hover{transform:scale(1.2)}.cart-footer{background:#f7fafc;border-top:2px solid #e2e8f0;padding:1.5rem}.cart-summary{margin-bottom:1.5rem}.summary-row.total{color:#2d3748;border-top:2px solid #cbd5e0;margin-top:.75rem;padding-top:.75rem;font-size:1.5rem;font-weight:700}.free{color:#38a169;font-weight:600}.checkout-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;width:100%;padding:1rem;font-size:1.1rem;font-weight:700;transition:all .3s}.checkout-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.empty-cart{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.empty-cart-icon{opacity:.5;margin-bottom:1rem;font-size:5rem}.empty-cart p{color:#718096;margin-bottom:2rem;font-size:1.2rem}.continue-shopping{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;padding:.875rem 2rem;font-size:1rem;font-weight:600;transition:all .3s}.continue-shopping:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media (width<=768px){.cart-panel{max-width:100%}.cart-item{flex-direction:column}.cart-item-actions{flex-direction:row;justify-content:space-between;width:100%}}.checkout-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;padding:2rem}.checkout-container{max-width:1200px;margin:0 auto}.back-btn{color:#fff;cursor:pointer;background:#fff3;border:2px solid #fff;border-radius:8px;margin-bottom:2rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .3s}.back-btn:hover{color:#667eea;background:#fff;transform:translate(-4px)}.checkout-title{color:#fff;text-align:center;margin-bottom:2rem;font-size:2.5rem}.checkout-content{grid-template-columns:1fr 400px;align-items:start;gap:2rem;display:grid}.checkout-form{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 8px 24px #0003}.form-section{margin-bottom:2rem}.form-section h2{color:#2d3748;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem;padding-bottom:.75rem;font-size:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{color:#4a5568;margin-bottom:.5rem;font-size:.95rem;font-weight:600;display:block}.form-group input{border:2px solid #e2e8f0;border-radius:8px;width:100%;padding:.875rem;font-size:1rem;transition:all .3s}.form-group input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-group input.error{border-color:#e53e3e}.error-message{color:#e53e3e;margin-top:.25rem;font-size:.85rem;display:block}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.place-order-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:1.25rem;font-size:1.2rem;font-weight:700;transition:all .3s;display:flex}.place-order-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.place-order-btn:disabled{opacity:.7;cursor:not-allowed}.spinner-small{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:1s linear infinite spin}.order-summary{background:#fff;border-radius:12px;padding:2rem;position:sticky;top:2rem;box-shadow:0 8px 24px #0003}.order-summary h2{color:#2d3748;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem;padding-bottom:.75rem;font-size:1.5rem}.summary-items{max-height:300px;margin-bottom:1.5rem;overflow-y:auto}.summary-item{background:#f7fafc;border-radius:8px;gap:1rem;margin-bottom:1rem;padding:1rem;display:flex}.summary-item img{object-fit:cover;border-radius:6px;width:60px;height:60px}.summary-item-info{flex:1;min-width:0}.summary-item-info h4{color:#2d3748;white-space:nowrap;text-overflow:ellipsis;margin:0 0 .25rem;font-size:.95rem;overflow:hidden}.summary-item-info p{color:#718096;margin:0;font-size:.85rem}.summary-item-price{color:#2d3748;font-weight:700}.summary-totals{border-top:2px solid #e2e8f0;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem;padding:1.5rem 0}.summary-row{color:#4a5568;justify-content:space-between;margin-bottom:.75rem;font-size:1rem;display:flex}.summary-row.total{color:#2d3748;margin-top:1rem;margin-bottom:0;font-size:1.5rem;font-weight:700}.secure-checkout{color:#38a169;justify-content:center;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;display:flex}@media (width<=1024px){.checkout-content{grid-template-columns:1fr}.order-summary{position:static}}@media (width<=768px){.checkout-page{padding:1rem}.checkout-title{font-size:2rem}.checkout-form,.order-summary{padding:1.5rem}.form-row{grid-template-columns:1fr}}.header{color:#fff;z-index:100;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:1.5rem 0;position:sticky;top:0;box-shadow:0 4px 6px #0000001a}.header-content{justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;padding:0 2rem;display:flex}.logo{align-items:center;gap:1rem;display:flex}.logo-icon{font-size:2.5rem}.logo h1{margin:0;font-size:1.8rem;font-weight:700}.tagline{opacity:.9;margin:0;font-size:.9rem}.header-actions{align-items:center;gap:1.5rem;display:flex}.view-toggle{background:#fff3;border-radius:8px;gap:.5rem;padding:.25rem;display:flex}.view-btn{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:.5rem;transition:all .3s;display:flex}.view-btn:hover{background:#fff3}.view-btn.active{color:#667eea;background:#fff}.cart-button{color:#667eea;cursor:pointer;background:#fff;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1rem;font-weight:600;transition:all .3s;display:flex;position:relative}.cart-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.cart-badge{color:#fff;background:#e53e3e;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:700;display:flex;position:absolute;top:-8px;right:-8px}@media (width<=768px){.header-content{padding:0 1rem}.logo h1{font-size:1.3rem}.logo-icon{font-size:2rem}.tagline,.view-toggle{display:none}}
