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)}constC=g;functionQ(A,I){returnBigInt(A)<<BigInt(I)}functionB(A,I){returnBigInt(A)>>BigInt(I)}constt=Q,i=B;varE=Object.freeze({__proto__:null,fromString:g,e:C,fromArray:function(A,I){letg=0n;I=BigInt(I);for(letC=0;C<A.length;C++)g=g*I+BigInt(A[C]);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:Q,shiftRight:B,shl:t,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=[];letC=BigInt(A);for(I=BigInt(I);C;)g.unshift(Number(C%I)),C/=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)}}),e="undefined"!=typeofglobalThis?globalThis:"undefined"!=typeofwindow?window:"undefined"!=typeofglobal?global:"undefined"!=typeofself?self:{};functionn(A){if(A.__esModule)returnA;varI=Object.defineProperty({},"__esModule",{value:!0});returnObject.keys(A).forEach((function(g){varC=Object.getOwnPropertyDescriptor(A,g);Object.defineProperty(I,g,C.get?C:{enumerable:!0,get:function(){returnA[g]}})})),I}functionh(A){varI={exports:{}};returnA(I,I.exports),I.exports}varo=h((function(A){varI=function(A){varg=1e7,C=9007199254740992,Q=o(C),B="0123456789abcdefghijklmnopqrstuvwxyz",t="function"==typeofBigInt;functioni(A,I,g,C){returnvoid0===A?i[0]:void0!==I&&(10!=+I||g)?Z(A,I,g,C):j(A)}functionE(A,I){this.value=A,this.sign=I,this.isSmall=!1}functione(A){this.value=A,this.sign=A<0,this.isSmall=!0}functionn(A){this.value=A}functionh(A){return-C<A&&A<C}functiono(A){returnA<1e7?[A]:A<1e14?[A%1e7,Math.floor(A/1e7)]:[A%1e7,Math.floor(A/1e7)%1e7,Math.floor(A/1e14)]}functions(A){r(A);varI=A.length;if(I<4&&L(A,Q)<0)switch(I){case0:return0;case1:returnA[0];case2:returnA[0]+A[1]*g;default:returnA[0]+(A[1]+A[2]*g)*g}returnA}functionr(A){for(varI=A.length;0===A[--I];);A.length=I+1}functionf(A){for(varI=newArray(A),g=-1;++g<A;)I[g]=0;returnI}functiona(A){returnA>0?Math.floor(A):Math.ceil(A)}functionw(A,I){varC,Q,B=A.length,t=I.length,i=newArray(B),E=0,e=g;for(Q=0;Q<t;Q++)E=(C=A[Q]+I[Q]+E)>=e?1:0,i[Q]=C-E*e;for(;Q<B;)E=(C=A[Q]+E)===e?1:0,i[Q++]=C-E*e;returnE>0&&i.push(E),i}functionD(A,I){returnA.length>=I.length?w(A,I):w(I,A)}functiony(A,I){varC,Q,B=A.length,t=newArray(B),i=g;for(Q=0;Q<B;Q++)C=A[Q]-i+I,I=Math.floor(C/i),t[Q]=C-I*i,I+=1;for(;I>0;)t[Q++]=I%i,I=Math.floor(I/i);returnt}functionc(A,I){varC,Q,B=A.length,t=I.length,i=newArray(B),E=0,e=g;for(C=0;C<t;C++)(Q=A[C]-E-I[C])<0?(Q+=e,E=1):E=0,i[C]=Q;for(C=t;C<B;C++){if(!((Q=A[C]-E)<0)){i[C++]=Q;break}Q+=e,i[C]=Q}for(;C<B;C++)i[C]=A[