*{box-sizing:border-box}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;background:#f5f5f5;color:#000}body *{color:inherit}body.modal-open,body.cart-open{overflow:hidden}.cart-page,.checkout-page,.create-address{min-height:100vh;background:#fff;display:flex;flex-direction:column}.cart-page .cart-header h2,.checkout-header h2,.create-address .header h2{margin:0;font-size:20px;font-weight:600;color:#000}.cart-page .back-btn,.checkout-page .back-btn{padding:8px 12px;border:none;background:transparent;color:#3390ec;font-size:14px;cursor:pointer}.cart-page .cart-header,.checkout-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid #eee;position:sticky;top:0;background:#fff;z-index:10}.create-address .error-message,.address-select .error-message{padding:12px;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:13px}.cart-page .checkout-btn,.cart-page .btn-primary,.create-address .submit-btn,.step-btn.primary{border:none;border-radius:8px;background:#3390ec;color:#fff;font-weight:600;cursor:pointer;transition:opacity .2s}.cart-page .checkout-btn:hover,.create-address .submit-btn:hover:not(:disabled){opacity:.9}.create-address .submit-btn:disabled{opacity:.5;cursor:not-allowed}.cart-page .summary-row,.checkout-page .summary-row{display:flex;justify-content:space-between;font-size:16px;color:#000}.create-address .form-input,.create-address .form-textarea,.address-select-input,.points-input{padding:12px;border:1px solid #999;border-radius:8px;font-size:14px;background:#fff;color:#000;font-family:inherit}.create-address .form-input:focus,.create-address .form-textarea:focus,.address-select-input:focus{outline:none;border-color:#3390ec}.catalog-page{min-height:100vh;background:#f5f5f5}.loading-state,.error-state,.empty-state{text-align:center;padding:60px 20px;font-size:16px;color:#999}.loader{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #007aff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-state{color:#d14e4e}.products-container{padding-bottom:100px}.products-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:12px}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state-hint{font-size:14px;color:#999;margin-top:8px}.cart-button{position:fixed;bottom:20px;right:20px;width:60px;height:60px;background:#007aff;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 12px #007aff66;cursor:pointer;z-index:900;border:none;transition:transform .2s;text-decoration:none}.cart-button:active{transform:scale(.95)}.cart-badge{position:absolute;top:-5px;right:-5px;background:#ff3b30;color:#fff;border-radius:10px;padding:2px 6px;font-size:12px;font-weight:700;min-width:20px;text-align:center}.cart-backdrop{position:fixed;inset:0;background:#00000080;z-index:998;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.cart-sidebar{position:fixed;top:0;right:-100%;width:85%;max-width:400px;height:100vh;background:#fff;color:#000;z-index:999;display:flex;flex-direction:column;transition:right .3s ease;box-shadow:-2px 0 8px #0000001a}.cart-sidebar.active{right:0}.cart-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e7e7e7}.cart-header h2{margin:0;font-size:20px;font-weight:600}.cart-header button{background:none;border:none;font-size:24px;cursor:pointer;color:#999;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.cart-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:0;min-height:0;-webkit-overflow-scrolling:touch}.cart-empty{text-align:center;padding:40px 20px;color:#999}.cart-empty-icon{font-size:48px;margin-bottom:12px}.cart-footer{padding:16px;border-top:2px solid #e7e7e7;background:#f9f9f9}.cart-summary{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e7e7e7}.cart-summary.no-border{border-bottom:none;margin-bottom:0;padding-bottom:0}.cart-subtotal{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:#666;margin-bottom:4px}.cart-discount{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:#34c759;font-weight:500}.discount-amount{color:#34c759;font-weight:600}.cart-total{display:flex;justify-content:space-between;align-items:center;font-size:18px;font-weight:600;margin-top:4px;margin-bottom:12px}.checkout-btn{width:100%;background:#34c759;color:#fff;border:none;padding:14px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer}.checkout-btn:active{opacity:.8}.loyalty-points-section{margin-top:12px;padding-top:12px;border-top:1px solid #e7e7e7}.loyalty-points-info{font-size:14px;color:#666;margin-bottom:8px}.loyalty-points-input{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px}.loyalty-points-input label{color:#666}.points-input{width:80px;padding:6px 8px;border:1px solid #e7e7e7;border-radius:6px;font-size:14px;text-align:right}.loyalty-points-discount{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:#34c759;font-weight:500}.points-amount{color:#34c759;font-weight:600}.loyalty-points-balance{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:#666;margin-top:4px;margin-bottom:4px}.points-balance-value{font-weight:600;color:#007aff;font-size:16px}.cart-item{display:flex;gap:12px;padding:12px;border-bottom:1px solid #e7e7e7}.cart-item-image{width:60px;height:60px;object-fit:cover;border-radius:8px;flex-shrink:0}.cart-item-info{flex:1;display:flex;flex-direction:column;gap:4px}.cart-item-name{font-size:14px;font-weight:500;color:#000}.cart-item-price{font-size:14px;color:#007aff;font-weight:600;display:flex;align-items:center;gap:8px}.price-original{text-decoration:line-through;color:#999;font-size:12px;font-weight:400}.price-discounted{color:#34c759;font-weight:600}.quantity-controls{display:flex;align-items:center;gap:8px;margin-top:4px}.quantity-value{min-width:20px;text-align:center;color:#000}.qty-btn{width:28px;height:28px;border:1px solid #e7e7e7;background:#fff;color:#000;border-radius:6px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.qty-btn:active{background:#f0f0f0}.qty-btn.remove{margin-left:auto;border-color:#ff3b30;color:#ff3b30}.card-text-input{margin-top:12px;padding-top:12px;border-top:1px solid #e7e7e7}.card-text-checkbox{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#000;cursor:pointer;margin-bottom:12px}.card-text-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#007aff}.card-text-field{margin-top:8px}.card-text-label{display:block;font-size:13px;font-weight:500;color:#666;margin-bottom:8px}.card-textarea{width:100%;padding:10px;border:1px solid #e7e7e7;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;min-height:60px;color:#000;background:#fff}.card-textarea:focus{outline:none;border-color:#007aff}.add-free-card-section{padding:12px;border-top:1px solid #e7e7e7;border-bottom:1px solid #e7e7e7;margin:12px 0}.add-free-card-btn{width:100%;padding:12px;background:#f0f0f0;border:1px dashed #999;border-radius:8px;font-size:14px;color:#007aff;cursor:pointer;transition:all .2s;font-weight:500}.add-free-card-btn:active{background:#e0e0e0;border-color:#007aff}.filter-sort-bar{background:#fff;padding:16px 12px;border-bottom:1px solid #e7e7e7;position:sticky;top:0;z-index:99}.filter-section,.sort-section{margin-bottom:16px}.filter-section:last-child,.sort-section:last-child{margin-bottom:0}.filter-title{font-size:14px;font-weight:600;color:#000;margin-bottom:8px}.price-filter{display:flex;align-items:center;gap:6px}.price-input{flex:1;min-width:0;padding:8px;border:1px solid #e7e7e7;border-radius:8px;font-size:14px;background:#f9f9f9;transition:border-color .2s;width:calc(50% - 10px)}.price-input:focus{outline:none;border-color:#007aff;background:#fff}.price-separator{color:#999;font-size:14px}.sort-select,.tag-select{width:100%;padding:8px 12px;border:1px solid #e7e7e7;border-radius:8px;font-size:14px;background:#f9f9f9;color:#000;cursor:pointer;transition:border-color .2s}.sort-select:focus,.tag-select:focus{outline:none;border-color:#007aff;background:#fff}.product-card{border-radius:12px;overflow:hidden;background:#fff;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:transform .2s;display:flex;flex-direction:column}.product-card:active{transform:scale(.98)}.product-card-content{flex:1;cursor:pointer}.product-image{width:100%;aspect-ratio:1;object-fit:cover;background:#f0f0f0;display:block}.product-info{padding:8px}.product-name{font-size:14px;font-weight:500;color:#000;margin-bottom:4px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-price{font-size:16px;font-weight:600;color:#007aff}.add-to-cart-btn{margin:8px;padding:8px;background:#007aff;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.add-to-cart-btn:active{background:#0051d5}.modal{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s}.modal-content{background:#fff;color:#000;border-radius:16px;padding:20px;max-width:400px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .3s}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.close{position:absolute;top:16px;right:16px;font-size:28px;font-weight:300;color:#999;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.close:hover{background:#f0f0f0}.modal-image{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px;margin-bottom:16px;background:#f0f0f0}.modal-title{font-size:20px;font-weight:600;margin:0 0 8px;color:#000}.modal-price{font-size:24px;font-weight:600;color:#007aff;margin-bottom:16px}.modal-description{font-size:14px;color:#666;line-height:1.5;margin:0 0 12px}.modal-vendor{font-size:14px;color:#999;margin-bottom:20px}.modal-add-btn{width:100%;background:#007aff;color:#fff;border:none;padding:14px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.modal-add-btn:active{background:#0051d5}.cart-page .cart-body{flex:1;padding:16px;display:flex;flex-direction:column;gap:16px}.cart-page .cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.cart-page .cart-empty-icon{font-size:64px;margin-bottom:16px}.cart-page .cart-empty p{font-size:18px;color:#999;margin-bottom:24px}.cart-page .cart-summary{padding:16px;background:#f8f9fa;border-radius:8px;display:flex;flex-direction:column;gap:8px}.cart-page .summary-row:last-child{font-weight:600;font-size:18px;padding-top:8px;border-top:1px solid #eee}.cart-page .checkout-btn{width:100%;padding:16px;font-size:16px;margin-top:auto}.cart-page .btn-primary{padding:12px 24px;font-size:14px}.create-address{padding:16px}.create-address .header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.create-address .close-btn{width:32px;height:32px;border:none;background:transparent;color:#999;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.create-address .close-btn:hover{color:#000}.create-address .form{display:flex;flex-direction:column;gap:16px}.create-address .form-group{display:flex;flex-direction:column;gap:8px}.create-address .form-group label{font-size:14px;font-weight:500;color:#000}.create-address .form-textarea{resize:vertical;min-height:80px}.create-address .geocoding-info{padding:8px;font-size:12px;color:#999;text-align:center}.create-address .submit-btn{padding:14px;font-size:16px;font-weight:500;margin-top:8px;width:100%}.address-select{display:flex;flex-direction:column;gap:12px}.address-select-input{width:100%;cursor:pointer}.address-select-input:disabled{opacity:.5;cursor:not-allowed}.address-select .loading,.address-select .calculating{padding:12px;text-align:center;color:#999;font-size:14px}.address-select .error-message{padding:12px;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:13px}.address-select .success-message{padding:12px;background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;margin-top:12px}.address-select .price-info{display:flex;justify-content:space-between;align-items:center;font-size:14px}.address-select .label{color:#155724;font-weight:500}.address-select .price{font-weight:600;font-size:16px;color:#155724}.address-select .free-delivery{margin-top:8px;font-size:13px;color:#2a2;font-weight:500}.steps-indicator{display:flex;align-items:center;justify-content:center;padding:20px 16px;gap:8px}.step-item{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}.step-number{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#eee;color:#666;font-weight:600;font-size:14px}.step-item.active .step-number{background:#3390ec;color:#fff}.step-item.completed .step-number{background:#34c759;color:#fff}.step-label{font-size:12px;color:#999}.step-item.active .step-label{color:#000;font-weight:500}.step-divider{flex:1;height:2px;background:#eee;margin:0 8px}.step-item.active~.step-divider,.step-item.completed~.step-divider{background:#3390ec}.checkout-body{flex:1;padding:16px;display:flex;flex-direction:column}.step-content{display:flex;flex-direction:column;gap:20px}.step-content h3{margin:0;font-size:18px;font-weight:600;color:#000}.items-list{display:flex;flex-direction:column;gap:12px}.step-summary,.final-summary{padding:16px;background:#e9ecef;border:1px solid #dee2e6;border-radius:8px;display:flex;flex-direction:column;gap:8px}.checkout-page .summary-row{display:flex;justify-content:space-between;font-size:16px;color:#000}.checkout-page .summary-row.total{font-weight:600;font-size:20px;padding-top:8px;border-top:2px solid #eee}.checkout-page .summary-row.discount{color:#34c759}.discount-value{color:#34c759;font-weight:600}.loyalty-section{padding:16px;background:#e9ecef;border:1px solid #dee2e6;border-radius:8px}.loyalty-info{display:flex;flex-direction:column;gap:12px}.info-row{display:flex;justify-content:space-between;font-size:14px;color:#000}.loyalty-warning{padding:12px;background:#fff3cd;border-radius:4px;font-size:12px;color:#856404}.loyalty-input-group{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:12px}.loyalty-input-group label{font-size:14px;color:#000;flex:1}.points-input{width:80px;padding:6px 8px;border:1px solid #e7e7e7;border-radius:6px;text-align:right}.points-input:focus{outline:none;border-color:#007aff}.step-actions{display:flex;gap:12px;margin-top:auto;padding-top:20px}.step-btn{flex:1;padding:16px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s;background:#3390ec;color:#fff}.step-btn.primary{background:#3390ec;color:#fff}.step-btn.secondary{background:#e9ecef;color:#000;border:1px solid #dee2e6}.step-btn.secondary:hover:not(:disabled){background:#dee2e6}.step-btn:disabled{opacity:.5;cursor:not-allowed}.step-btn.primary:hover:not(:disabled){opacity:.9}.delivery-type-select{display:flex;gap:12px;padding:12px;background:#f8f9fa;border-radius:8px}.delivery-type-option{display:flex;align-items:center;gap:8px;cursor:pointer;flex:1;padding:12px;border:2px solid #e9ecef;border-radius:8px;background:#fff;transition:all .2s}.delivery-type-option:hover{border-color:#3390ec;background:#f0f7ff}.delivery-type-option input[type=radio]{margin:0;cursor:pointer;width:20px;height:20px;accent-color:#3390ec}.delivery-type-option input[type=radio]:checked+span{font-weight:600;color:#3390ec}.delivery-type-option:has(input[type=radio]:checked){border-color:#3390ec;background:#f0f7ff}.delivery-type-option span{font-size:16px;color:#000;-webkit-user-select:none;user-select:none}
