varsnarkjs=function(A){"use strict";constI=[0,1,2,2,3,3,3,3,4,4,4,4,4,4,4,4];functiong(A,I){returnI&&10!=I?16==I?"0x"==A.slice(0,2)?BigInt(A):BigInt("0x"+A):void0:BigInt(A)}constQ=g;functionC(A,I){returnBigInt(A)<<BigInt(I)}functionB(A,I){returnBigInt(A)>>BigInt(I)}constE=C,i=B;vart=Object.freeze({__proto__:null,fromString:g,e:Q,fromArray:function(A,I){letg=0n;I=BigInt(I);for(letQ=0;Q<A.length;Q++)g=g*I+BigInt(A[Q]);returng},bitLength:function(A){constg=A.toString(16);return4*(g.length-1)+I[parseInt(g[0],16)]},isNegative:function(A){returnBigInt(A)<0n},isZero:function(A){return!A},shiftLeft:C,shiftRight:B,shl:E,shr:i,isOdd:function(A){return1n==(1n&BigInt(A))},naf:function(A){letI=BigInt(A);constg=[];for(;I;){if(1n&I){constA=2-Number(I%4n);g.push(A),I-=BigInt(A)}elseg.push(0);I>>=1n}returng},bits:function(A){letI=BigInt(A);constg=[];for(;I;)1n&I?g.push(1):g.push(0),I>>=1n;returng},toNumber:function(A){if(A>BigInt(Number.MAX_SAFE_INTEGER))thrownewError("Number too big");returnNumber(A)},toArray:function(A,I){constg=[];letQ=BigInt(A);for(I=BigInt(I);Q;)g.unshift(Number(Q%I)),Q/=I;returng},add:function(A,I){returnBigInt(A)+BigInt(I)},sub:function(A,I){returnBigInt(A)-BigInt(I)},neg:function(A){return-BigInt(A)},mul:function(A,I){returnBigInt(A)*BigInt(I)},square:function(A){returnBigInt(A)*BigInt(A)},pow:function(A,I){returnBigInt(A)**BigInt(I)},exp:function(A,I){returnBigInt(A)**BigInt(I)},abs:function(A){returnBigInt(A)>=0?BigInt(A):-BigInt(A)},div:function(A,I){returnBigInt(A)/BigInt(I)},mod:function(A,I){returnBigInt(A)%BigInt(I)},eq:function(A,I){returnBigInt(A)==BigInt(I)},neq:function(A,I){returnBigInt(A)!=BigInt(I)},lt:function(A,I){returnBigInt(A)<BigInt(I)},gt:function(A,I){returnBigInt(A)>BigInt(I)},leq:function(A,I){returnBigInt(A)<=BigInt(I)},geq:function(A,I){returnBigInt(A)>=BigInt(I)},band:function(A,I){returnBigInt(A)&BigInt(I)},bor:function(A,I){returnBigInt(A)|BigInt(I)},bxor:function(A,I){returnBigInt(A)^BigInt(I)},land:function(A,I){returnBigInt(A)&&BigInt(I)},lor:function(A,I){returnBigInt(A)||BigInt(I)},lnot:function(A){return!BigInt(A)}}),h="undefined"!=typeofglobalThis?globalThis:"undefined"!=typeofwindow?window:"undefined"!=typeofglobal?global:"undefined"!=typeofself?self:{};functionD(A){if(A.__esModule)returnA;varI=Object.defineProperty({},"__esModule",{value:!0});returnObject.keys(A).forEach((function(g){varQ=Object.getOwnPropertyDescriptor(A,g);Object.defineProperty(I,g,Q.get?Q:{enumerable:!0,get:function(){returnA[g]}})})),I}functionn(A){varI={exports:{}};returnA(I,I.exports),I.exports}varw=n((function(A){varI=function(A){varg=1e7,Q=9007199254740992,C=w(Q),B="0123456789abcdefghijklmnopqrstuvwxyz",E="function"==typeofBigInt;functioni(A,I,g,Q){returnvoid0===A?i[0]:void0!==I&&(10!=+I||g)?Z(A,I,g,Q):O(A)}functiont(A,I){this.value=A,this.sign=I,this.isSmall=!1}functionh(A){this.value=A,this.sign=A<0,this.isSmall=!0}functionD(A){this.value=A}functionn(A){return-Q<A&&A<Q}functionw(A){returnA<1e7?[A]:A<1e14?[A%1e7,Math.floor(A/1e7)]:[A%1e7,Math.floor(A/1e7)%1e7,Math.floor(A/1e14)]}functione(A){f(A);varI=A.length;if(I<4&&k(A,C)<0)switch(I){case0:return0;case1:returnA[0];case2:returnA[0]+A[1]*g;default:returnA[0]+(A[1]+A[2]*g)*g}returnA}functionf(A){for(varI=A.length;0===A[--I];);A.length=I+1}functiono(A){for(varI=newArray(A),g=-1;++g<A;)I[g]=0;returnI}functions(A){returnA>0?Math.floor(A):Math.ceil(A)}functionr(A,I){varQ,C,B=A.length,E=I.length,i=newArray(B),t=0,h=g;for(C=0;C<E;C++)t=(Q=A[C]+I[C]+t)>=h?1:0,i[C]=Q-t*h;for(;C<B;)t=(Q=A[C]+t)===h?1:0,i[C++]=Q-t*h;returnt>0&&i.push(t),i}functiona(A,I){returnA.length>=I.length?r(A,I):r(I,A)}functiony(A,I){varQ,C,B=A.length,E=newArray(B),i=g;for(C=0;C<B;C++)Q=A[C]-i+I,I=Math.floor(Q/i),E[C]=Q-I*i,I+=1;for(;I>0;)E[C++]=I%i,I=Math.floor(I/i);returnE}functionF(A,I){varQ,C,B=A.length,E=I.length,i=newArray(B),t=0,h=g;for(Q=0;Q<E;Q++)(C=A[Q]-t-I[Q])<0?(C+=h,t=1):t=0,i[Q]=C;for(Q=E;Q<B;Q++){if(!((C=A[Q]-t)<0)){i[Q++]=C;break}C+=h,i[Q]=C}for(;Q<B;Q++)i[Q]=A[