#include #define debug(x) cerr<<#x<<" = "< #define mp make_pair #define pb push_back using namespace std; inline LL read(){ LL nm=0; bool fh=1; char cw=getchar(); for(;!isdigit(cw);cw=getchar()) fh^=(cw=='-'); for(;isdigit(cw);cw=getchar()) nm=nm*10+(cw-'0'); return fh?nm:-nm; } #define mod 998244353 namespace CALC{ inline int add(int x,int y){return (x+y>=mod)?(x+y-mod):(x+y);} inline int mns(int x,int y){return (x-y<0)?(x-y+mod):(x-y);} inline int mul(LL x,LL y){return x*y%mod;} inline void upd(int &x,int y){x=(x+y>=mod)?(x+y-mod):(x+y);} inline void dec(int &x,int y){x=(x-y<0)?(x-y+mod):(x-y);} inline int qpow(int x,int sq){LL res=1;for(;sq;sq>>=1,x=mul(x,x))if(sq&1)res=mul(res,x);return res;} }using namespace CALC; #define M 1100010 int n,m,ans; inline void dn(int &x,int y){(x>y)?(x=y):0;} inline int solve(){ n=read(),m=read(),memset(&ans,0x3f,sizeof(int)); while(n--){ int x=read(),y=read(); dn(ans,y*((m-1)/x+1)); } return ans; } int main(){ for(int Cas=read();Cas;--Cas) printf("%d\n",solve()); return 0; }