#CartDrawerRoot{position:fixed;inset:0;z-index:9999;display:none}
#CartDrawerRoot.is-open{display:block}
#CartDrawerOverlay{position:absolute;inset:0;background:rgba(0,0,0,.55)}
#CartDrawerPanel{position:absolute;top:0;right:0;height:100%;width:min(420px,92vw);background:#0b0b0b;color:#fff;box-shadow:-20px 0 60px rgba(0,0,0,.5);display:flex;flex-direction:column}
.CartDrawerHeader{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid rgba(255,255,255,.08)}
.CartDrawerTitle{font-size:16px;font-weight:700;letter-spacing:.2px}
.CartDrawerClose{background:transparent;border:0;color:#fff;font-size:22px;cursor:pointer;line-height:1}
.CartDrawerBody{padding:12px 16px;overflow:auto;flex:1}
.CartItem{display:grid;grid-template-columns:72px 1fr;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.CartItemImg img{width:72px;height:72px;object-fit:cover;border-radius:12px;display:block}
.CartItemTitle{font-size:13px;font-weight:700;margin:0 0 6px}
.CartItemMeta{font-size:12px;opacity:.75;margin:0 0 10px}
.CartItemRow{display:flex;align-items:center;justify-content:space-between;gap:10px}
.Qty{display:flex;align-items:center;gap:8px}
.QtyBtn{width:30px;height:30px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:transparent;color:#fff;cursor:pointer}
.QtyVal{min-width:18px;text-align:center;font-size:13px}
.RemoveBtn{background:transparent;border:0;color:rgba(255,255,255,.8);cursor:pointer;font-size:12px;text-decoration:underline;margin-top:8px}
.Price{font-size:13px;font-weight:700}
.CartDrawerFooter{padding:16px;border-top:1px solid rgba(255,255,255,.08)}
.SubtotalRow{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px}
.CheckoutBtn{width:100%;padding:14px 16px;border-radius:14px;border:0;cursor:pointer;font-weight:800}
.CheckoutBtn:disabled{opacity:.6;cursor:not-allowed}
.EmptyState{padding:20px 0;opacity:.85;font-size:14px}