:root{--cart-overlay:rgba(0,0,0,.55);--cart-bg:#fff;--cart-radius:16px}
.cart-badge{position:absolute;top:2px;right:8px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--primary-color,#ff0000);color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;line-height:1;font-weight:700;z-index:3}
.cart-modal-overlay{position:fixed;inset:0;background:var(--cart-overlay);display:none;z-index:2000}
.cart-modal-overlay.active{display:block}
.cart-modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:min(520px,92vw);max-height:85vh;background:var(--cart-bg);border-radius:var(--cart-radius);box-shadow:0 12px 40px rgba(0,0,0,.25);display:none;z-index:2001;overflow:hidden}
.cart-modal.active{display:flex;flex-direction:column}
.cart-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #eee}
.cart-modal-title{font-weight:800;font-size:1.05rem;color:#111}
.cart-close-btn{background:transparent;border:none;cursor:pointer;font-size:22px;line-height:1;color:#444}
.cart-modal-body{padding:12px 16px;overflow:auto}
.cart-empty{text-align:center;color:#666;padding:24px 10px}
.cart-item{display:grid;grid-template-columns:64px 1fr auto;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid #f0f0f0}
.cart-item:last-child{border-bottom:none}
.cart-item-img{width:64px;height:64px;border-radius:12px;object-fit:cover;background:#f6f6f6}
.cart-item-name{font-weight:800;color:#111;margin:0 0 4px 0;font-size:.95rem}
.cart-item-meta{color:#666;font-size:.85rem}
.cart-qty{display:flex;align-items:center;gap:6px}
.cart-qty button{width:30px;height:30px;border-radius:10px;border:1px solid #ddd;background:#fff;cursor:pointer;font-weight:800}
.cart-qty span{min-width:22px;text-align:center;font-weight:800}
.cart-item-actions{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.cart-item-price{font-weight:900;color:var(--primary-color,#ff0000)}
.cart-remove{background:transparent;border:1px solid #eee;color:#666;border-radius:10px;padding:6px 10px;cursor:pointer;font-weight:700}
.cart-modal-footer{border-top:1px solid #eee;padding:12px 16px;display:flex;flex-direction:column;gap:10px}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;font-weight:900;color:#111}
.cart-coupon-row{display:flex;gap:10px;align-items:center;padding:10px;border-radius:14px;background:linear-gradient(180deg,#ffffff 0%,#fafafa 100%);border:1px solid #eee}
.cart-coupon-row input{flex:1;border:1px solid #e5e7eb;border-radius:12px;padding:10px 12px;font-size:.95rem;font-family:inherit;background:#fff;font-weight:800}
.cart-coupon-row input::placeholder{color:#9ca3af;font-weight:800}
.cart-coupon-row input:focus{outline:none;border-color:rgba(255,0,0,0.55);box-shadow:0 0 0 4px rgba(255,0,0,0.10)}
.cart-coupon-apply{border:none;border-radius:12px;background:linear-gradient(45deg,var(--primary-color,#ff0000),#ff4d4d);color:#fff;padding:10px 14px;cursor:pointer;font-weight:900;white-space:nowrap;box-shadow:0 10px 20px rgba(255,0,0,0.15)}
.cart-coupon-clear{border:1px solid #e5e7eb;border-radius:12px;background:#fff;color:#111827;padding:10px 14px;cursor:pointer;font-weight:900;white-space:nowrap}
.cart-coupon-apply:active,.cart-coupon-clear:active{transform:scale(0.99)}
.cart-coupon-msg{display:none;margin-top:8px;color:#b91c1c;font-weight:900;font-size:13px}

.toast-container{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);z-index:4000;display:flex;flex-direction:column;gap:10px;max-width:min(420px,92vw);pointer-events:none}
.toast{pointer-events:auto;padding:12px 14px;border-radius:14px;color:#fff;font-weight:900;text-align:center;box-shadow:0 12px 30px rgba(0,0,0,.25);opacity:0;transform:translateY(10px);transition:opacity .22s ease,transform .22s ease}
.toast.show{opacity:1;transform:translateY(0)}
.toast.hide{opacity:0;transform:translateY(10px)}
.toast.toast-error{background:linear-gradient(135deg,#b91c1c,#ef4444)}
.toast.toast-success{background:linear-gradient(135deg,#16a34a,#22c55e)}
@media (max-width: 420px){
 .cart-coupon-row{flex-wrap:wrap}
 .cart-coupon-row input{flex:1 1 100%}
 .cart-coupon-apply,.cart-coupon-clear{flex:1 1 calc(50% - 5px)}
}
.cart-primary-btn{width:100%;border:none;border-radius:12px;background:var(--primary-color,#ff0000);color:#fff;padding:12px 14px;cursor:pointer;font-weight:900}
.cart-primary-btn:disabled{opacity:.6;cursor:not-allowed}
.cart-secondary-btn{width:100%;border:1px solid #eee;border-radius:12px;background:#fff;color:#333;padding:12px 14px;cursor:pointer;font-weight:900}
.checkout-form{display:flex;flex-direction:column;gap:10px}
.checkout-form input,.checkout-form textarea{width:100%;border:1px solid #ddd;border-radius:12px;padding:10px 12px;font-size:.95rem;font-family:inherit}
.checkout-form textarea{min-height:90px;resize:vertical}

.checkout-row{display:flex;gap:10px;align-items:stretch}
.checkout-row > *{flex:1}

.geo-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.geo-btn{border:none;border-radius:12px;background:linear-gradient(45deg,var(--primary-color,#ff0000),#ff4d4d);color:#fff;padding:10px 14px;cursor:pointer;font-weight:900;box-shadow:0 10px 20px rgba(255,0,0,0.12)}
.geo-btn:active{transform:scale(0.99)}
.geo-status{font-size:12px;font-weight:900;color:#374151}
.geo-link{font-size:12px;font-weight:900;color:var(--primary-color,#ff0000);text-decoration:none}

.auth-actions{display:flex;gap:10px}
.auth-actions .cart-primary-btn,.auth-actions .cart-secondary-btn{width:auto;flex:1}
.auth-hint{font-size:12px;font-weight:900;color:#6b7280;line-height:1.45}
.auth-error{display:none;margin-top:8px;color:#b91c1c;font-weight:900;font-size:13px}

.cart-addons{margin-top:14px;padding-top:12px;border-top:1px solid #f0f0f0}
.cart-addons-title{font-weight:900;color:#111;margin:0 0 10px 0;font-size:.98rem;display:flex;align-items:center;justify-content:space-between}
.cart-addons-title:after{content:'';height:2px;flex:1;margin-right:10px;background:linear-gradient(90deg,rgba(255,0,0,0.35),rgba(255,0,0,0))}

.cart-addons-scroll{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-snap-type:x mandatory;padding:2px 2px 8px 2px}
.cart-addons-scroll::-webkit-scrollbar{display:none}
.cart-addons-track{display:flex;gap:12px;padding-bottom:6px}

.cart-addon-card{flex:0 0 156px;border-radius:18px;overflow:hidden;position:relative;scroll-snap-align:start;background:linear-gradient(180deg,#fff 0%,#fbfbfb 100%);box-shadow:0 10px 28px rgba(15,23,42,0.10);transform:translateY(0);transition:transform .18s ease,box-shadow .18s ease}
.cart-addon-card:before{content:'';position:absolute;inset:0;padding:1px;border-radius:18px;background:linear-gradient(135deg,rgba(255,0,0,0.35),rgba(255,0,0,0.10),rgba(0,0,0,0));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.cart-addon-card:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(15,23,42,0.14)}

.cart-addon-img{width:100%;height:96px;object-fit:cover;background:#f6f6f6;display:block}
.cart-addon-name{padding:10px 12px 0 12px;font-weight:900;color:#111;font-size:13px;line-height:1.35;min-height:36px}
.cart-addon-footer{padding:10px 12px 12px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.cart-addon-price{font-weight:900;color:var(--primary-color,#ff0000);font-size:12.5px;white-space:nowrap}
.cart-addon-add{border:none;border-radius:12px;padding:8px 12px;font-weight:900;cursor:pointer;background:linear-gradient(45deg,var(--primary-color,#ff0000),#ff4d4d);color:#fff;font-size:12px;white-space:nowrap;box-shadow:0 8px 18px rgba(255,0,0,0.18);transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}
.cart-addon-add:hover{filter:brightness(1.02);box-shadow:0 10px 22px rgba(255,0,0,0.22)}
.cart-addon-add:active{transform:scale(0.98)}

.cart-notes{margin-top:14px;padding-top:12px;border-top:1px solid #f0f0f0}
.cart-notes-title{font-weight:900;color:#111;margin:0 0 10px 0;font-size:.98rem;display:flex;align-items:center;justify-content:space-between}
.cart-notes-title:after{content:'';height:2px;flex:1;margin-right:10px;background:linear-gradient(90deg,rgba(255,0,0,0.35),rgba(255,0,0,0))}
.cart-notes textarea{width:100%;min-height:84px;resize:vertical;border-radius:16px;border:1px solid #e5e7eb;padding:12px 12px;font-weight:800;font-size:14px;line-height:1.6;background:#fff;outline:none}
.cart-notes textarea:focus{border-color:rgba(255,0,0,0.55);box-shadow:0 0 0 4px rgba(255,0,0,0.12)}

.orders-modal-overlay{position:fixed;inset:0;background:var(--cart-overlay);display:none;z-index:2000}
.orders-modal-overlay.active{display:block}
.orders-modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:min(520px,92vw);max-height:85vh;background:var(--cart-bg);border-radius:var(--cart-radius);box-shadow:0 12px 40px rgba(0,0,0,.25);display:none;z-index:2001;overflow:hidden}
.orders-modal.active{display:flex;flex-direction:column}
.orders-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #eee}
.orders-modal-title{font-weight:800;font-size:1.05rem;color:#111}
.orders-modal-body{padding:12px 16px;overflow:auto}
